Name: bosh-deployment
Owner: Stark & Wayne
Description: Genesis templates for deploying BOSH (via bosh-init, or bosh-proper)
Created: 2016-06-07 20:31:39.0
Updated: 2018-05-08 16:03:23.0
Pushed: 2017-03-30 18:07:59.0
Homepage: null
Size: 69
Language: Shell
GitHub Committers
User | Most Recent Commit | # Commits |
---|
Other Committers
User | Most Recent Commit | # Commits |
---|
This repository acts as an upstream repository of YAML templates for use in deploying one or more BOSH directors, via the Gensis utility.
To create a new Genesis-based deployment of BOSH, run
genesis new deployment --template bosh
This will create a new repo called bosh-deployments
for you, and
pull in the github.com/starkandwayne/bosh-deployment
repo as the
upstream
remote, copying the contents of global/*
into the new
bosh-deployments
repository.
This allows you to easily diverge from the upstream templates to suit your environment, yet still be able to pull in changes from upstream down the road.
Jurassic BOSH is a paradigm for deploying multiple BOSH directors to eliminate
much of the time-sink created by bosh-init
. Its highly useful in a situation
where you have many BOSH directors (one for each of your staging, prod, dev, etc.
environments). Essentially, you deploy a Proto BOSH via bosh-init
, and then
deploy the environment-specific BOSHes on top of your Proto BOSH as regular
BOSH deployments.
Doing this with these templates is quite easy! To stand up your Proto BOSH:
nesis new deployment --template bosh
bosh-deployments
nesis new site --template <aws|vsphere|openstack> site-name
nesis new env --type bosh-init site-name proto
site-name/proto
ke deploy # ... and fill in all the required parameters to deploy your BOSH
Once that bosh has been stood up, you can target it with the BOSH cli, and start creating your environment-specific BOSHen:
sh target https://your.director.ip:25555 site-name-proto-bosh
nesis new env --type normal site-name staging
../staging # assuming you were still in the site-name/proto directory
ke deploy # ... and fill in all the required parameters to deploy your BOSH
The deployment in site-name/proto
will get deployed via bosh-init
, while the
site-name/staging
deployment will be deployed via BOSH against the site-name-proto-bosh
director. As of now, the --type normal
flag is optional for regular BOSHen, since it
is the default method for deploying in genesis
The vsphere
template will set you up with a structure suitable
for deploying BOSH directors on a VMWare vSphere ESXi cluster.
genesis new site --template vsphere <name>
The aws
template will set you up with a structure suitable for
deploying BOSH directors to Amazon Web Service's EC2/VPC
infrastructure.
genesis new site --template aws <name>
The azure
template will set you up with a structure suitable for
deploying BOSH directors to Azure's ARM
infrastructure.
genesis new site --template azure <name>
The google
template will set you up with a structure suitable for
deploying BOSH directors to Google Cloud Plaftorm infrastructure.
genesis new site --template google <name>
The vcloud
template will set you up with a structure suitable for
deploying BOSH directors to vCloud Director infrastructure.
genesis new site --template vcloud <name>
For more information, check out the Genesis repo, or genesis help
.
You can download the Genesis program from Github