Creating a Deployment


Get the latest docs

You are looking at documentation for an older release. Not what you want? Go to the current release documentation.

In order for Cloudify to deploy your application, it reads the uploaded blueprint YAML (the logical representation) and manifests a model called a deployment. A deployment is a “technical” drilled-down representation of your application. For example, if a blueprint describes a single server node that is defined to deploy multiple instances, the deployment will comprise the instances themselves, together with their unique identifiers.

Creating a deployment does not actually create any resources, it simply generates a “physical” representation of your application from a “logical” (blueprint) representation and stores it in the database. Technically, it is a virtual environment on Cloudify Manager.

Creating a Deployment via the CLI

To create a deployment using the Cloudify CLI execute:

  
cfy deployments create -b <BLUEPRINT_NAME> <DEPLOYMENT_NAME> --inputs </path/to/your/inputs.yaml​>
  

Creating a Deployment via the Cloudify Web UI

  1. On the Blueprints widget, select the required blueprint and click Deploy.
    Create deployment button

  2. Enter the name of the deployment and, optionally, specify the raw input parameters.

  3. Click Deploy.
    Create deployment box

After creating the deployment, you can open the Deployment widget to track the initialization stage.
Deployment initialize

For information about deployment states, see the Deployments Page documentation.

After initialization is complete, you can start using the deployment and executing workflows.

Example: Creating a Deployment

This example shows how a deployment can be created for a blueprint, using the command line. For more information about creating deployments using the command line, click here.

First create an inputs file (in a similar way to the Manager blueprint’s inputs dialog):

 
  inputs:
    image:
      description: >
        Image to be used when launching agent VM's
    flavor:
      description: >
        Flavor of the agent VM's
    agent_user:
      description: >
        User for connecting to agent VM's
    

Make a copy of the inputs template already provided and edit it:

 
  cd cloudify-nodecellar-example/inputs/openstack.yaml.template
  cp openstack.yaml.template inputs.yaml
    
The inputs.yaml file should look somewhat like this:
 
  image: 8c096c29-a666-4b82-99c4-c77dc70cfb40
  flavor: 102
  agent_user: ubuntu
    

All inputs have default values so no input file is needed.

To specify different values for one or more inputs, create an inputs.yaml file with the required inputs, for example:

 
  echo -e "domain: 'my_domain.org'\nlocation: '168642'" > inputs.yaml
    

The inputs.yaml file will look like this:

 
  domain: 'my_domain.org'
  location: '168642'
    

 
  inputs:
    image:
      description: >
        Image to be used when launching agent VM's
    flavor:
      description: >
        Flavor of the agent VM's
    agent_user:
      description: >
        User for connecting to agent VM's
    

Make a copy of the inputs template already provided and edit it:

 
  cd cloudify-nodecellar-example/inputs
  cp aws-ec2.yaml.template inputs.yaml
    
The inputs.yaml file should look somewhat like this:
 
    image: ''
    size: ''
    agent_user: ''
    

The image is again the AMI image ID. The size is the instance_type, and the agent user is the default user agent on the image type.

 
  inputs:
    vcloud_username:
        type: string
    vcloud_password:
        type: string
    vcloud_url:
        type: string
    vcloud_service:
        type: string
    vcloud_vcd:
        type: string
    catalog:
      type: string
    template:
      type: string
    agent_user:
      type: string
      default: ubuntu
    management_network_name:
      type: string
    floating_ip_gateway:
      type: string
    nodecellar_public_ip:
      type: string
    

Make a copy of the inputs template already provided and edit it:

 
  cd cloudify-nodecellar-example/inputs
  cp vcloud.yaml.template inputs.yaml
    
The inputs.yaml file should look somewhat like this:
 
  {
      "vcloud_username": "your_vcloud_username",
      "vcloud_password": "your_vcloud_password",
      "vcloud_url": "https://vchs.vmware.com&#34;,
      "vcloud_service": "service_name",
      "vcloud_vdc": "virtual_datacenter_name",
      "manager_server_name": "your_manager",
      "manager_server_catalog": "templates_catalog",
      "manager_server_template": "template",
      "edge_gateway": "gateway_name",
      "floating_ip_public_ip": "",
      "management_network_name": "management",
      "manager_private_key_path": "~/.ssh/vcloud_template.pem",
      "agent_private_key_path": "~/.ssh/vcloud_template.pem"
  }