Deploy with Command Line
GigaSpaces provides an interactive command line tool as part of the product. This can be started using gs.sh/bat command (referred to as GigaSpaces CLI).
This tool provides many commands that can be used to manage and gather information about the various GigaSpaces runtime components. This section describes the commands supported by GigaSpaces CLI.
In order to interact with a secured grid you need to log in first. See Using the CLI in a Secured Environment.
application
Syntax
gs> deploy-application [-user xxx -password yyy] [-secured true/false] application_directory_or_zipfile
Description
Deploys an application, which deploys one or more processing units in dependency order onto the service grid.
Options
Option | Description | Value Format |
---|---|---|
-timeout | Allows you to specify a timeout value (in milliseconds) when looking up the GSM to deploy to. Defaults to 5000 milliseconds (5 seconds). |
-timeout [timeoutValue] |
-deploy-timeout | Timeout for deploy operation (in milliseconds), otherwise blocks until all successful/failed deployment events arrive (default)" |
-deploy-timeout [timeoutValue] |
-h / -help | Prints help | |
-secured | Deploys a secured processing unit (implicit when using -user/-password) - Using the CLI in a Secured Environment | -secured [true/false] |
-user -password | Deploys a secured processing unit propagated with the supplied user and password - Using the CLI in a Secured Environment | -user xxx -password yyyy |
The following deploys the data-app example application (which includes a feeder and a processor).
gs> deploy-application examples/data/dist.zip
The dist.zip file includes:
application.xml
feeder.jar
processor.jar
application.xml file describes the application dependencies:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
xmlns:os-admin="http://www.openspaces.org/schema/admin"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
http://www.openspaces.org/schema/admin http://www.openspaces.org/schema/16.2.1/admin/openspaces-admin.xsd">
<context:annotation-config />
<os-admin:application name="data-app">
<os-admin:pu processing-unit="processor.jar"
cluster-schema="partitioned"
number-of-instances="2" number-of-backups="1"
The number of backups per partition is zero or one.
max-instances-per-vm="1" max-instances-per-machine="0" />
<os-admin:pu processing-unit="feeder.jar">
<os-admin:depends-on name="processor" min-instances-per-partition="1"/>
</os-admin:pu>
</os-admin:application>
</beans>
Undeploy Application
Syntax
gs> undeploy-application application_name
Description
Undeploys an application from the service grid, while respecting pu dependency order.
Options
Option | Description | Value Format |
---|---|---|
-timeout | Allows you to specify a timeout value (in milliseconds) when looking up the GSM to deploy to. Defaults to **5000 milliseconds (5 seconds). |
-timeout [timeoutValue]
|
-undeploy-timeout | Timeout for deploy operation (in milliseconds), otherwise blocks until all successful/failed deployment events arrive (default)" | -undeploy-timeout [timeoutValue]
|
-h / -help | Prints help | |
-secured | Deploys a secured processing unit (implicit when using -user/-password) - Using the CLI in a Secured Environment | -secured [true/false]
|
-user -password | Deploys a secured processing unit propagated with the supplied user and password - Using the CLI in a Secured Environment | -user xxx -password yyyy
|
The following undeploys the data-app example application (which includes a feeder and a processor).
gs> undeploy-application data-app
Deploy PU
Syntax
gs> deploy [processing unit jar file / directory location / name]
The deploy
command replaces the pudeploy
command and is identical to it in terms of
supported arguments and options.
pudeploy
is still supported but is considered a deprecated command and will be removed in future
versions.
Description
A Processing Unit can be easily deployed onto the Service Grid. In order to deploy a Processing Unit, the
Processing Unit must follow the processing
unit directory structure.
Before deploying the processing unit you will need to jar it and then specify that jar file as the parameter to the
deploy
command. The deployment process will upload the jar file to all the GSMs it finds and unpack it
under the deploy
directory. It will then issue the deploy command.
You may use the GigaSpaces Universal Deployer to deploy complex multi processing unit applications.
Third Party jars Location and Property Files
Third party jars should be placed within one of the following locations:
-
Within the deployed jar under the lib folder - Good if you have relatively small amount of jars and few PU instances within the same GSC. These will be copied automatically by GigaSpaces during the deploy process to the
$GS_HOME\work
folder on all the machines running GSCs hosting the PU instances. You may control this folder location using thecom.gs.work
system property. -
Within the
$GS_HOME\lib\optional\pu-common
folder for each machine running GSCs - Each PU instance will have its own instance of the loaded class. Speed up the deployed time. You may control this folder location using thecom.gs.pu-common
system property. -
Within the
$GS_HOME\lib\platform\ext
folder for each machine running GSCs - All PUs class loaders will share the same loaded class. Speed up the deployed time. Optimize the JVM perm gem space usage since all 3rd party jars are loaded only once. You may control this folder location using thecom.gigaspaces.lib.platform.ext
system property.
Property files and other resources should be jared and placed within any of the above locations.
Deploy Command Options
Option | Description | Value Format |
---|---|---|
Processing Unit Location/Name – mandatory | The location of the processing unit directory or jar file on your file system (see this
page). If you are using a few options in the deploy command, pass this option as the
last parameter.For example: gs> deploy hello-world.jar ( hello-world.jar
is the processing jar file). |
|
-cluster |
Allows you to control the clustering characteristics of the processing unit. The cluster option is a simplified option that overrides the cluster part of the processing unit's built in SLA (if such exists). The following options are available (used automatically by any embedded space included in the Processing Unit):
(number of backups is required
only if the The number of backups per partition is zero or one. |
-cluster schema=[schema name]
total_members=
numberOfInstances[,numberOfBackups]
|
-properties | Allows you to control deployment properties. | -properties [bean name] location
|
-properties embed | Direct property injection | -properties embed://user=admin |
-sla | Allows you to specify a link (default to file-system) to a Spring XML configuration, holding the SLA definition. | -sla [slaLocation]
|
-zones | Allows you to specify a list of deployment zones that are to restrict that the deployment to specific GSCs. | -zones [zoneName1 zoneName2 ... ]
|
-timeout | Allows you to specify a timeout value (in milliseconds) when looking up the GSM to deploy
to.Defaults to 5000 milliseconds (5 seconds). |
-timeout [timeoutValue]
|
-override-name | Allows you to specify an override name for the deployed Processing Unit (a different name than the directory name under deploy ).Mainly used when using a Processing Unit as a template. |
-override-name [processing unit name]
|
-max-instances-per-vm | Allows you to set the SLA number of instances per VM | |
-max-instances-per-machine | Allows you to set the SLA number of instances per machine | |
-max-instances-per-zone | Allows you to set the SLA number of instances per zone in the format of zoneX/number,zoneY/number |
|
-requires-isolation | Allows to set the SLA requires isolation, if set to true only a single processing unit instance will deployed on a given GSC | -requires-isolation [true/false]
|
h / help | Prints help | |
-secured | Deploys a secured processing unit (implicit when using -user/-password) - Using the CLI in a Secured Environment | -secured [true/false]
|
-user -password | Deploys a secured processing unit propagated with the supplied user and password - Using the CLI in a Secured Environment | -user xxx -password yyyy
|
The following deploys a processing unit jar file named data-processor.jar
using the sync_replicated
cluster schema with 2 instances (total_members
).
gs> deploy -cluster schema=sync_replicated total_members=2 data-processor.jar
The following deploys a processing unit archive called data-processor.jar
using deployment
properties file called pu.properties
.
gs> deploy -properties file://config/pu.properties data-processor.jar
The following deploys a processing unit archive called data-processor.jar
direct injecting the
properties.
gs> deploy -properties embed://DB_username=postgres;DB_password=pass mirror
Using the following pu configuration:
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="org.postgresql.Driver"/>
<property name="url" value="jdbc:postgresql:presence"/>
<property name="username" value="${DB_username}"/>
<property name="password" value="${DB_password}"/>
</bean>
The following deploys a processing unit archive called data-processor.jar
using an SLA element
read from an external sla.xml
file.
gs> deploy -sla file://config/sla.xml data-processor.jar
The following example deploys a partitioned
space cluster with the name mySpace
for both the processing unit and the Space it contains.
deploy -cluster schema=partitioned total_members=2,1 -override-name mySpace -properties embed://dataGridName=mySpace myPUFolder
Multiple deployment properties can be injected by having ; between each property - see below example:
>gs deploy -cluster schema=partitioned total_members=10,1
-properties "embed://dataGridName=myIMDG;space-config.proxy.router.active-server-lookup-timeout=5000;space-config.engine.max_threads=256;mypropA=aaa;mypropB=bbb" -override-name myPU /tmp/myPu.jar
Undeploy App
Syntax
gs> undeploy-application application_name
Description
Undeploys an application from the service grid, while respecting pu dependency order.
Options
Option | Description | Value Format |
---|---|---|
-timeout | Allows you to specify a timeout value (in milliseconds) when looking up the GSM to deploy
to.Defaults to 5000 milliseconds (5 seconds). |
-timeout [timeoutValue]
|
-undeploy-timeout | Timeout for deploy operation (in milliseconds), otherwise blocks until all successful/failed deployment events arrive (default)" | -undeploy-timeout [timeoutValue]
|
-h / -help | Prints help | |
-secured | Deploys a secured processing unit (implicit when using -user/-password) - Using the CLI in a Secured Environment | -secured [true/false]
|
-user -password | Deploys a secured processing unit propagated with the supplied user and password - Using the CLI in a Secured Environment | -user xxx -password yyyy
|
The following undeploys the data-app example application (which includes a feeder and a processor).
gs> undeploy-application data-app
Deploy Memcached
Syntax
gs> deploy-memcached [-sla ...] [-cluster ...] [-properties ...] [-user xxx -password yyy] [-secured true/false] space_url
Description
Options
Option | Description | Value Format |
---|---|---|
space_url | The url of the space, can be embedded, eg: /./myMemcachedSpace , or remote eg:
jini://*/*/myMemcachedSpace |
|
-cluster |
Allows you to control the clustering characteristics of the processing unit. The cluster option is a simplified option that overrides the cluster part of the processing unit's built in SLA (if such exists). The following options are available (used automatically by any embedded space included in the Processing Unit):
(number of backups is required
only if the The number of backups per partition is zero or one. |
-cluster schema=[schema name]
total_members=numberOfInstances[,numberOfBackups] |
-properties | Allows you to control deployment properties. | -properties [bean name] location
|
-sla | Allows you to specify a link (defaults to file-system) to a Spring XML configuration, holding the SLA definition. | -sla [slaLocation]
|
-zones | Allows you to specify a list of deployment zones that are to restrict that the deployment to specific GSCs. | -zones [zoneName1, zoneName2 ... ]
|
-timeout | Allows you to specify a timeout value (in milliseconds) when looking up the GSM to deploy to. Defaults to 5000 milliseconds (5 seconds). |
-timeout [timeoutValue]
|
-max-instances-per-vm | Allows you to set the SLA number of instances per VM | |
-max-instances-per-machine | Allows you to set the SLA number of instances per machine | |
-max-instances-per-zone | Allows you to set the SLA number of instances per zone in the format of zoneX/number,zoneY/number |
|
-requires-isolation | Allows to set the SLA requires isolation, if set to true only a single processing unit instance will deployed on a given GSC | -requires-isolation [true/false]
|
h / help | Prints help | |
-secured | Deploys a secured processing unit (implicit when using -user/-password) - Using the CLI in a Secured Environment | -secured [true/false]
|
-user -password | Deploys a secured processing unit propagated with the supplied user and password - Using the CLI in a Secured Environment | -user xxx -password yyyy
|
You can use the GigaSpaces Universal Deployer to deploy complex multi processing unit applications.
The following deploys a memcached-enabled space named mySpace
using the partitioned
cluster schema with 2 primaries and 1 primary per backup.
gs> deploy-memcached -cluster schema=partitioned total_members=2,1 mySpace
The following deploys a memcached-enabled space called mySpace
using an SLA element read from
an external sla.xml
file.
gs> deploy-space -sla file://config/sla.xml mySpace
Deploy Space
Syntax
gs> deploy-space [space name]
Description
A Space only Processing Unit can be easily deployed onto the Service Grid.
Options
Option | Description | Value Format |
---|---|---|
Space Name – mandatory | The name of the space to be deployed. | |
-cluster |
Allows you to control the clustering characteristics of the space. The following options are available (used automatically by any embedded space included in the Processing Unit):
(number of backups is required only if the
|
-cluster schema=[schema name]
total_members=numberOfInstances[,numberOfBackups]
|
-properties | Allows you to control deployment properties. | -properties [bean name] location
|
-sla | Allows you to specify a link (default to file-system) to a Spring XML configuration, holding the SLA definition. | -sla [slaLocation]
|
-zones | Allows you to specify a list of deployment zones that are to restrict that the deployment to specific GSCs. | -zones [zoneName1, zoneName2 ... ]
|
-max-instances-per-vm | Allows you to set the SLA number of instances per VM | |
-max-instances-per-machine | Allows you to set the SLA number of instances per machine | |
-max-instances-per-zone | Allows you to set the SLA number of instances per zone in the format of zoneX/number,zoneY/number |
|
-requires-isolation | Allows to set the SLA requires isolation, if set to true only a single processing unit instance will deployed on a given GSC | -requires-isolation [true/false]
|
h / help | Prints help | |
-secured | Deploys a secured processing unit (implicit when using -user/-password) - Using the CLI in a Secured Environment | -secured [true/false]
|
-user -password | Deploys a secured processing unit propagated with the supplied user and password - Using the CLI in a Secured Environment | -user xxx -password yyyy
|
You may use the GigaSpaces Universal Deployer to deploy complex multi processing unit applications.
The following deploys a space named mySpace
using the sync_replicated
cluster
schema with 2 instances (total_members
).
gs> deploy-space -cluster schema=sync_replicated total_members=2 mySpace
The following deploys a space named mySpace
using deployment properties file called pu.properties
.
gs> deploy-space -properties file://config/pu.properties mySpace
The following deploys a space called mySpace
using an SLA element read from an external sla.xml
file.
gs> deploy-space -sla file://config/sla.xml mySpace
Task
Syntax
usage: task ant-file [target=target-name]
Description
The task
command submits a task in the form of an Ant configuration file..
Options
Option | Description |
---|---|
ant-file | The name of the Ant configuration file, an XML file representing the task. The file must reside in the current directory. |
list-of-machines | A comma-separated list of hostnames or of IP addresses, or the name of a file containing such a list, saying where to submit the Ant configuration file. By default, if machines are available, you receive a list to choose from. If no machines are currently available, are prompted to start an HTTP server. |
Deployment States
This is a list of possible deployment states and their meaning.
State | Description |
---|---|
BROKEN | Indicates the deployment is deployed and is broken, where all required services are not available. |
COMPROMISED | Indicates the deployment is deployed and is compromised, where some specified services are not available. |
DEPLOYED | Indicates the deployment is deployed. |
INTACT | Indicates the deployment is deployed and is intact, where all specified services are available. |
SCHEDULED | Indicates the deployment is scheduled for deployment. |
UNDEPLOYED | Indicates the deployment is not deployed. |
Hot Deploy
The Hot Deploy tool allows business logic running as a PU to be refreshed (rolling PU upgrade) without any system downtime and data loss. The tool uses the hot deploy approach , placing new PU code on the GSM PU deploy folder and later restart each PU instance.