From d1041bf8c28304beb8e4bf64f0254e7404b14e41 Mon Sep 17 00:00:00 2001 From: Ludo Stellingwerff Date: Fri, 9 Nov 2018 12:57:39 +0100 Subject: [PATCH] More documentation. Added reload feature to install script. --- README.md | 45 +++++++++++++++++++++++++++++++++++++++++++-- deploy.sh | 1 + installAsset.js | 20 +++++++++++++++----- 3 files changed, 59 insertions(+), 7 deletions(-) diff --git a/README.md b/README.md index a4e7a31..cff2100 100644 --- a/README.md +++ b/README.md @@ -126,6 +126,11 @@ You can just create you component(s) through any development process you'll like Before creating the zipfile, you need to build your docker image with the correct labels on them. +*** +*note: You can install this docker image directly as an asset into the platform, bypassing the whole quarantine registry. This is a good way to test the labels. Skip directly to [Install asset locally](#installLocally) for this. +*** + + #### Create asset zipfile To facilitate the creation of the zipfile for distributing the assets, the platform provides a tool, called `label2manifest.js`, which you can find in the root folder of the source distribution and/or in the *tools* folder of the binary distribution. @@ -175,7 +180,7 @@ The script will create a zipfile in the folder where you run the script, called #### Deploy asset to local quarantine registry In the final setup of the platform, all assets will be installed from the vf-OS Store, by downloading, checking, intermediate storing in the quarantine registry, and installation of the asset into the local docker environment. This is a complex, multi-step process that is annoying and slow during development testing. -To ease this for developers, a script is provided that bypasses many of these steps and can deploy the asset from the zipfile, directly into the quarantine repository. This script is called *manifest2label.js* to mimic it's mirror counterpart. +To ease this for developers, a script is provided that bypasses many of these steps and can deploy the asset from the zipfile, directly into the quarantine repository. This script is called *manifest2label.js* to mimic it's mirror counterpart. This script is provided in the tools folder of the binary distribution, and requires running *npm install* for it's dependencies. ```shell user@host:~/platform$ manifest2label.js $PWD/asset-c.zip true true @@ -203,6 +208,42 @@ manifest2label [] [] [Install asset locally + +To get the asset from the local quarantine registry into the actual running platform, requires the generation of the docker-compose file for this asset. This can be done through the REST API of the platform, but to simplify this a script *installAsset.js* is provided that does this. This script is provided in the tools folder of the binary distribution, and requires running *npm install* for it's dependencies. + +*** +*note: You can also install an Asset directly from your local docker daemon, bypassing the whole quarantine registry. In the example below, you don't include the 'localhost:5000/' part for such images. (Just use the local imageid) +*** + +Before running the script the platform should be running, to provide access to the registry. Run the script like: +```shell +user@host:~/platform$ installAsset.js localhost:5000/asset-a true +Got metadata from docker image: localhost:5000/asset-c +Platform reloaded. +user@host:~/platform$ ls .compose +0_platform_compose.yml 1_networks_compose.yml 3_asset-c_compose.yml docker-compose +user@host:~/platform$ docker container list +CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES +ccb18f1062d8 localhost:5000/vfos/deploy "/usr/src/app/entryp…" 23 seconds ago Up 19 seconds 9000/tcp vfos_deployment_1 +7cda48ac56a4 localhost:5000/vfos/system-dashboard "npm start" 23 seconds ago Up 18 seconds 9000/tcp vfos_dashboard_1 +067dd4ec6b0a localhost:5000/vfos/test-server "npm start" 23 seconds ago Up 15 seconds 9000/tcp vfos_testserver_1 +0afa60d16778 localhost:5000/vfos/exec-manager "npm start" 23 seconds ago Up 17 seconds 9000/tcp vfos_execution-manager_1 +f16f1a26a87c localhost:5000/asset-c "npm start" 23 seconds ago Up 15 seconds 9001/tcp vfos_asset-c_1 +789b38d393a8 localhost:5000/vfos/aim "/opt/jboss/tools/do…" 23 seconds ago Up 20 seconds 8080/tcp vfos_aim_1 +91187164867b localhost:5000/vfos/portal "npm start" 23 seconds ago Up 21 seconds 9000/tcp vfos_portal_1 +c06837648ca6 traefik:latest "/traefik --api --do…" 23 seconds ago Up 12 seconds 0.0.0.0:80->80/tcp, 0.0.0.0:8080->8080/tcp vfos_reverse-proxy_1 +f53130f4f819 registry:2 "/entrypoint.sh /etc…" About an hour ago Up About an hour 0.0.0.0:5000->5000/tcp vfos_registry_1 +2bfa81621399 docker/compose:1.22.0 "/bin/sh -c 'cat /de…" About an hour ago Up About an hour vf_os_platform_exec_control +``` +As you can see in the example, the script creates a docker-compose file, called *3_assetId_compose.yml* which is included by the reload of the platform. +There are four parameters to this script: +``` shell +installAsset.js [] [] [] +``` +* imageUrl: The imageId or url to the registry imageId. +* reload: Should the platform reload its configfiles? (Basically running *docker-compose up*) Simple *true* or *false* parameter, defaults to *false*. +* targetFolder: Path to the folder where the compose file needs to be generated. Defaults to $PWD/.compose. +* volumesFolder: Absolute path in the host to the folder where the host side of volume mounts needs to be placed. Defaults to $PWD/.persist. diff --git a/deploy.sh b/deploy.sh index 8ab3ec8..6c07ede 100755 --- a/deploy.sh +++ b/deploy.sh @@ -15,6 +15,7 @@ cp stop.sh vfosPlatform/ cp start.sh vfosPlatform/ cp label2manifest.js vfosPlatform/tools/ +cp manifest2label.js vfosPlatform/tools/ cp installAsset.js vfosPlatform/tools/ cp package.json vfosPlatform/tools/ diff --git a/installAsset.js b/installAsset.js index a90b0bc..3889a28 100755 --- a/installAsset.js +++ b/installAsset.js @@ -5,12 +5,13 @@ const exec = require('child_process').exec const fs = require('fs') let dockerImage = process.argv[2] -let folder = process.argv[3] -let volumeFolder = process.argv[4] ? process.argv[4] : process.cwd() + '/.persist/' +let reload = process.argv[3] ? process.argv[3] : false +let folder = process.argv[4] ? process.argv[4] : process.cwd() + '/.compose/' +let volumeFolder = process.argv[5] ? process.argv[5] : process.cwd() + '/.persist/' if (!volumeFolder.endsWith('/')) volumeFolder += '/' -if (!dockerImage && process.argv.length < 4) { - console.log('Call this script as: ' + process.argv[1] + ' ') +if (!dockerImage && process.argv.length < 3) { + console.log('Call this script as: ' + process.argv[1] + ' [] [] []') process.exit(1) } let imageFile = dockerImage.replace(/.*\//gi, '') @@ -119,8 +120,17 @@ new Promise((resolve, reject) => { // Generate docker-compose file for this asset into folder fs.writeFileSync(folder + '/3_' + imageFile + '_compose.yml', 'version: "3"\nservices:\n ' + services) + // If parameter: call docker-compose image to reload asset + if (reload) { + exec('docker exec vf_os_platform_exec_control docker-compose up -d', (error, stdout, stderr) => { + if (error) { + console.log('Failed to reload the platform.', stderr) + } else { + console.log('Platform reloaded.', stdout) + } + }) + } } - // If parameter: call docker-compose image to reload asset }) }).catch((e) => { console.error('failed to pull image', e)