These instructions allow you to:
- Provision an AWS account with preliminary resources and secrets,
- Deploy BOSH to AWS via
bosh-init
, and - Deploy CF and Diego via the deployed BOSH.
- Setting Up the Local Environment
- Creating the AWS Environment
- Deploying Cloud Foundry
- Setup a SQL database for Diego
- Deploying Diego
As part of the deployment process, you must install the following dependencies:
You must also clone the following git repositories from GitHub:
The deployment process requires that you create a directory for each deployment which will hold the necessary configuration to deploy BOSH, cf-release, and diego-release.
Before proceeding with setup, select a domain name you intend to use for your CF deployment. This domain name will be the base domain for all apps deployed to your Cloud Foundry instance, as well as the base domain for the Cloud Foundry system components. You will later create a Route 53 Hosted Zone for this domain to set up DNS entries for the deployment, so you should make sure you have access at your domain registrar to integrate these DNS settings into your domain.
Change into the directory you just created for the deployment and run the following to produce the deployment-env
file:
cat <<"EOF" > deployment-env
export DEPLOYMENT_DIR="$(cd $(dirname "$BASH_SOURCE[0]") && pwd)"
export CF_RELEASE_DIR="$HOME/workspace/cf-release"
export DIEGO_RELEASE_DIR="$HOME/workspace/diego-release"
export CF_DOMAIN=REPLACE_WITH_DEPLOYMENT_DOMAIN
echo "DEPLOYMENT_DIR set to '$DEPLOYMENT_DIR'"
echo "CF_RELEASE_DIR set to '$CF_RELEASE_DIR'"
echo "DIEGO_RELEASE_DIR set to '$DIEGO_RELEASE_DIR'"
echo "CF_DOMAIN set to '$CF_DOMAIN'"
EOF
Edit the deployment-env
file to replace REPLACE_WITH_DEPLOYMENT_DOMAIN
with the domain selected above. If you have not checked out cf-release and diego-release as subdirectories of ~/workspace
, also replace those default locations.
Run source deployment-env
to export these variables to your environment. They will be used extensively as $DEPLOYMENT_DIR
, $CF_RELEASE_DIR
, $DIEGO_RELEASE_DIR
, and $CF_DOMAIN
in commands and references below.
Before deploying the BOSH director, you must create the following resources in your AWS account through the AWS console:
- From the AWS console homepage, click on
Identity & Access Management
. - Click on the
Policies
link. - Click on the
Create Policy
button. - Select
Create Your Own Policy
. - Enter
bosh-aws-policy
as thePolicy Name
. - Enter the following as the
Policy Document
and click on theCreate Policy
button:
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"iam:DeleteServerCertificate",
"iam:UploadServerCertificate",
"iam:ListServerCertificates",
"iam:GetServerCertificate",
"cloudformation:*",
"ec2:*",
"s3:*",
"vpc:*",
"elasticloadbalancing:*",
"route53:*"
],
"Resource": "*"
}
]
}
- From the AWS console homepage, click on
Identity & Access Management
. - Click on
Users
link. - Click on the
Create New Users
button. - Fill in only one user name.
- Make sure that the
Generate an access key for each user
checkbox is checked and clickCreate
. - Click
Download Credentials
at the bottom of the screen. - Copy the downloaded
credentials.csv
file to$DEPLOYMENT_DIR
. - Click on the
Close
link to return to the IAM Users page. - Click on the user that you created.
- Click on the
Permissions
tab. - Click on the
Attach Policy
button. - Filter for
bosh-aws-policy
in the filter box - Select
bosh-aws-policy
and click on theAttach Policy
button
- From the AWS console homepage, click on
EC2
. - Click on the
Key Pairs
link in the sidebar, in theNetwork & Security
group. - Click the
Create Key Pair
button at the top of the page. - When prompted for the key name, enter a name that can be easily referred to later, for example:
bosh_keypair
. - Make the directory
$DEPLOYMENT_DIR/keypair
and move the downloadedbosh_keypair.pem
key to$DEPLOYMENT_DIR/keypair/id_rsa_bosh
. - Change the permissions on the new key file to
600
(rw-------
):chmod 600 $DEPLOYMENT_DIR/keypair/id_rsa_bosh
.
- From the AWS console homepage, click on
Route 53
. - Select
Hosted zones
from the left sidebar. - Click the
Create Hosted Zone
button. - Fill in the
$CF_DOMAIN
domain name you chose above for your Cloud Foundry deployment.
If you host this domain at another domain registrar, set the nameservers at that registrar to the DNS servers listed in the NS record in the AWS Hosted Zone.
After creating the necessary resources in AWS, you must populate
$DEPLOYMENT_DIR
in the following format. Each of the files is explained further
below.
DEPLOYMENT_DIR
|-(bootstrap_environment)
|-keypair
| |-(id_rsa_bosh)
|-certs
| |-(elb-cfrouter.key)
| |-(elb-cfrouter.pem)
|-stubs
| |-(domain.yml)
| |-(aws-instance-types.yml) [OPTIONAL]
| |-infrastructure
| | |-(availablity_zones.yml)
| |-bosh-init
| |-(keypair.yml)
| |-(releases.yml)
| |-(users.yml)
| |-(stemcell.yml)
To create the directories, run the following commands:
cd $DEPLOYMENT_DIR
mkdir -p keypair
mkdir -p certs
mkdir -p stubs/infrastructure
mkdir -p stubs/bosh-init
This script exports your AWS default region and the access and secret keys of your IAM user as environment variables.
Run the following to create a new bootstrap_environment
file in $DEPLOYMENT_DIR
:
cat <<EOF > $DEPLOYMENT_DIR/bootstrap_environment
export AWS_DEFAULT_REGION=us-east-1
export AWS_ACCESS_KEY_ID=REPLACE_WITH_AKI
export AWS_SECRET_ACCESS_KEY='REPLACE_WITH_SECRET_ACCESS_KEY'
EOF
Next, replace the values prefixed with REPLACE_WITH_
as follows from the values in the credentials.csv
file downloaded during creation of the IAM user:
- For the
AWS_ACCESS_KEY_ID
variable, replaceREPLACE_WITH_AKI
with the access key id. - For the
AWS_SECRET_ACCESS_KEY
variable, replaceREPLACE_WITH_SECRET_ACCESS_KEY
with the secret access key.
Replace the value of AWS_DEFAULT_REGION
if you are deploying to a different AWS region.
This file is the private key pair generated as the AWS keypair for the BOSH director.
#### certs/elb-cfrouter.key
and certs/elb-cfrouter.pem
An SSL certificate for the domain where Cloud Foundry will be accessible is required. If you do not already provide a certificate, you can generate a self-signed certificate following the commands below.
cd $DEPLOYMENT_DIR/certs
openssl genrsa -out elb-cfrouter.key 2048
When prompted for the 'Common Name' in the next command, enter *.$CF_DOMAIN
, where $CF_DOMAIN
is the value you entered in the hosted zone setup. The other fields can be left blank.
openssl req -new -key elb-cfrouter.key -out elb-cfrouter.csr
openssl x509 -req -in elb-cfrouter.csr -signkey elb-cfrouter.key -out elb-cfrouter.pem
Run the following command to produce the stubs/domain.yml
stub file with the domain you selected above:
cat <<EOF > $DEPLOYMENT_DIR/stubs/domain.yml
---
domain: $CF_DOMAIN
EOF
To override the instance sizes for the Diego VMS, you may optionally create a stubs/aws-instance-types.yml file. For example, to make all Diego VMs use the t2.micro instance type, run the following command:
cat <<EOF > $DEPLOYMENT_DIR/stubs/aws-instance-types.yml
instance_types:
access: t2.micro
brain: t2.micro
cc_bridge: t2.micro
cell: t2.micro
cell_windows: t2.micro
database: t2.micro
route_emitter: t2.micro
EOF
If this file does not exist, the default sizes will be used. If the file does exist, but not all types are provided, the default sizes will be used for anything not explicitly overridden.
Note: this file needs to be created before deploy_aws_environment
script described below is run.
Run the following to produce the stubs/infrastructure/availability_zones.yml
file, which defines the three availability zones to host your Cloud Foundry deployment.
cat <<EOF > $DEPLOYMENT_DIR/stubs/infrastructure/availability_zones.yml
---
meta:
availability_zones:
- us-east-1a
- us-east-1c
- us-east-1d
EOF
If you wish to use different availability zones, or to assign them a different order, edit this file to replace them. Note that these availability zones must be located in the AWS region specified in the bootstrap_environment
file.
Note: These zones could become restricted by AWS. If at some point during the deploy_aws_cli
script and you see an error
similar to the following message:
Value (us-east-1b) for parameter availabilityZone is invalid Subnets can currently only be created in the following availability zones: us-east-1d, us-east-1c, us-east-1a, us-east-1e
then update this file with acceptable availability zone values.
Run the following to create the stubs/bosh-init/keypair.yml
file:
cat <<EOF > $DEPLOYMENT_DIR/stubs/bosh-init/keypair.yml
---
BoshKeypairName: REPLACE_WITH_BOSH_KEYPAIR_NAME
EOF
Next, edit this file to replace REPLACE_WITH_BOSH_KEYPAIR_NAME
with the name of the keypair created on AWS keypair for the
BOSH director. For example:
---
BoshKeypairName: bosh_keypair
Run the following to create the stubs/bosh-init/releases.yml
file, which specifies the bosh
and bosh-aws-cpi
releases for bosh-init
to use to deploy the BOSH VM.
cat <<EOF > $DEPLOYMENT_DIR/stubs/bosh-init/releases.yml
---
releases:
- name: bosh
url: REPLACE_WITH_URL_TO_LATEST_BOSH_BOSH_RELEASE
sha1: REPLACE_WITH_SHA1_OF_LATEST_BOSH_BOSH_RELEASE
- name: bosh-aws-cpi
url: REPLACE_WITH_URL_TO_LATEST_BOSH_AWS_CPI_BOSH_RELEASE
sha1: REPLACE_WITH_SHA1_OF_LATEST_BOSH_AWS_CPI_BOSH_RELEASE
EOF
Next, replace the values in this file with the URLs and SHA1 checksums of the bosh
and bosh-aws-cpi
releases.
Releases for bosh
can be found here, and
releases for bosh-aws-cpi
can be found here.
For example:
releases:
- name: bosh
url: https://bosh.io/d/github.com/cloudfoundry/bosh?v=255
sha1: 923dfb8c26fab7041c0a3e591f0e92f3c4bca29e
- name: bosh-aws-cpi
url: https://bosh.io/d/github.com/cloudfoundry-incubator/bosh-aws-cpi-release?v=44
sha1: a1fe03071e8b9bf1fa97a4022151081bf144c8bc
Run the following to create the stubs/bosh-init/users.yml
file, which defines the admin users for the BOSH director.
cat <<EOF > $DEPLOYMENT_DIR/stubs/bosh-init/users.yml
---
BoshInitUsers:
- name: admin
password: REPLACE_WITH_BOSH_ADMIN_PASSWORD
EOF
Next, edit this file to replace the REPLACE_WITH_BOSH_ADMIN_PASSWORD
with the password you intend to use for the 'admin' BOSH user.
Run the following to create the stubs/bosh-init/creds.yml
file, which defines passwords for different bosh users:
cat <<EOF > $DEPLOYMENT_DIR/stubs/bosh-init/creds.yml
---
BoshInitCreds:
NatsPassword: REPLACE_ME
PostgresPassword: REPLACE_ME
BlobStoreDirectorPassword: REPLACE_ME
BlobStoreAgentPassword: REPLACE_ME
MBusPassword: REPLACE_ME
HMPassword: REPLACE_ME
RegistryPassword: REPLACE_ME
EOF
Next, edit this file to replace each REPLACE_ME
with a password. Note
each one of these passwords is meant to be unique. Do not share the same
password.
Run the following to create the stubs/bosh-init/stemcell.yml
file, which defines the stemcell to use to create the BOSH director.
cat <<EOF > $DEPLOYMENT_DIR/stubs/bosh-init/stemcell.yml
---
BoshInitStemcell:
url: REPLACE_WITH_URL_TO_LATEST_BOSH_AWS_HVM_STEMCELL
sha1: REPLACE_WITH_URL_TO_LATEST_BOSH_AWS_HVM_STEMCELL
EOF
Next, select an AWS Xen-HVM Light stemcell and edit the file to replace the url
and sha1
fields for that stemcell. For example:
---
BoshInitStemcell:
url: https://bosh.io/d/stemcells/bosh-aws-xen-hvm-ubuntu-trusty-go_agent?v=3232.6
sha1: 971e869bd825eb0a7bee36a02fe2f61e930aaf29
The bosh.io site does not currently provide the SHA1 hash of stemcells. You must download the stemcell locally and calcuate the SHA1 hash manually. On Mac OS X, this can be done by running:
shasum /path/to/downloaded/stemcell
In order to secure your Cloud Foundry deployment properly, you must generate SSL certificates and keys to secure traffic between components.
The CF and Diego release repositories provide scripts to generate the necessary SSL certificates.
- To generate certificates for consul, run:
cd $DEPLOYMENT_DIR/certs
$CF_RELEASE_DIR/scripts/generate-consul-certs
- To generate certificates for BBS servers in the Diego deployment, run:
$DIEGO_RELEASE_DIR/scripts/generate-diego-certs
mv $DIEGO_RELEASE_DIR/diego-certs/* $DEPLOYMENT_DIR/certs
After running these scripts, you should see the following files in $DEPLOYMENT_DIR/certs
:
DEPLOYMENT_DIR/certs
|- diego-ca.crt
|- diego-ca.key
|-bbs-certs # generated via diego-release/scripts/generate-diego-certs
| |- client.crt
| |- client.key
| |- server.crt
| |- server.key
|-rep-certs # generated via diego-release/scripts/generate-diego-certs
| |- client.crt
| |- client.key
| |- server.crt
| |- server.key
|-consul-certs # generated via cf-release/scripts/generate-consul-certs
| |- agent.crt
| |- agent.key
| |- server-ca.crt
| |- server-ca.key
| |- server.crt
| |- server.key
You can ignore any files with a crl
or csr
extension.
The certificates in consul-certs
are used to set SSL properties for the consul VMs, and the certificates in bbs-certs
are used to set SSL properties on the BBS API servers. Finally, certificates in rep-certs
are used to secure communication between the Auctioneer
, BBS
and the Rep
To enable SSH access to CF instances running on Diego, generate a host key and fingerprint for the SSH proxy as follows, entering an empty string for the passphrase when prompted:
ssh-keygen -f $DEPLOYMENT_DIR/keypair/ssh-proxy-host-key.pem
If the local ssh-keygen
supports the -E
flag, as it does on OS X 10.11 El Capitan or Ubuntu 16.04 Xenial Xerus, generate the MD5 fingerprint of the public host key as follows:
ssh-keygen -lf $DEPLOYMENT_DIR/keypair/ssh-proxy-host-key.pem.pub -E md5 | cut -d ' ' -f2 | sed 's/MD5://g' > $DEPLOYMENT_DIR/keypair/ssh-proxy-host-key-fingerprint
Otherwise, generate the MD5 fingerprint as follows:
ssh-keygen -lf $DEPLOYMENT_DIR/keypair/ssh-proxy-host-key.pem.pub | cut -d ' ' -f2 > $DEPLOYMENT_DIR/keypair/ssh-proxy-host-key-fingerprint
The ssh-proxy-host-key.pem
file contains the PEM-encoded private host key for the Diego manifest, and the ssh-proxy-host-key-fingerprint
file contains the MD5 fingerprint of the public host key. You will later copy these values into stubs for generating the CF and Diego manifests.
UAA requires an RSA keypair for its configuration. Generate one as follows, entering an empty string for the passphrase when prompted:
ssh-keygen -t rsa -b 4096 -f $DEPLOYMENT_DIR/keypair/uaa
openssl rsa -in $DEPLOYMENT_DIR/keypair/uaa -pubout > $DEPLOYMENT_DIR/keypair/uaa.pub
To create the AWS environment and two VMs essential to the Cloud Foundry infrastructure,
run ./deploy_aws_environment create "$CF_RELEASE_DIR" "$DEPLOYMENT_DIR"
from the directory containing these instructions ($DIEGO_RELEASE_DIR/examples/aws
).
This process may take up to 30 minutes.
cd "$DIEGO_RELEASE_DIR/examples/aws"
./deploy_aws_environment create "$CF_RELEASE_DIR" "$DEPLOYMENT_DIR"
The ./deploy_aws_environment
script takes three required arguments and a fourth, optional argument:
-
The first argument is one of three directives, which you'll need if our script doesn't succeed the first time:
create
creates an AWS CloudFormation stack based off of the stubs filled out above.update
updates the CloudFormation stack. Run the script with this command after changing the stubs in$DEPLOYMENT_DIR/stubs/infrastructure
, or after an update to this example directory. If there are no changes to the stack, instead run theskip
command below, as otherwise the script will fail.skip
upgrades the BOSH director without affecting the CloudFormation stack.
-
The second argument is the absolute path to
$CF_RELEASE_DIR
. -
The third argument is the absolute path to
$DEPLOYMENT_DIR
, which must be structured as defined above. -
The fourth (optional) argument is the stack name for the deployment environment which, if provided, overrides the default environment name
cf-diego-stack
.
The deployment process generates a collection of stubs, in the following directory structure. Some of the stubs start with the line GENERATED: NO TOUCHING
, and are not intended for hand-editing.
DEPLOYMENT_DIR
|-stubs
| |- director-uuid.yml # the unique id of the BOSH directory
| |- aws-resources.yml # general metadata about the CloudFormation stack
| |-cf
| | |- stub.yml # networks, zones, s3 buckets for the Cloud Foundry deployment
| | |- properties.yml # consul configuration and shared secrets
| | |- domain.yml # domain
| |-diego
| | |- property-overrides.yml # stub to parametrize with Diego manifest property overrides
| | |- iaas-settings.yml # networks, zones for the Diego deployment
| |-diego-windows
| | |- iaas-settings.yml #networks, zones for the Diego Windows deployment
| |-infrastructure
| |- certificates.yml # certificates for the cfrouter ELB
| |- cloudformation.json # CloudFormation JSON deployed to AWS
|-deployments
| |-bosh-init
| |- bosh-init.yml # bosh director deployment
The ./deploy_aws_environment
script generates a partial stub for your
Cloud Foundry deployment. It is a generated stub that contains information specific to the AWS CloudFormation stack and should not be edited manually.
The ./deploy_aws_environment
script copies another partial stub for your
Cloud Foundry deployment. This stub is intended to be editied, as describes in more detail in the
Manifest Generation section.
This stub will be used as part of Diego manifest generation and was constructed from your deployed AWS infrastructure, as well as our default template. This stub provides the skeleton for the certificates generated in the Configuring Security section, as well as for setting the log levels of components.
This stub is used during Diego manifest generation. It contains settings specific to your AWS environment.
This stub is used during Diego Windows Cells manifest generation. It contains settings specific to your AWS environment.
For your BOSH director to be accessible on the Internet via DNS using the Route 53 hosted zone created above, perform the following steps:
- From the EC2 dashboard, obtain the public IP address of the
bosh/0
BOSH director instance. - Click on the
Route53
link on the AWS console. - Click the
Hosted Zones
link. - Click on the hosted zone created earlier.
- Click the
Create Record Set
button. - Enter
bosh
for theName
. - Change the
Type
toA - IPv4 address
if it is not already set to that type. - Enter the public IP address of the BOSH director for the value.
- Click the
Create
button.
To deploy Cloud Foundry, you need a stub similar to the one from the Cloud Foundry Documentation.
The generated stub $DEPLOYMENT_DIR/stubs/cf/stub.yml
already has some of these properties filled out for you.
The stub $DEPLOYMENT_DIR/stubs/cf/properties.yml
contains some additional placeholder properties that you must specify.
For more information on stubs for Cloud Foundry manifest generation, please refer to the documentation here.
The default deployment configuration from the manifest-generation scripts in cf-release omits some instances and properties that Diego depends on.
It also includes some instances and properties that are unnecessary for a deployment with Diego as the only container runtime. Including $DIEGO_RELEASE_DIR/examples/aws/stubs/cf/diego.yml
in the list of stubs when generating the Cloud Foundry manifest will configure these instance counts and properties correctly.
In order to correctly generate a manifest for the Cloud Foundry deployment, you must
replace certain values in the provided $DEPLOYMENT_DIR/stubs/cf/properties.yml
.
Replace all the values that are prefixed with REPLACE_WITH_
.
Note: If you did not generate a self-signed certificate for the
CF Router ELB and are instead using a certificate signed by a
trusted certificate authority, change the value of properties.ssl.skip_cert_verify
from true
to false
.
If you also wish to change the instance counts for the jobs in the CF deployment, add those different counts to this stub. These counts will override the counts set in the $DIEGO_RELEASE_DIR/examples/aws/stubs/cf/diego.yml
if using the command below to generate the manifest.
If you wish to enable volume services add the following property to the cc
section of $DEPLOYMENT_DIR/stubs/cf/properties.yml
:
cc:
...
volume_services_enabled: true
After following the instructions to fill out the placeholder values
in the DEPLOYMENT_DIR/stubs/cf/stub.yml
stub, run the following to generate the Cloud Foundry manifest:
cd $CF_RELEASE_DIR
./scripts/generate_deployment_manifest aws \
$DEPLOYMENT_DIR/stubs/director-uuid.yml \
$DIEGO_RELEASE_DIR/examples/aws/stubs/cf/diego.yml \
$DEPLOYMENT_DIR/stubs/cf/properties.yml \
$DEPLOYMENT_DIR/stubs/cf/stub.yml \
> $DEPLOYMENT_DIR/deployments/cf.yml
Target the BOSH director using either the public IP address or the Route53 record created earlier.
The public IP address can be obtained from either the $DEPLOYMENT_DIR/stubs/aws-resources.yml
under Resources.EIP.BoshInit
or from the EC2 dashboard in the AWS console.
bosh target bosh.$CF_DOMAIN
When prompted for the username and password, provide the credentials set in the $DEPLOYMENT_DIR/stubs/bosh-init/users.yml
stub.
Upload the lastest BOSH stemcell for AWS to the bosh director. You can find the latest stemcell here.
bosh upload stemcell /path/to/stemcell
In order to deploy CF, create and upload the release to the director using the following commands:
cd $CF_RELEASE_DIR
bosh --parallel 10 create release
bosh upload release
Set the CF deployment manifest and deploy with the following commands:
bosh deployment $DEPLOYMENT_DIR/deployments/cf.yml
bosh deploy
From here, follow the documentation on deploying a Cloud Foundry with BOSH. Depending on the size of the deployment and the time required for package compilation, the initial deploy can take many minutes or hours.
These instructions allow you to configure Diego to use a relational database as the backing data store using one of the following methods:
- Setting up an RDS MySQL
- Setting up an RDS PostgreSQL
- Deploying a standalone CF-MySQL
- Using the PostgreSQL job from CF-Release
The instructions below describe how to set up a MariaDB RDS instance that is known to work with Diego.
- From the AWS console homepage, click on
RDS
in theDatabase
section. - Click on
Launch DB Instance
under Instances. - Click on the
MariaDB
tab and click theSelect
button. - Select Production or Dev/Test version of MariaDB depending on your use case and click the
Next Step
button. - Select the DB Instance Class required. For performance testing the Diego team uses db.m4.4xlarge.
- Optionally tune the other parameters based on your deployment requirements.
- Provide a unique DB Instance Identifier. This identifier can be arbitrary, as is not used directly in the Diego configuration below.
- Choose and confirm a master username and password, and record them for later use in the Diego-SQL stub.
- Click
Next Step
. - Select the VPC created during the bosh-init steps above.
- Select
No
for thePublicly Accessible
option. - Select the
VPC Security Group
matching*-InternalSecurityGroup-*
. - Choose a Database Name (for example,
diego
). - Click
Launch DB Instance
. - Wait for the Instance to be
available
.
In order to configure SSL for RDS you need to download the ca cert bundle from AWS. This can be done by:
curl -o $DEPLOYMENT_DIR/certs/rds-combined-ca-bundle.pem http://s3.amazonaws.com/rds-downloads/rds-combined-ca-bundle.pem
The contents of this file will be supplied in the sql_overrides.bbs.ca_cert
field in the Diego-SQL stub below.
To setup a PostgreSQL instance on RDS in AWS, follow the instructions above describing the setup of a MySQL AWS RDS instance, but select the PostgreSQL
tab instead of the MariaDB
tab in step 3. Make sure to pick a version of PostgreSQL that is 9.4 or higher.
The CF-MySQL release can be deployed in a few different modes and configurations. All configurations have the same starting steps:
- Make a directory for the CF-MySQL stubs:
mkdir -p $DEPLOYMENT_DIR/stubs/cf-mysql
- Clone the CF-MySQL release
release-candidate
branch:
git clone -b release-candidate https://github.com/cloudfoundry/cf-mysql-release.git
export CF_MYSQL_RELEASE_DIR=$PWD/cf-mysql-release
- Copy over relevant stubs from the CF-MySQL release to deployment directory:
cp $CF_MYSQL_RELEASE_DIR/manifest-generation/examples/standalone/property-overrides.yml \
$CF_MYSQL_RELEASE_DIR/manifest-generation/examples/standalone/instance-count-overrides.yml \
$DEPLOYMENT_DIR/stubs/cf-mysql/
- Copy over CF-based manifest stub:
cp $DEPLOYMENT_DIR/deployments/cf.yml $DEPLOYMENT_DIR/stubs/cf-mysql/cf.yml
- Edit
property-overrides.yml
: - Rename the deployment:
```yaml
property_overrides:
deployment_name: diego-mysql
```
- Fill in all
REPLACE_WITH_
properties with appropriate values. Ignore allUNUSED_VALUE
properties. - Set the
host
property tonull
. Do not remove it entirely, since the current manifest-generation scripts for CF-MySQL depend on its presence:
```yaml
property_overrides:
host: null
```
- Add the following
seeded_databases
property to configure a database for Diego to use. ReplaceREPLACE_ME_WITH_DB_PASSWORD
with the desired password for the database:
```yaml
property_overrides:
mysql:
seeded_databases:
- name: diego
username: diego
password: REPLACE_ME_WITH_DB_PASSWORD
```
After that you can deploy the CF-MySQL release in either mode:
- Single Node CF-MySQL - Used mostly for development and experimentation since it does not provide the same uptime guarantees that the multi-node deployment does.
- Highly Available CF-MySQL - Recommended for production use. Uses Consul for discovery.
- Edits to
instance-count-overrides.yml
:
instance_count_overrides:
- name: cf-mysql-broker_z1
instances: 0
- name: cf-mysql-broker_z2
instances: 0
- name: mysql_z2
instances: 0
- name: arbitrator_z3
instances: 0
- name: proxy_z1
instances: 0
- name: proxy_z2
instances: 0
- Generate deployment manifest:
$CF_MYSQL_RELEASE_DIR/scripts/generate-deployment-manifest \
-c $DEPLOYMENT_DIR/stubs/cf-mysql/cf.yml \
-p $DEPLOYMENT_DIR/stubs/cf-mysql/property-overrides.yml \
-i $DEPLOYMENT_DIR/stubs/cf-mysql/iaas-settings.yml \
-n $DEPLOYMENT_DIR/stubs/cf-mysql/instance-count-overrides.yml \
> $DEPLOYMENT_DIR/deployments/cf-mysql.yml
- Deploy the CF-MySQL cluster
cd $CF_MYSQL_RELEASE_DIR
bosh create release && bosh upload release && bosh -d $DEPLOYMENT_DIR/deployments/cf-mysql.yml deploy
- Copy additional
job-overrides-consul.yml
:
cp $CF_MYSQL_RELEASE_DIR/manifest-generation/examples/job-overrides-consul.yml \
$DEPLOYMENT_DIR/stubs/cf-mysql/
- Edits to
property-overrides.yml
, add the following properties:
property_overrides:
proxy:
# ...
consul_enabled: true
consul_service_name: mysql
- Generate deployment manifest:
$CF_MYSQL_RELEASE_DIR/scripts/generate-deployment-manifest \
-c $DEPLOYMENT_DIR/stubs/cf-mysql/cf.yml \
-p $DEPLOYMENT_DIR/stubs/cf-mysql/property-overrides.yml \
-i $DEPLOYMENT_DIR/stubs/cf-mysql/iaas-settings.yml \
-j $DEPLOYMENT_DIR/stubs/cf-mysql/job-overrides-consul.yml \
-n $DEPLOYMENT_DIR/stubs/cf-mysql/instance-count-overrides.yml \
> $DEPLOYMENT_DIR/deployments/cf-mysql.yml
- Deploy the CF-MySQL cluster
bosh -d $DEPLOYMENT_DIR/deployments/cf-mysql.yml deploy
The PostgreSQL job in CF Release can be used as the database for Diego. Replace REPLACE_ME_WITH_DB_PASSWORD
in your stubs/cf/properties.yml
with your desired password, and configure Diego to use this database.
databases:
...
roles:
...
- name: diego:
password: REPLACE_WITH_DB_PASSWORD
To configure Diego to communicate with the SQL instance, first create a Diego-SQL stub file at $DEPLOYMENT_DIR/stubs/diego/diego-sql.yml
with the following contents:
sql_overrides:
bbs:
db_driver: <driver>
db_host: <sql-instance-endpoint>
db_port: <port>
db_username: diego
db_password: <REPLACE_ME_WITH_DB_PASSWORD>
db_schema: diego
max_open_connections: 500
require_ssl: null
ca_cert: null
Fill in the bracketed parameters in the db_driver
, db_host
, db_port
and db_password
with the following values:
<driver>
could be eithermysql
orpostgres
depending on the flavor of your backing data store.- For AWS RDS:
- The endpoint displayed at the top of the DB instance would replace
<sql-instance-endpoint>
in details page <port>
will take on the value of the port for the given DB instance.
- The endpoint displayed at the top of the DB instance would replace
- For Standalone CF-MySQL:
- If configuring a Single Node CF-MySQL,
<sql-instance-endpoint>
would be the internal IP address and<port>
would take on the port of the single MySQL node. - If configuring an Highly Available CF-MySQL with Consul use the consul service address (e.g.
mysql.service.cf.internal
for<sql-instance-endpoint>
and3306
for<port>
).
- If configuring a Single Node CF-MySQL,
<REPLACE_ME_WITH_DB_PASSWORD>
: The password chosen when you created the SQL instance.
Note: these instructions are deprecated, and we suggest using the properties described above instead of providing a connection string.
To configure Diego to communicate with the SQL instance, first create a Diego-SQL stub file at $DEPLOYMENT_DIR/stubs/diego/diego-sql.yml
with the following contents:
sql_overrides:
bbs:
db_connection_string: 'diego:REPLACE_ME_WITH_DB_PASSWORD@tcp(<sql-instance-endpoint>)/diego'
max_open_connections: 500
require_ssl: null
ca_cert: null
Fill in the bracketed parameters in the db_connection_string
with the following values:
REPLACE_ME_WITH_DB_PASSWORD
: The password chosen when you created the SQL instance.<sql-instance-endpoint>
:- For AWS RDS: The endpoint displayed at the top of the DB instance details page in AWS, including the port.
- For Standalone CF-MySQL:
- If configuring a Single Node CF-MySQL the internal IP address and port of the single MySQL node. (e.g.
10.10.5.222:3306
). - If configuring an Highly Available CF-MySQL with Consul use the consul service address (e.g.
mysql.service.cf.internal:3306
). - In both cases the port will be
3306
by default.
- If configuring a Single Node CF-MySQL the internal IP address and port of the single MySQL node. (e.g.
Note: The sql_overrides.bbs.ca_cert
and sql_overrides.bbs.require_ssl
properties should be provided only when deploying with an SSL-supported MySQL cluster. Set the require_ssl
property to true
to ensure that the BBS uses SSL to connect to the store, and set the ca_cert
property to the contents of a certificate bundle containing the correct CA certificates to verify the certificate that the SQL server presents.
If enabling SSL for an RDS database, include the contents of $DEPLOYMENT_DIR/certs/rds-combined-ca-bundle.pem
as the value of the ca_cert
property:
sql_overrides:
bbs:
ca_cert: |
REPLACE_WITH_CONTENTS_OF_(DEPLOYMENT_DIR/certs/rds-combined-ca-bundle.pem)
Note Assuming you are migrating from an etcd deployment, you need to follow steps in this section in order to ensure data is migrated successfully from etcd to the new sql backend. Otherwise, feel free to skip to the next section.
Genereate the Diego manifest with an additional -s
flag that specifies
the location of the Diego-SQL stub, as shown below. Remember that the -n
instance-count-overrides flag and the -v
release-versions flags are optional.
cd $DIEGO_RELEASE_DIR
./scripts/generate-deployment-manifest \
-c $DEPLOYMENT_DIR/deployments/cf.yml \
-i $DEPLOYMENT_DIR/stubs/diego/iaas-settings.yml \
-p $DEPLOYMENT_DIR/stubs/diego/property-overrides.yml \
-s $DEPLOYMENT_DIR/stubs/diego/diego-sql.yml \
-n $DEPLOYMENT_DIR/stubs/diego/instance-count-overrides.yml \
-v $DEPLOYMENT_DIR/stubs/diego/release-versions.yml \
> $DEPLOYMENT_DIR/deployments/diego.yml
This step will disable etcd as the backend store and enable SQL (unless already enabled). Make sure to follow the steps in the previous section if you are migrating from etcd.
To enable sql and remove etcd from your deployment, invoke the
manifest-generation script with the -x
and -s
flags as shown below:
cd $DIEGO_RELEASE_DIR
./scripts/generate-deployment-manifest \
-c $DEPLOYMENT_DIR/deployments/cf.yml \
-i $DEPLOYMENT_DIR/stubs/diego/iaas-settings.yml \
-p $DEPLOYMENT_DIR/stubs/diego/property-overrides.yml \
-s $DEPLOYMENT_DIR/stubs/diego/diego-sql.yml \
-x \
-n $DEPLOYMENT_DIR/stubs/diego/instance-count-overrides.yml \
-v $DEPLOYMENT_DIR/stubs/diego/release-versions.yml \
> $DEPLOYMENT_DIR/deployments/diego.yml
Follow steps in Migration of BBS Data from etcd to SQL to verify that the migration ran successfully.
Support for etcd is deprecated.
If you enabled volume services, create and upload your Driver's bosh release.
If you would like to use the cephdriver
that we use for testing and development then you may use this repo.
After deploying Cloud Foundry, you can now deploy Diego.
To generate a manifest for the Diego deployment, replace the properties in the
$DEPLOYMENT_DIR/stubs/diego/property-overrides.yml
file that are prefixed with REPLACE_WITH_
.
Here is a summary of the properties that must be changed:
- Replace all instances of
REPLACE_WITH_ACTIVE_KEY_LABEL
with the desired key name (for example,key-a
). - Replace
REPLACE_WITH_A_SECURE_PASSPHRASE
with a unique passphrase associated with the active key label.
Component log levels and other deployment properties may also be overridden in this stub file.
This stub file also contains the contents of the BBS, and SSH-Proxy
certificates and keys generated above. If those files are regenerated, the
deploy_aws_environment
script will update the property-overrides stub with
their new contents.
Copy the example stub to $DEPLOYMENT_DIR/stubs/diego/instance-count-overrides.yml
:
cp $DIEGO_RELEASE_DIR/examples/aws/stubs/diego/instance-count-overrides-example.yml $DEPLOYMENT_DIR/stubs/diego/instance-count-overrides.yml
Edit that file to change the instance counts of the deployed Diego VMs.
Copy the example release-versions stub to the correct location:
cp $DIEGO_RELEASE_DIR/examples/aws/stubs/diego/release-versions.yml $DEPLOYMENT_DIR/stubs/diego/release-versions.yml
Edit it to fix the versions of the diego, garden-runc, and cflinuxfs2 releases in the Diego deployment, instead of using the latest versions uploaded to the BOSH director.
For example, to use version 1.0.0 of garden-runc-release, edit the stub to read:
release-versions:
diego: latest
cflinuxfs2-rootfs: latest
garden-runc: 1.0.0
If using a SQL store for the BBS, follow the directions to fill in the Diego-SQL Stub with the SQL database configuration.
If you enabled volume services, follow these directions to fill in the drivers Stub with your driver configuration.
See the full manifest generation documentation for more generation instructions.
Remember that the -n
instance-count-overrides flag and the -v
release-versions flags are optional. If using a non-standard deployment (SQL, Volume Drivers, etc) follow the generate the Diego manifest optional instructions.
cd $DIEGO_RELEASE_DIR
./scripts/generate-deployment-manifest \
-c $DEPLOYMENT_DIR/deployments/cf.yml \
-i $DEPLOYMENT_DIR/stubs/diego/iaas-settings.yml \
-p $DEPLOYMENT_DIR/stubs/diego/property-overrides.yml \
-n $DEPLOYMENT_DIR/stubs/diego/instance-count-overrides.yml \
-v $DEPLOYMENT_DIR/stubs/diego/release-versions.yml \
> $DEPLOYMENT_DIR/deployments/diego.yml
-
Upload the latest garden-runc-release:
bosh upload release https://bosh.io/d/github.com/cloudfoundry/garden-runc-release
To upload a specific version of garden-runc-release, or to download the release locally before uploading it, please consult directions at bosh.io.
-
Upload the latest cflinuxfs2-rootfs-release:
bosh upload release https://bosh.io/d/github.com/cloudfoundry/cflinuxfs2-rootfs-release
To upload a specific version of cflinuxfs2-rootfs-release, or to download the release locally before uploading it, please consult directions at bosh.io.
As with the Cloud Foundry deployment, once the Diego manifest is generated, you need to create the Diego release, upload it to the BOSH director, and deploy Diego:
bosh deployment $DEPLOYMENT_DIR/deployments/diego.yml
cd $DIEGO_RELEASE_DIR
bosh --parallel 10 create release --force
bosh upload release
bosh deploy
To deploy a set of Diego cells using garden-windows, follow the directions in Setup Garden Windows for Diego.