[GitHub] brooklyn-docs pull request #180: Update bundle upload
Github user asfgit closed the pull request at: https://github.com/apache/brooklyn-docs/pull/180 --- If your project is set up for it, you can reply to this email and have your reply appear on GitHub as well. If your project does not have this feature enabled and wishes so, or if the feature is enabled but not working, please contact infrastructure at infrastruct...@apache.org or file a JIRA ticket with INFRA. ---
[GitHub] brooklyn-docs pull request #180: Update bundle upload
Github user alasdairhodge commented on a diff in the pull request: https://github.com/apache/brooklyn-docs/pull/180#discussion_r117459280 --- Diff: guide/blueprints/catalog/index.md --- @@ -371,6 +373,126 @@ increment an internal version number for the catalog item. When referencing a blueprint, if a version number is not specified the latest non-snapshot version will be loaded when an entity is instantiated. +### Bundling Catalog Resources + +It is possible to add an OSGi bundle to AMP. This is useful when you have a blueprint that needs to reference external scripts/resources or when you have multiple blueprints that you want to keep in sync. Brooklyn will persist any uploaded bundles so that they are available after a restart, or a HA failover. + +In this example, we will create a simple `my-server` catalog item, bundled with a simple script. The script will be run when launching the server. + +First, create a folder called bundleFolder, then add a file called myfile.sh to it. +The contents of myfile.sh should be as follows: + +~~~ bash +echo Hello, World! +~~~ + +Now create a file in bundleFolder called `catalog.bom` with the following contents: + +~~~ yaml +brooklyn.catalog: + bundle: MyServerBundle + version: 1.0.0 + item: +id: my-server +type: org.apache.brooklyn.entity.software.base.VanillaSoftwareProcess +brooklyn.config: + files.runtime: +classpath://myfile.sh: files/myfile.sh + launch.command: | +chmod +x ./files/myfile.sh +./files/myfile.sh + + checkRunning.command: +echo "Running" + +~~~ + +The `bundle: MyServerBundle` line specifies the OSGI bundle name for this bundle. Any resources included +in this bundle will be accessible on the classpath, but will be scoped to this bundle. This prevents an +issue where multiple bundles include the same resource. + +To create the bundle, simply use the BR command as follows: + +~~~ bash +br add-catalog bundleFolder --- End diff -- `add-catalog` is deprected in favour of `catalog add` --- If your project is set up for it, you can reply to this email and have your reply appear on GitHub as well. If your project does not have this feature enabled and wishes so, or if the feature is enabled but not working, please contact infrastructure at infrastruct...@apache.org or file a JIRA ticket with INFRA. ---
[GitHub] brooklyn-docs pull request #180: Update bundle upload
Github user Graeme-Miller commented on a diff in the pull request: https://github.com/apache/brooklyn-docs/pull/180#discussion_r117458781 --- Diff: guide/blueprints/catalog/index.md --- @@ -375,153 +375,120 @@ the latest non-snapshot version will be loaded when an entity is instantiated. ### Bundling Catalog Resources -When deploying a blueprint, it is possible to deploy it as an OSGI bundle with additional resources scoped -to this bundle. This is particularly useful when, for example, deploying a Tomcat server with a `.war` file -which is deployed using a classpath path such as `classpath://mywar.war`. +It is possible to add an OSGi bundle to AMP. This is useful when you have a blueprint that needs to reference external scripts/resources or when you have multiple blueprints that you want to keep in sync. Brooklyn will persist any uploaded bundles so that they are available after a restart, or a HA failover. -In this example, we will create a simple `server` catalog item, bundled with a simple text file. +In this example, we will create a simple `my-server` catalog item, bundled with a simple script. The script will be run when launching the server. -First, create the text file with some sample contents: +First, create a folder called bundleFolder, then add a file called myfile.sh to it. +The contents of myfile.sh should be as follows: ~~~ bash -echo Hello, World! > myfile.txt +echo Hello, World! ~~~ -Now create a file called `catalog.bom` with the following contents: +Now create a file in bundleFolder called `catalog.bom` with the following contents: ~~~ yaml brooklyn.catalog: - bundle: script-server + bundle: MyServerBundle version: 1.0.0 - items: - - id: script-server -itemType: entity -item: - type: server - brooklyn.config: -files.runtime: - classpath://myfile.txt: files/myfile.txt + item: +id: my-server +type: org.apache.brooklyn.entity.software.base.VanillaSoftwareProcess +brooklyn.config: + files.runtime: +classpath://myfile.sh: files/myfile.sh + launch.command: | +chmod +x ./files/myfile.sh +./files/myfile.sh + + checkRunning.command: +echo "Running" + ~~~ -The `bundle: script-server` line specifies the OSGI bundle name for this blueprint. Any resources included +The `bundle: MyServerBundle` line specifies the OSGI bundle name for this bundle. Any resources included in this bundle will be accessible on the classpath, but will be scoped to this bundle. This prevents an issue where multiple bundles include the same resource. -To create the bundle, simply zip the `.bom` and `.txt` files as follows: +To create the bundle, simply use the BR command as follows: ~~~ bash -zip script-server.zip catalog.bom myfile.txt +br add-catalog bundleFolder ~~~ -Currently the only supported method for uploading the bundle to the server is via the API, e.g. using -`curl`: - -~~~ bash -curl -X POST -u admin:password -H "Content-Type: application/zip" --data-binary @/tmp/zip/script-server.zip "http://127.0.0.1:8081/v1/catalog; -~~~ - -We can now deploy an instance of our script server as follows: +This will have added our bundle to the catalog. We can now deploy an instance of our server as follows: ~~~ yaml location: localhost services: -- type: script-server +- type: my-server ~~~ -And we can now inspect the contents of the file copied to the server +We can now see the result of running that script. In the UI find the activities for this application. The start activity has a sub task called launch (you will have to click through multiple activities called start/launch. Looking at the stdout of the launch task you should see: -~~~ bash -cat /tmp/brooklyn-martin/apps/nl9djqbq2i/entities/EmptySoftwareProcess_g52gahfxnt/files/myfile.txt -~~~ -~~~ bash +~~~ bash Hello, World! ~~~ -Now modify `myfile.txt` to contain a different message, change the version number in `catalog.bom` to -`1.1.0`, re-build the zip file and re-post it to the server - -If you now deploy a new instance of the script-server using the same YAML as used above, you should be -able to confirm that the new script has been copied to the server: - +Alternatively you can view the script directly if you ran this against localhost: ~~~ bash -cat /tmp/brooklyn-martin/apps/bwu57darkd/entities/EmptySoftwareProcess_umcgshzduk/files/myfile.txt +cat /tmp/brooklyn-username/apps/nl9djqbq2i/entities/EmptySoftwareProcess_g52gahfxnt/files/myfile.sh ~~~
[GitHub] brooklyn-docs pull request #180: Update bundle upload
Github user drigodwin commented on a diff in the pull request: https://github.com/apache/brooklyn-docs/pull/180#discussion_r115700104 --- Diff: guide/blueprints/catalog/index.md --- @@ -371,6 +373,126 @@ increment an internal version number for the catalog item. When referencing a blueprint, if a version number is not specified the latest non-snapshot version will be loaded when an entity is instantiated. +### Bundling Catalog Resources + +It is possible to add an OSGi bundle to AMP. This is useful when you have a blueprint that needs to reference external scripts/resources or when you have multiple blueprints that you want to keep in sync. Brooklyn will persist any uploaded bundles so that they are available after a restart, or a HA failover. + +In this example, we will create a simple `my-server` catalog item, bundled with a simple script. The script will be run when launching the server. + +First, create a folder called bundleFolder, then add a file called myfile.sh to it. +The contents of myfile.sh should be as follows: + +~~~ bash +echo Hello, World! +~~~ + +Now create a file in bundleFolder called `catalog.bom` with the following contents: + +~~~ yaml +brooklyn.catalog: + bundle: MyServerBundle + version: 1.0.0 + item: +id: my-server +type: org.apache.brooklyn.entity.software.base.VanillaSoftwareProcess +brooklyn.config: + files.runtime: +classpath://myfile.sh: files/myfile.sh + launch.command: | +chmod +x ./files/myfile.sh +./files/myfile.sh + + checkRunning.command: +echo "Running" + +~~~ + +The `bundle: MyServerBundle` line specifies the OSGI bundle name for this bundle. Any resources included +in this bundle will be accessible on the classpath, but will be scoped to this bundle. This prevents an +issue where multiple bundles include the same resource. + +To create the bundle, simply use the BR command as follows: + +~~~ bash +br add-catalog bundleFolder +~~~ + +This will have added our bundle to the catalog. We can now deploy an instance of our server as follows: + +~~~ yaml +location: localhost +services: +- type: my-server +~~~ + +We can now see the result of running that script. In the UI find the activities for this application. The start activity has a sub task called launch (you will have to click through multiple activities called start/launch. Looking at the stdout of the launch task you should see: + +~~~ bash +Hello, World! +~~~ + +Alternatively you can view the script directly if you ran this against localhost: --- End diff -- ran -> run --- If your project is set up for it, you can reply to this email and have your reply appear on GitHub as well. If your project does not have this feature enabled and wishes so, or if the feature is enabled but not working, please contact infrastructure at infrastruct...@apache.org or file a JIRA ticket with INFRA. ---
[GitHub] brooklyn-docs pull request #180: Update bundle upload
Github user drigodwin commented on a diff in the pull request: https://github.com/apache/brooklyn-docs/pull/180#discussion_r115700585 --- Diff: guide/blueprints/catalog/index.md --- @@ -371,6 +373,126 @@ increment an internal version number for the catalog item. When referencing a blueprint, if a version number is not specified the latest non-snapshot version will be loaded when an entity is instantiated. +### Bundling Catalog Resources + +It is possible to add an OSGi bundle to AMP. This is useful when you have a blueprint that needs to reference external scripts/resources or when you have multiple blueprints that you want to keep in sync. Brooklyn will persist any uploaded bundles so that they are available after a restart, or a HA failover. + +In this example, we will create a simple `my-server` catalog item, bundled with a simple script. The script will be run when launching the server. + +First, create a folder called bundleFolder, then add a file called myfile.sh to it. +The contents of myfile.sh should be as follows: + +~~~ bash +echo Hello, World! +~~~ + +Now create a file in bundleFolder called `catalog.bom` with the following contents: + +~~~ yaml +brooklyn.catalog: + bundle: MyServerBundle + version: 1.0.0 + item: +id: my-server +type: org.apache.brooklyn.entity.software.base.VanillaSoftwareProcess +brooklyn.config: + files.runtime: +classpath://myfile.sh: files/myfile.sh + launch.command: | +chmod +x ./files/myfile.sh +./files/myfile.sh + + checkRunning.command: +echo "Running" + +~~~ + +The `bundle: MyServerBundle` line specifies the OSGI bundle name for this bundle. Any resources included +in this bundle will be accessible on the classpath, but will be scoped to this bundle. This prevents an +issue where multiple bundles include the same resource. + +To create the bundle, simply use the BR command as follows: + +~~~ bash +br add-catalog bundleFolder +~~~ + +This will have added our bundle to the catalog. We can now deploy an instance of our server as follows: + +~~~ yaml +location: localhost --- End diff -- If you're going to use localhost for an example, probably link to the localhost configuration section. It might be better to assume people are using vagrant and use the byon location from the getting started. --- If your project is set up for it, you can reply to this email and have your reply appear on GitHub as well. If your project does not have this feature enabled and wishes so, or if the feature is enabled but not working, please contact infrastructure at infrastruct...@apache.org or file a JIRA ticket with INFRA. ---
[GitHub] brooklyn-docs pull request #180: Update bundle upload
Github user drigodwin commented on a diff in the pull request: https://github.com/apache/brooklyn-docs/pull/180#discussion_r115700370 --- Diff: guide/blueprints/catalog/index.md --- @@ -371,6 +373,126 @@ increment an internal version number for the catalog item. When referencing a blueprint, if a version number is not specified the latest non-snapshot version will be loaded when an entity is instantiated. +### Bundling Catalog Resources + +It is possible to add an OSGi bundle to AMP. This is useful when you have a blueprint that needs to reference external scripts/resources or when you have multiple blueprints that you want to keep in sync. Brooklyn will persist any uploaded bundles so that they are available after a restart, or a HA failover. + +In this example, we will create a simple `my-server` catalog item, bundled with a simple script. The script will be run when launching the server. + +First, create a folder called bundleFolder, then add a file called myfile.sh to it. +The contents of myfile.sh should be as follows: + +~~~ bash +echo Hello, World! +~~~ + +Now create a file in bundleFolder called `catalog.bom` with the following contents: + +~~~ yaml +brooklyn.catalog: + bundle: MyServerBundle + version: 1.0.0 + item: +id: my-server +type: org.apache.brooklyn.entity.software.base.VanillaSoftwareProcess +brooklyn.config: + files.runtime: +classpath://myfile.sh: files/myfile.sh + launch.command: | +chmod +x ./files/myfile.sh +./files/myfile.sh + + checkRunning.command: +echo "Running" + +~~~ + +The `bundle: MyServerBundle` line specifies the OSGI bundle name for this bundle. Any resources included +in this bundle will be accessible on the classpath, but will be scoped to this bundle. This prevents an +issue where multiple bundles include the same resource. + +To create the bundle, simply use the BR command as follows: + +~~~ bash +br add-catalog bundleFolder +~~~ + +This will have added our bundle to the catalog. We can now deploy an instance of our server as follows: + +~~~ yaml +location: localhost +services: +- type: my-server +~~~ + +We can now see the result of running that script. In the UI find the activities for this application. The start activity has a sub task called launch (you will have to click through multiple activities called start/launch. Looking at the stdout of the launch task you should see: + +~~~ bash +Hello, World! +~~~ + +Alternatively you can view the script directly if you ran this against localhost: + +~~~ bash +cat /tmp/brooklyn-username/apps/nl9djqbq2i/entities/EmptySoftwareProcess_g52gahfxnt/files/myfile.sh --- End diff -- you should probably indicate `nl9djqbq2i` and `g52gahfxnt` will be different on the users machine --- If your project is set up for it, you can reply to this email and have your reply appear on GitHub as well. If your project does not have this feature enabled and wishes so, or if the feature is enabled but not working, please contact infrastructure at infrastruct...@apache.org or file a JIRA ticket with INFRA. ---
[GitHub] brooklyn-docs pull request #180: Update bundle upload
Github user nakomis commented on a diff in the pull request: https://github.com/apache/brooklyn-docs/pull/180#discussion_r115698327 --- Diff: guide/blueprints/catalog/index.md --- @@ -375,153 +375,120 @@ the latest non-snapshot version will be loaded when an entity is instantiated. ### Bundling Catalog Resources -When deploying a blueprint, it is possible to deploy it as an OSGI bundle with additional resources scoped -to this bundle. This is particularly useful when, for example, deploying a Tomcat server with a `.war` file -which is deployed using a classpath path such as `classpath://mywar.war`. +It is possible to add an OSGi bundle to AMP. This is useful when you have a blueprint that needs to reference external scripts/resources or when you have multiple blueprints that you want to keep in sync. Brooklyn will persist any uploaded bundles so that they are available after a restart, or a HA failover. -In this example, we will create a simple `server` catalog item, bundled with a simple text file. +In this example, we will create a simple `my-server` catalog item, bundled with a simple script. The script will be run when launching the server. -First, create the text file with some sample contents: +First, create a folder called bundleFolder, then add a file called myfile.sh to it. +The contents of myfile.sh should be as follows: ~~~ bash -echo Hello, World! > myfile.txt +echo Hello, World! ~~~ -Now create a file called `catalog.bom` with the following contents: +Now create a file in bundleFolder called `catalog.bom` with the following contents: ~~~ yaml brooklyn.catalog: - bundle: script-server + bundle: MyServerBundle version: 1.0.0 - items: - - id: script-server -itemType: entity -item: - type: server - brooklyn.config: -files.runtime: - classpath://myfile.txt: files/myfile.txt + item: +id: my-server +type: org.apache.brooklyn.entity.software.base.VanillaSoftwareProcess +brooklyn.config: + files.runtime: +classpath://myfile.sh: files/myfile.sh + launch.command: | +chmod +x ./files/myfile.sh +./files/myfile.sh + + checkRunning.command: +echo "Running" + ~~~ -The `bundle: script-server` line specifies the OSGI bundle name for this blueprint. Any resources included +The `bundle: MyServerBundle` line specifies the OSGI bundle name for this bundle. Any resources included in this bundle will be accessible on the classpath, but will be scoped to this bundle. This prevents an issue where multiple bundles include the same resource. -To create the bundle, simply zip the `.bom` and `.txt` files as follows: +To create the bundle, simply use the BR command as follows: ~~~ bash -zip script-server.zip catalog.bom myfile.txt +br add-catalog bundleFolder --- End diff -- Would be good to mention that we also support .zip --- If your project is set up for it, you can reply to this email and have your reply appear on GitHub as well. If your project does not have this feature enabled and wishes so, or if the feature is enabled but not working, please contact infrastructure at infrastruct...@apache.org or file a JIRA ticket with INFRA. ---
[GitHub] brooklyn-docs pull request #180: Update bundle upload
Github user nakomis commented on a diff in the pull request: https://github.com/apache/brooklyn-docs/pull/180#discussion_r115697990 --- Diff: guide/blueprints/catalog/index.md --- @@ -375,153 +375,120 @@ the latest non-snapshot version will be loaded when an entity is instantiated. ### Bundling Catalog Resources -When deploying a blueprint, it is possible to deploy it as an OSGI bundle with additional resources scoped -to this bundle. This is particularly useful when, for example, deploying a Tomcat server with a `.war` file -which is deployed using a classpath path such as `classpath://mywar.war`. +It is possible to add an OSGi bundle to AMP. This is useful when you have a blueprint that needs to reference external scripts/resources or when you have multiple blueprints that you want to keep in sync. Brooklyn will persist any uploaded bundles so that they are available after a restart, or a HA failover. -In this example, we will create a simple `server` catalog item, bundled with a simple text file. +In this example, we will create a simple `my-server` catalog item, bundled with a simple script. The script will be run when launching the server. -First, create the text file with some sample contents: +First, create a folder called bundleFolder, then add a file called myfile.sh to it. +The contents of myfile.sh should be as follows: ~~~ bash -echo Hello, World! > myfile.txt +echo Hello, World! ~~~ -Now create a file called `catalog.bom` with the following contents: +Now create a file in bundleFolder called `catalog.bom` with the following contents: ~~~ yaml brooklyn.catalog: - bundle: script-server + bundle: MyServerBundle version: 1.0.0 - items: - - id: script-server -itemType: entity -item: - type: server - brooklyn.config: -files.runtime: - classpath://myfile.txt: files/myfile.txt + item: +id: my-server +type: org.apache.brooklyn.entity.software.base.VanillaSoftwareProcess +brooklyn.config: + files.runtime: +classpath://myfile.sh: files/myfile.sh + launch.command: | +chmod +x ./files/myfile.sh +./files/myfile.sh + + checkRunning.command: +echo "Running" + ~~~ -The `bundle: script-server` line specifies the OSGI bundle name for this blueprint. Any resources included +The `bundle: MyServerBundle` line specifies the OSGI bundle name for this bundle. Any resources included in this bundle will be accessible on the classpath, but will be scoped to this bundle. This prevents an issue where multiple bundles include the same resource. -To create the bundle, simply zip the `.bom` and `.txt` files as follows: +To create the bundle, simply use the BR command as follows: --- End diff -- BR -> \`br\`, also include a link to download the CLI. It would also be nice to include at least one example of how to use `curl` instead of `br` --- If your project is set up for it, you can reply to this email and have your reply appear on GitHub as well. If your project does not have this feature enabled and wishes so, or if the feature is enabled but not working, please contact infrastructure at infrastruct...@apache.org or file a JIRA ticket with INFRA. ---
[GitHub] brooklyn-docs pull request #180: Update bundle upload
Github user nakomis commented on a diff in the pull request: https://github.com/apache/brooklyn-docs/pull/180#discussion_r115699050 --- Diff: guide/blueprints/catalog/index.md --- @@ -375,153 +375,120 @@ the latest non-snapshot version will be loaded when an entity is instantiated. ### Bundling Catalog Resources -When deploying a blueprint, it is possible to deploy it as an OSGI bundle with additional resources scoped -to this bundle. This is particularly useful when, for example, deploying a Tomcat server with a `.war` file -which is deployed using a classpath path such as `classpath://mywar.war`. +It is possible to add an OSGi bundle to AMP. This is useful when you have a blueprint that needs to reference external scripts/resources or when you have multiple blueprints that you want to keep in sync. Brooklyn will persist any uploaded bundles so that they are available after a restart, or a HA failover. -In this example, we will create a simple `server` catalog item, bundled with a simple text file. +In this example, we will create a simple `my-server` catalog item, bundled with a simple script. The script will be run when launching the server. -First, create the text file with some sample contents: +First, create a folder called bundleFolder, then add a file called myfile.sh to it. +The contents of myfile.sh should be as follows: ~~~ bash -echo Hello, World! > myfile.txt +echo Hello, World! ~~~ -Now create a file called `catalog.bom` with the following contents: +Now create a file in bundleFolder called `catalog.bom` with the following contents: ~~~ yaml brooklyn.catalog: - bundle: script-server + bundle: MyServerBundle version: 1.0.0 - items: - - id: script-server -itemType: entity -item: - type: server - brooklyn.config: -files.runtime: - classpath://myfile.txt: files/myfile.txt + item: +id: my-server +type: org.apache.brooklyn.entity.software.base.VanillaSoftwareProcess +brooklyn.config: + files.runtime: +classpath://myfile.sh: files/myfile.sh + launch.command: | +chmod +x ./files/myfile.sh +./files/myfile.sh + + checkRunning.command: +echo "Running" + ~~~ -The `bundle: script-server` line specifies the OSGI bundle name for this blueprint. Any resources included +The `bundle: MyServerBundle` line specifies the OSGI bundle name for this bundle. Any resources included in this bundle will be accessible on the classpath, but will be scoped to this bundle. This prevents an issue where multiple bundles include the same resource. -To create the bundle, simply zip the `.bom` and `.txt` files as follows: +To create the bundle, simply use the BR command as follows: ~~~ bash -zip script-server.zip catalog.bom myfile.txt +br add-catalog bundleFolder ~~~ -Currently the only supported method for uploading the bundle to the server is via the API, e.g. using -`curl`: - -~~~ bash -curl -X POST -u admin:password -H "Content-Type: application/zip" --data-binary @/tmp/zip/script-server.zip "http://127.0.0.1:8081/v1/catalog; -~~~ - -We can now deploy an instance of our script server as follows: +This will have added our bundle to the catalog. We can now deploy an instance of our server as follows: ~~~ yaml location: localhost services: -- type: script-server +- type: my-server ~~~ -And we can now inspect the contents of the file copied to the server +We can now see the result of running that script. In the UI find the activities for this application. The start activity has a sub task called launch (you will have to click through multiple activities called start/launch. Looking at the stdout of the launch task you should see: -~~~ bash -cat /tmp/brooklyn-martin/apps/nl9djqbq2i/entities/EmptySoftwareProcess_g52gahfxnt/files/myfile.txt -~~~ -~~~ bash +~~~ bash Hello, World! ~~~ -Now modify `myfile.txt` to contain a different message, change the version number in `catalog.bom` to -`1.1.0`, re-build the zip file and re-post it to the server - -If you now deploy a new instance of the script-server using the same YAML as used above, you should be -able to confirm that the new script has been copied to the server: - +Alternatively you can view the script directly if you ran this against localhost: ~~~ bash -cat /tmp/brooklyn-martin/apps/bwu57darkd/entities/EmptySoftwareProcess_umcgshzduk/files/myfile.txt +cat /tmp/brooklyn-username/apps/nl9djqbq2i/entities/EmptySoftwareProcess_g52gahfxnt/files/myfile.sh ~~~
[GitHub] brooklyn-docs pull request #180: Update bundle upload
Github user nakomis commented on a diff in the pull request: https://github.com/apache/brooklyn-docs/pull/180#discussion_r115698765 --- Diff: guide/blueprints/catalog/index.md --- @@ -375,153 +375,120 @@ the latest non-snapshot version will be loaded when an entity is instantiated. ### Bundling Catalog Resources -When deploying a blueprint, it is possible to deploy it as an OSGI bundle with additional resources scoped -to this bundle. This is particularly useful when, for example, deploying a Tomcat server with a `.war` file -which is deployed using a classpath path such as `classpath://mywar.war`. +It is possible to add an OSGi bundle to AMP. This is useful when you have a blueprint that needs to reference external scripts/resources or when you have multiple blueprints that you want to keep in sync. Brooklyn will persist any uploaded bundles so that they are available after a restart, or a HA failover. -In this example, we will create a simple `server` catalog item, bundled with a simple text file. +In this example, we will create a simple `my-server` catalog item, bundled with a simple script. The script will be run when launching the server. -First, create the text file with some sample contents: +First, create a folder called bundleFolder, then add a file called myfile.sh to it. +The contents of myfile.sh should be as follows: ~~~ bash -echo Hello, World! > myfile.txt +echo Hello, World! ~~~ -Now create a file called `catalog.bom` with the following contents: +Now create a file in bundleFolder called `catalog.bom` with the following contents: ~~~ yaml brooklyn.catalog: - bundle: script-server + bundle: MyServerBundle version: 1.0.0 - items: - - id: script-server -itemType: entity -item: - type: server - brooklyn.config: -files.runtime: - classpath://myfile.txt: files/myfile.txt + item: +id: my-server +type: org.apache.brooklyn.entity.software.base.VanillaSoftwareProcess +brooklyn.config: + files.runtime: +classpath://myfile.sh: files/myfile.sh + launch.command: | +chmod +x ./files/myfile.sh +./files/myfile.sh + + checkRunning.command: +echo "Running" + ~~~ -The `bundle: script-server` line specifies the OSGI bundle name for this blueprint. Any resources included +The `bundle: MyServerBundle` line specifies the OSGI bundle name for this bundle. Any resources included in this bundle will be accessible on the classpath, but will be scoped to this bundle. This prevents an issue where multiple bundles include the same resource. -To create the bundle, simply zip the `.bom` and `.txt` files as follows: +To create the bundle, simply use the BR command as follows: ~~~ bash -zip script-server.zip catalog.bom myfile.txt +br add-catalog bundleFolder ~~~ -Currently the only supported method for uploading the bundle to the server is via the API, e.g. using -`curl`: - -~~~ bash -curl -X POST -u admin:password -H "Content-Type: application/zip" --data-binary @/tmp/zip/script-server.zip "http://127.0.0.1:8081/v1/catalog; -~~~ - -We can now deploy an instance of our script server as follows: +This will have added our bundle to the catalog. We can now deploy an instance of our server as follows: ~~~ yaml location: localhost services: -- type: script-server +- type: my-server ~~~ -And we can now inspect the contents of the file copied to the server +We can now see the result of running that script. In the UI find the activities for this application. The start activity has a sub task called launch (you will have to click through multiple activities called start/launch. Looking at the stdout of the launch task you should see: -~~~ bash -cat /tmp/brooklyn-martin/apps/nl9djqbq2i/entities/EmptySoftwareProcess_g52gahfxnt/files/myfile.txt -~~~ -~~~ bash +~~~ bash Hello, World! ~~~ -Now modify `myfile.txt` to contain a different message, change the version number in `catalog.bom` to -`1.1.0`, re-build the zip file and re-post it to the server - -If you now deploy a new instance of the script-server using the same YAML as used above, you should be -able to confirm that the new script has been copied to the server: - +Alternatively you can view the script directly if you ran this against localhost: ~~~ bash -cat /tmp/brooklyn-martin/apps/bwu57darkd/entities/EmptySoftwareProcess_umcgshzduk/files/myfile.txt +cat /tmp/brooklyn-username/apps/nl9djqbq2i/entities/EmptySoftwareProcess_g52gahfxnt/files/myfile.sh --- End
[GitHub] brooklyn-docs pull request #180: Update bundle upload
Github user nakomis commented on a diff in the pull request: https://github.com/apache/brooklyn-docs/pull/180#discussion_r115698151 --- Diff: guide/blueprints/catalog/index.md --- @@ -375,153 +375,120 @@ the latest non-snapshot version will be loaded when an entity is instantiated. ### Bundling Catalog Resources -When deploying a blueprint, it is possible to deploy it as an OSGI bundle with additional resources scoped -to this bundle. This is particularly useful when, for example, deploying a Tomcat server with a `.war` file -which is deployed using a classpath path such as `classpath://mywar.war`. +It is possible to add an OSGi bundle to AMP. This is useful when you have a blueprint that needs to reference external scripts/resources or when you have multiple blueprints that you want to keep in sync. Brooklyn will persist any uploaded bundles so that they are available after a restart, or a HA failover. -In this example, we will create a simple `server` catalog item, bundled with a simple text file. +In this example, we will create a simple `my-server` catalog item, bundled with a simple script. The script will be run when launching the server. -First, create the text file with some sample contents: +First, create a folder called bundleFolder, then add a file called myfile.sh to it. +The contents of myfile.sh should be as follows: ~~~ bash -echo Hello, World! > myfile.txt +echo Hello, World! ~~~ -Now create a file called `catalog.bom` with the following contents: +Now create a file in bundleFolder called `catalog.bom` with the following contents: ~~~ yaml brooklyn.catalog: - bundle: script-server + bundle: MyServerBundle version: 1.0.0 - items: - - id: script-server -itemType: entity -item: - type: server - brooklyn.config: -files.runtime: - classpath://myfile.txt: files/myfile.txt + item: +id: my-server +type: org.apache.brooklyn.entity.software.base.VanillaSoftwareProcess +brooklyn.config: + files.runtime: +classpath://myfile.sh: files/myfile.sh + launch.command: | +chmod +x ./files/myfile.sh +./files/myfile.sh + + checkRunning.command: +echo "Running" + ~~~ -The `bundle: script-server` line specifies the OSGI bundle name for this blueprint. Any resources included +The `bundle: MyServerBundle` line specifies the OSGI bundle name for this bundle. Any resources included in this bundle will be accessible on the classpath, but will be scoped to this bundle. This prevents an issue where multiple bundles include the same resource. -To create the bundle, simply zip the `.bom` and `.txt` files as follows: +To create the bundle, simply use the BR command as follows: ~~~ bash -zip script-server.zip catalog.bom myfile.txt +br add-catalog bundleFolder --- End diff -- `br catalog add` --- If your project is set up for it, you can reply to this email and have your reply appear on GitHub as well. If your project does not have this feature enabled and wishes so, or if the feature is enabled but not working, please contact infrastructure at infrastruct...@apache.org or file a JIRA ticket with INFRA. ---
[GitHub] brooklyn-docs pull request #180: Update bundle upload
Github user nakomis commented on a diff in the pull request: https://github.com/apache/brooklyn-docs/pull/180#discussion_r115698963 --- Diff: guide/blueprints/catalog/index.md --- @@ -375,153 +375,120 @@ the latest non-snapshot version will be loaded when an entity is instantiated. ### Bundling Catalog Resources -When deploying a blueprint, it is possible to deploy it as an OSGI bundle with additional resources scoped -to this bundle. This is particularly useful when, for example, deploying a Tomcat server with a `.war` file -which is deployed using a classpath path such as `classpath://mywar.war`. +It is possible to add an OSGi bundle to AMP. This is useful when you have a blueprint that needs to reference external scripts/resources or when you have multiple blueprints that you want to keep in sync. Brooklyn will persist any uploaded bundles so that they are available after a restart, or a HA failover. -In this example, we will create a simple `server` catalog item, bundled with a simple text file. +In this example, we will create a simple `my-server` catalog item, bundled with a simple script. The script will be run when launching the server. -First, create the text file with some sample contents: +First, create a folder called bundleFolder, then add a file called myfile.sh to it. +The contents of myfile.sh should be as follows: ~~~ bash -echo Hello, World! > myfile.txt +echo Hello, World! ~~~ -Now create a file called `catalog.bom` with the following contents: +Now create a file in bundleFolder called `catalog.bom` with the following contents: ~~~ yaml brooklyn.catalog: - bundle: script-server + bundle: MyServerBundle version: 1.0.0 - items: - - id: script-server -itemType: entity -item: - type: server - brooklyn.config: -files.runtime: - classpath://myfile.txt: files/myfile.txt + item: +id: my-server +type: org.apache.brooklyn.entity.software.base.VanillaSoftwareProcess +brooklyn.config: + files.runtime: +classpath://myfile.sh: files/myfile.sh + launch.command: | +chmod +x ./files/myfile.sh +./files/myfile.sh + + checkRunning.command: +echo "Running" + ~~~ -The `bundle: script-server` line specifies the OSGI bundle name for this blueprint. Any resources included +The `bundle: MyServerBundle` line specifies the OSGI bundle name for this bundle. Any resources included in this bundle will be accessible on the classpath, but will be scoped to this bundle. This prevents an issue where multiple bundles include the same resource. -To create the bundle, simply zip the `.bom` and `.txt` files as follows: +To create the bundle, simply use the BR command as follows: ~~~ bash -zip script-server.zip catalog.bom myfile.txt +br add-catalog bundleFolder ~~~ -Currently the only supported method for uploading the bundle to the server is via the API, e.g. using -`curl`: - -~~~ bash -curl -X POST -u admin:password -H "Content-Type: application/zip" --data-binary @/tmp/zip/script-server.zip "http://127.0.0.1:8081/v1/catalog; -~~~ - -We can now deploy an instance of our script server as follows: +This will have added our bundle to the catalog. We can now deploy an instance of our server as follows: ~~~ yaml location: localhost services: -- type: script-server +- type: my-server ~~~ -And we can now inspect the contents of the file copied to the server +We can now see the result of running that script. In the UI find the activities for this application. The start activity has a sub task called launch (you will have to click through multiple activities called start/launch. Looking at the stdout of the launch task you should see: -~~~ bash -cat /tmp/brooklyn-martin/apps/nl9djqbq2i/entities/EmptySoftwareProcess_g52gahfxnt/files/myfile.txt -~~~ -~~~ bash +~~~ bash Hello, World! ~~~ -Now modify `myfile.txt` to contain a different message, change the version number in `catalog.bom` to -`1.1.0`, re-build the zip file and re-post it to the server - -If you now deploy a new instance of the script-server using the same YAML as used above, you should be -able to confirm that the new script has been copied to the server: - +Alternatively you can view the script directly if you ran this against localhost: ~~~ bash -cat /tmp/brooklyn-martin/apps/bwu57darkd/entities/EmptySoftwareProcess_umcgshzduk/files/myfile.txt +cat /tmp/brooklyn-username/apps/nl9djqbq2i/entities/EmptySoftwareProcess_g52gahfxnt/files/myfile.sh ~~~
[GitHub] brooklyn-docs pull request #180: Update bundle upload
Github user nakomis commented on a diff in the pull request: https://github.com/apache/brooklyn-docs/pull/180#discussion_r115697711 --- Diff: guide/blueprints/catalog/index.md --- @@ -375,153 +375,120 @@ the latest non-snapshot version will be loaded when an entity is instantiated. ### Bundling Catalog Resources -When deploying a blueprint, it is possible to deploy it as an OSGI bundle with additional resources scoped -to this bundle. This is particularly useful when, for example, deploying a Tomcat server with a `.war` file -which is deployed using a classpath path such as `classpath://mywar.war`. +It is possible to add an OSGi bundle to AMP. This is useful when you have a blueprint that needs to reference external scripts/resources or when you have multiple blueprints that you want to keep in sync. Brooklyn will persist any uploaded bundles so that they are available after a restart, or a HA failover. -In this example, we will create a simple `server` catalog item, bundled with a simple text file. +In this example, we will create a simple `my-server` catalog item, bundled with a simple script. The script will be run when launching the server. -First, create the text file with some sample contents: +First, create a folder called bundleFolder, then add a file called myfile.sh to it. +The contents of myfile.sh should be as follows: ~~~ bash -echo Hello, World! > myfile.txt +echo Hello, World! ~~~ -Now create a file called `catalog.bom` with the following contents: +Now create a file in bundleFolder called `catalog.bom` with the following contents: ~~~ yaml brooklyn.catalog: - bundle: script-server + bundle: MyServerBundle version: 1.0.0 - items: - - id: script-server -itemType: entity -item: - type: server - brooklyn.config: -files.runtime: - classpath://myfile.txt: files/myfile.txt + item: +id: my-server +type: org.apache.brooklyn.entity.software.base.VanillaSoftwareProcess +brooklyn.config: + files.runtime: +classpath://myfile.sh: files/myfile.sh + launch.command: | +chmod +x ./files/myfile.sh +./files/myfile.sh + + checkRunning.command: +echo "Running" --- End diff -- This should be on the previous line --- If your project is set up for it, you can reply to this email and have your reply appear on GitHub as well. If your project does not have this feature enabled and wishes so, or if the feature is enabled but not working, please contact infrastructure at infrastruct...@apache.org or file a JIRA ticket with INFRA. ---
[GitHub] brooklyn-docs pull request #180: Update bundle upload
Github user nakomis commented on a diff in the pull request: https://github.com/apache/brooklyn-docs/pull/180#discussion_r115697661 --- Diff: guide/blueprints/catalog/index.md --- @@ -375,153 +375,120 @@ the latest non-snapshot version will be loaded when an entity is instantiated. ### Bundling Catalog Resources -When deploying a blueprint, it is possible to deploy it as an OSGI bundle with additional resources scoped -to this bundle. This is particularly useful when, for example, deploying a Tomcat server with a `.war` file -which is deployed using a classpath path such as `classpath://mywar.war`. +It is possible to add an OSGi bundle to AMP. This is useful when you have a blueprint that needs to reference external scripts/resources or when you have multiple blueprints that you want to keep in sync. Brooklyn will persist any uploaded bundles so that they are available after a restart, or a HA failover. -In this example, we will create a simple `server` catalog item, bundled with a simple text file. +In this example, we will create a simple `my-server` catalog item, bundled with a simple script. The script will be run when launching the server. -First, create the text file with some sample contents: +First, create a folder called bundleFolder, then add a file called myfile.sh to it. +The contents of myfile.sh should be as follows: ~~~ bash -echo Hello, World! > myfile.txt +echo Hello, World! ~~~ -Now create a file called `catalog.bom` with the following contents: +Now create a file in bundleFolder called `catalog.bom` with the following contents: ~~~ yaml brooklyn.catalog: - bundle: script-server + bundle: MyServerBundle version: 1.0.0 - items: - - id: script-server -itemType: entity -item: - type: server - brooklyn.config: -files.runtime: - classpath://myfile.txt: files/myfile.txt + item: --- End diff -- The [catalog docs](http://brooklyn.apache.org/v/latest/ops/catalog/index.html) use the following format rather than the shortcut format which excludes `items:` ``` items: id: foo item: type: bar ``` --- If your project is set up for it, you can reply to this email and have your reply appear on GitHub as well. If your project does not have this feature enabled and wishes so, or if the feature is enabled but not working, please contact infrastructure at infrastruct...@apache.org or file a JIRA ticket with INFRA. ---
[GitHub] brooklyn-docs pull request #180: Update bundle upload
GitHub user Graeme-Miller opened a pull request: https://github.com/apache/brooklyn-docs/pull/180 Update bundle upload You can merge this pull request into a Git repository by running: $ git pull https://github.com/Graeme-Miller/brooklyn-docs updateBundleUpload Alternatively you can review and apply these changes as the patch at: https://github.com/apache/brooklyn-docs/pull/180.patch To close this pull request, make a commit to your master/trunk branch with (at least) the following in the commit message: This closes #180 commit 1ced5fa083e8b1f79d1f23d56adfed5fd376d786 Author: Martin HarrisDate: 2017-04-07T09:46:43Z Adds documentation for bundling catalog resources in a zip file commit da1163f57bbc645da6a37615676f524b1d6e7f42 Author: graeme.miller Date: 2017-05-09T15:50:36Z Tweaks to bundle uploaad docs commit c71bfe3c0b2ef41f76e66325efff5bca11ab87e8 Author: graeme.miller Date: 2017-05-09T15:58:40Z Minor formatting tweak to bundle guide --- If your project is set up for it, you can reply to this email and have your reply appear on GitHub as well. If your project does not have this feature enabled and wishes so, or if the feature is enabled but not working, please contact infrastructure at infrastruct...@apache.org or file a JIRA ticket with INFRA. ---