Skip to content

Latest commit

 

History

History
90 lines (66 loc) · 4.43 KB

README.md

File metadata and controls

90 lines (66 loc) · 4.43 KB

Deploying Cloud Foundry on OpenStack with BOSH

Prerequisites

You'll need to following to proceed:

  • An OpenStack project
  • A user able to create/delete resource in this project
  • Flavors with the following names and configuration:
Name CPUs RAM (MiB) Root Disk (GiB) Ephemeral Disk (GiB)
minimal 1 3840 3 10
small 2 7680 3 14
small-50GB-ephemeral-disk 2 7680 3 50
small-highmem 4 31232 3 10
small-highmem-100GB-ephemeral-disk 4 31232 3 100

Validate OpenStack is ready to run BOSH and deploy Cloud Foundry

Before deploying Cloud Foundry, make sure to successfully run the CF-OpenStack-Validator against your project.

  • Make sure you have the required flavors on OpenStack by enabling the flavors extension with the flavors.yml file in this directory. Flavor names need to match those specified in the cloud config.
  • If you plan using the Swift ops file to enable Swift as blobstore for the Cloud Controller, you should also run the Swift extension.

Prepare OpenStack resources for BOSH and Cloud Foundry via Terraform

BOSH

To setup an OpenStack project to install BOSH please use the following Terraform module. Adapt terraform.tfvars.template to your needs.

Cloud Foundry

To setup the project to install Cloud Foundry please use the following Terraform module. Adapt terraform.tfvars.template to your needs. Variable bosh_router_id is output of the previous BOSH terraform module.

Install BOSH

To install the BOSH director please follow the instructions on bosh.io.

Make sure the BOSH director is accessible through the BOSH cli, by following the instructions on bosh.io. Use this mechanism in all BOSH cli examples in this documentation.

Cloud Config

After the BOSH director has been installed, you can prepare and upload a cloud config based on the cloud-config.yml file.

Take the variables and outputs from the Terraform run of cf-deployment-tf to finalize the cloud config.

Use the following command to upload the cloud config.

bosh update-cloud-config \
     -v availability_zone1="<az-1>" \
     -v availability_zone2="<az-2>" \
     -v availability_zone3="<az-3>" \
     -v network_id1="<cf-network-id-1>" \
     -v network_id2="<cf-network-id-2>" \
     -v network_id3="<cf-network-id-3>" \
     cf-deployment/iaas-support/openstack/cloud-config.yml

Deploy Cloud Foundry

To deploy Cloud Foundry run the following command filling in the necessary variables. system_domain is the user facing domain name of your Cloud Foundry installation.

bosh -d cf deploy cf-deployment/cf-deployment.yml \
     -o cf-deployment/operations/use-compiled-releases.yml \
     -o cf-deployment/operations/openstack.yml \
     --vars-store <vars-store> \
     -v system_domain="<system-domain>"

With Swift as Blobstore

  • Create four containers in Swift, which are used to store the artifacts for buildpacks, app-packages, droplets, and additional resources, respectively. The container names need to be passed in as variables in the below command snippet
  • Set a Temporary URL Key for your Swift account

Add the following lines to the deploy cmd:

  -o cf-deployment/operations/use-swift-blobstore.yml \
  -v auth_url="<auth-url>" \
  -v openstack_project="<project-name>" \
  -v openstack_domain="<domain>" \
  -v openstack_username="<user>" \
  -v openstack_password="<password>" \
  -v openstack_temp_url_key="<temp-url-key>" \
  -v app_package_directory_key="<app-package-directory-key>" \
  -v buildpack_directory_key="<buildpack-directory-key>" \
  -v droplet_directory_key="<droplet-directory-key>" \
  -v resource_directory_key="<resource-directory-key>" \