bosh-gen 0.13.3 → 0.14.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,15 +1,15 @@
1
1
  ---
2
2
  !binary "U0hBMQ==":
3
3
  metadata.gz: !binary |-
4
- NDU2OTNhYTgzN2FkODM4ZTlhOWI5YWI2MTE3MjZlMmJmMDRlOTY0Mw==
4
+ ZGY3MjdjNjc4MzQ1Y2Q0MjNmZTM1Mzg4ODYxNDJlNzFjMjdmMGRiNQ==
5
5
  data.tar.gz: !binary |-
6
- Mzg0ZTdjNjY1OGUwN2M3YTI1OGJhMzBjNmJkOTE3MGY3YmNjNDY1Nw==
6
+ NWE2ZWFjMGY5MmZiYWI4NTU0MjU2MmY4NGRmMDdiODc0MThkYjIxMw==
7
7
  SHA512:
8
8
  metadata.gz: !binary |-
9
- ZjczMWRhOWJmN2M4OTMzNTg5NGM0N2JiN2E4NzAyZDgzNDI1Yjk5YjliMzMz
10
- MWMzZGY0YmZhZGE5OWY1Y2Y5NGRiZmVlODU5Mjg4Y2VjODlkMTZiY2NlMTkz
11
- ZDUxNzZmZDE0NTZiY2Y0OTg0N2Q0ZjdjZjFmYmJkYzA5YjI0YzU=
9
+ MjAxNTliZDc2M2Y4ZWFiNjA0ZTgwYjI5Zjg2NjI1ODY1NTc2ZWJkMDBkNDNk
10
+ MWM4OWE0NTE3MTFhNDY1NzE3MzZkMjQxYzliOWRiMzYyZDk4MDlkMzZhZDEx
11
+ MmY0OGVkNDYwMTk3MzgxYmIyOWI4NDA1MTRjNjkwNmNkZWQ0ZjY=
12
12
  data.tar.gz: !binary |-
13
- NWFhZDZjN2Y4MmFlYmM0YTZmNDgyZDAwNzk4MGQ5NTVmNjcyMjc1Njk5OTVm
14
- Y2RmOTAyZTU1YjFmYTIzNjY4YzhhY2NhY2RjZGIzYjQxNzE1MTYwOTExNzkw
15
- NDJjMTBmNDQ3NWZlMjE3NWYwNDg3ZTMxMjY4NGZlYjQ4MWJhMGU=
13
+ NWJlMzBlYzY2OTlmMjEwNGE3YTA3YWEyNzk3OTMxOWRhNDBmZDYyNzZiMzg3
14
+ MjBjNTRkM2U2Y2I3ODZkMGNiOWVmYjE4NzM1NzUyZjg4NGVjNDJlNWVjZjgw
15
+ ZWY4NzlhNWY3MGRlMWYxYmJiMDhjZDRiMDVmNDE1YjY1NWI0OWY=
data/.gitignore CHANGED
@@ -15,4 +15,5 @@ spec/reports
15
15
  test/tmp
16
16
  test/version_tmp
17
17
  tmp
18
- .DS_Store
18
+ .DS_Store
19
+ binstubs
data/ChangeLog.md CHANGED
@@ -1,5 +1,10 @@
1
1
  # Change Log
2
2
 
3
+ ## v0.14.0
4
+
5
+ * templates/make_manifest & example spiff templates generated
6
+ * no more static example bosh-lite.yml templates
7
+
3
8
  ## v0.13.0
4
9
 
5
10
  * bosh-lite example manifests generated for new releases
data/Gemfile CHANGED
@@ -1,8 +1,7 @@
1
1
  source 'https://rubygems.org'
2
- source 'https://s3.amazonaws.com/bosh-jenkins-gems/' # for bosh 1.5.0.pre gems
3
2
 
4
3
  # Specify your gem's dependencies in bosh-gen.gemspec
5
4
  gemspec
6
5
 
7
- gem 'bosh_cli', '~> 1.5.0.pre'
8
- gem 'bosh_common', '~> 1.5.0.pre'
6
+ gem 'bosh_cli', '~> 1.1750.0'
7
+ gem 'bosh_common', '~> 1.1750.0'
data/bin/bosh-gen CHANGED
@@ -1,6 +1,6 @@
1
1
  #!/usr/bin/env ruby
2
- $:.push File.dirname(__FILE__) + '/../lib'
3
2
 
3
+ $:.push File.dirname(__FILE__) + '/../lib'
4
4
  require "rubygems"
5
5
  require "bosh/gen/cli"
6
6
 
data/lib/bosh/gen/cli.rb CHANGED
@@ -22,7 +22,6 @@ module Bosh
22
22
  def new(path)
23
23
  flags = { :aws => options["s3"], :atmos => options["atmos"],
24
24
  :swift => options["swift"]}
25
-
26
25
  require 'bosh/gen/generators/new_release_generator'
27
26
  Bosh::Gen::Generators::NewReleaseGenerator.start([path, flags])
28
27
  end
@@ -28,11 +28,15 @@ module Bosh::Gen
28
28
  end
29
29
 
30
30
  def directories
31
- %w[jobs packages src blobs examples].each do |dir|
31
+ %w[jobs packages src blobs templates].each do |dir|
32
32
  directory dir
33
33
  end
34
34
  end
35
-
35
+
36
+ def executables
37
+ chmod "templates/make_manifest", 0755
38
+ end
39
+
36
40
  def blobs_yaml
37
41
  create_file "config/blobs.yml", YAML.dump({})
38
42
  end
@@ -149,6 +153,8 @@ module Bosh::Gen
149
153
  *~
150
154
  *#
151
155
  #*
156
+ tmp
157
+ my*.yml
152
158
  IGNORE
153
159
  end
154
160
 
@@ -179,6 +185,14 @@ module Bosh::Gen
179
185
  @project_name ||= File.basename(proposed_app_path).gsub(/-(?:boshrelease|release)$/, '')
180
186
  end
181
187
 
188
+ def project_name_hyphenated
189
+ project_name.gsub(/[^A-Za-z]+/, '-')
190
+ end
191
+
192
+ def project_name_underscored
193
+ project_name.gsub(/[^A-Za-z]+/, '_')
194
+ end
195
+
182
196
  def blobstore_type
183
197
  return :s3 if s3?
184
198
  return :atmos if atmos?
@@ -11,11 +11,48 @@ cd <%= repository_name %>
11
11
  bosh upload release releases/<%= project_name %>-1.yml
12
12
  ```
13
13
 
14
- For [bosh-lite](https://github.com/cloudfoundry/bosh-lite), you can quickly create a deployment manifest:
14
+ For [bosh-lite](https://github.com/cloudfoundry/bosh-lite), you can quickly create a deployment manifest & deploy a 3 VM cluster:
15
15
 
16
16
  ```
17
- cp examples/bosh-lite-cluster.yml local-cluster.yml
18
- sed -i '' -e "s/DIRECTOR_UUID/$(bosh status | grep UUID | awk '{print $2}')/" local-cluster.yml
19
- bosh deployment local-cluster.yml
17
+ templates/make_manifest warden
18
+ bosh -n deploy
19
+ ```
20
+
21
+ For Openstack (Nova Networks), create a single VM:
22
+
23
+ ```
24
+ templates/make_manifest openstack-nova
25
+ bosh -n deploy
26
+ ```
27
+
28
+ For AWS EC2, create a single VM:
29
+
30
+ ```
31
+ templates/make_manifest aws-ec2
32
+ bosh -n deploy
33
+ ```
34
+
35
+ ### Override security groups
36
+
37
+ For AWS & Openstack, the default deployment assumes there is a `default` security group. If you wish to use a different security group(s) then you can pass in additional configuration when running `make_manifest` above.
38
+
39
+ Create a file `my-networking.yml`:
40
+
41
+ ``` yaml
42
+ ---
43
+ networks:
44
+ - name: <%= project_name %>1
45
+ type: dynamic
46
+ cloud_properties:
47
+ security_groups:
48
+ - <%= project_name %>
49
+ ```
50
+
51
+ Where `- <%= project_name %>` means you wish to use an existing security group called `<%= project_name %>`.
52
+
53
+ You now suffix this file path to the `make_manifest` command:
54
+
55
+ ```
56
+ templates/make_manifest openstack-nova my-networking.yml
20
57
  bosh -n deploy
21
58
  ```
@@ -0,0 +1,34 @@
1
+ meta:
2
+ environment: (( merge ))
3
+ stemcell: (( merge ))
4
+
5
+ name: (( meta.environment ))
6
+
7
+ director_uuid: (( merge ))
8
+
9
+ releases: (( merge ))
10
+
11
+ networks: (( merge ))
12
+
13
+ jobs: (( merge ))
14
+
15
+ properties: (( merge ))
16
+
17
+ compilation:
18
+ workers: 6
19
+ network: <%= project_name_underscored %>1
20
+ reuse_compilation_vms: true
21
+ cloud_properties: (( merge ))
22
+
23
+ update:
24
+ canaries: 1
25
+ max_in_flight: 1
26
+ canary_watch_time: 30000-60000
27
+ update_watch_time: 5000-60000
28
+
29
+ resource_pools:
30
+ - name: small_z1
31
+ network: <%= project_name_underscored %>1
32
+ size: (( auto ))
33
+ stemcell: (( meta.stemcell ))
34
+ cloud_properties: (( merge ))
@@ -0,0 +1,40 @@
1
+ meta:
2
+ environment: (( merge ))
3
+ dns_root: (( merge ))
4
+ security_groups: (( merge ))
5
+ network_name: (( merge ))
6
+
7
+ stemcell:
8
+ name: bosh-aws-xen-ubuntu
9
+ version: 1722
10
+
11
+ jobs:
12
+ - name: <%= project_name_underscored %>_leader_z1
13
+ instances: 1
14
+ networks:
15
+ - name: (( meta.network_name ))
16
+ - name: <%= project_name %>_z1
17
+ instances: 2
18
+ networks:
19
+ - name: (( meta.network_name ))
20
+ properties:
21
+ etcd:
22
+ leader_address: (( "0.<%= project_name_hyphenated %>-leader-z1.<%= project_name_hyphenated %>1." meta.environment "." meta.dns_root ))
23
+
24
+ compilation:
25
+ cloud_properties:
26
+ instance_type: m1.small
27
+
28
+ resource_pools:
29
+ - name: small_z1
30
+ cloud_properties:
31
+ instance_type: m1.small
32
+
33
+ networks:
34
+ - name: floating
35
+ type: vip
36
+ cloud_properties: {}
37
+ - name: (( meta.network_name ))
38
+ type: dynamic
39
+ cloud_properties:
40
+ security_groups: (( meta.security_groups ))
@@ -0,0 +1,107 @@
1
+ meta:
2
+ environment: <%= project_name_hyphenated %>-warden
3
+ network_name: (( merge ))
4
+
5
+ stemcell:
6
+ name: bosh-warden-boshlite-ubuntu
7
+ version: 24
8
+
9
+ update:
10
+ canaries: 1
11
+ max_in_flight: 50
12
+ canary_watch_time: 1000-30000
13
+ update_watch_time: 1000-30000
14
+
15
+ jobs:
16
+ - name: <%= project_name_underscored %>_leader_z1
17
+ instances: 1
18
+ networks:
19
+ - name: (( meta.network_name ))
20
+ static_ips: (( static_ips(0) ))
21
+ - name: <%= project_name_underscored %>_z1
22
+ instances: 2
23
+ networks:
24
+ - name: (( meta.network_name ))
25
+ static_ips: ~
26
+ properties:
27
+ <%= project_name_underscored %>:
28
+ master: (( jobs.<%= project_name_underscored %>_leader_z1.networks.<%= project_name_underscored %>1.static_ips.[0] ))
29
+
30
+ compilation:
31
+ cloud_properties:
32
+ name: random
33
+
34
+ resource_pools:
35
+ - name: small_z1
36
+ cloud_properties:
37
+ name: random
38
+
39
+ networks:
40
+ - name: (( meta.network_name ))
41
+ # Assumes up to 5 VMs, including 1 static and 4 dynamic.
42
+ # Plus 5 (double the size) unused IPs, due to BOSH bug/quirk.
43
+ subnets:
44
+ - cloud_properties:
45
+ name: random
46
+ range: 10.244.2.0/30
47
+ reserved:
48
+ - 10.244.2.1
49
+ static:
50
+ - 10.244.2.2
51
+
52
+ - cloud_properties:
53
+ name: random
54
+ range: 10.244.2.4/30
55
+ reserved:
56
+ - 10.244.2.5
57
+ static: []
58
+ - cloud_properties:
59
+ name: random
60
+ range: 10.244.2.8/30
61
+ reserved:
62
+ - 10.244.2.9
63
+ static: []
64
+ - cloud_properties:
65
+ name: random
66
+ range: 10.244.2.12/30
67
+ reserved:
68
+ - 10.244.2.13
69
+ static: []
70
+ - cloud_properties:
71
+ name: random
72
+ range: 10.244.2.16/30
73
+ reserved:
74
+ - 10.244.2.17
75
+ static: []
76
+
77
+ # Bonus double-sized network required due to BOSH oddity
78
+ - cloud_properties:
79
+ name: random
80
+ range: 10.244.2.20/30
81
+ reserved:
82
+ - 10.244.2.21
83
+ static: []
84
+ - cloud_properties:
85
+ name: random
86
+ range: 10.244.2.24/30
87
+ reserved:
88
+ - 10.244.2.25
89
+ static: []
90
+ - cloud_properties:
91
+ name: random
92
+ range: 10.244.2.28/30
93
+ reserved:
94
+ - 10.244.2.29
95
+ static: []
96
+ - cloud_properties:
97
+ name: random
98
+ range: 10.244.2.32/30
99
+ reserved:
100
+ - 10.244.2.33
101
+ static: []
102
+ - cloud_properties:
103
+ name: random
104
+ range: 10.244.2.36/30
105
+ reserved:
106
+ - 10.244.2.37
107
+ static: []
@@ -0,0 +1,27 @@
1
+ meta:
2
+ environment: ~
3
+
4
+ update:
5
+ canaries: 1
6
+ max_in_flight: 50
7
+ canary_watch_time: 1000-30000
8
+ update_watch_time: 1000-30000
9
+
10
+ jobs:
11
+ - name: <%= project_name_underscored %>_leader_z1
12
+ template: <%= project_name_underscored %>
13
+ instances: 0
14
+ resource_pool: small_z1
15
+ networks: (( merge ))
16
+ - name: <%= project_name_underscored %>_z1
17
+ template: <%= project_name_underscored %>
18
+ instances: 0
19
+ resource_pool: small_z1
20
+ networks: (( merge ))
21
+ update:
22
+ canaries: 10
23
+ properties:
24
+ <%= project_name_underscored %>:
25
+ master: (( merge ))
26
+
27
+ networks: (( merge ))
@@ -0,0 +1,63 @@
1
+ #!/bin/bash
2
+
3
+ set -e
4
+
5
+ infrastructure=$1
6
+ template_prefix="<%= project_name %>"
7
+
8
+ if [ "$infrastructure" != "openstack-nova" ] && \
9
+ [ "$infrastructure" != "aws-ec2" ] && \
10
+ [ "$infrastructure" != "warden" ] ; then
11
+ echo "usage: ./make_manifest <openstack-nova|warden>"
12
+ exit 1
13
+ fi
14
+
15
+ shift
16
+
17
+ BOSH_STATUS=$(bosh status)
18
+ DIRECTOR_UUID=$(echo "$BOSH_STATUS" | grep UUID | awk '{print $2}')
19
+ DIRECTOR_CPI=$(echo "$BOSH_STATUS" | grep CPI | awk '{print $2}')
20
+ DIRECTOR_NAME=$(echo "$BOSH_STATUS" | grep Name | awk '{print $2}')
21
+ NAME=$template_prefix-$infrastructure
22
+
23
+ if [[ $DIRECTOR_NAME = "warden" ]]; then
24
+ if [[ $infrastructure != "warden" ]]; then
25
+ echo "Not targeting bosh-lite with warden CPI. Please use 'bosh target' before running this script."
26
+ exit 1
27
+ fi
28
+ fi
29
+
30
+ if [[ $DIRECTOR_CPI = "aws" ]]; then
31
+ if [[ $infrastructure = "aws-ec2" ]]; then
32
+ echo "Not targeting an AWS BOSH. Please use 'bosh target' before running this script."
33
+ exit 1
34
+ fi
35
+ fi
36
+
37
+ if [[ $DIRECTOR_CPI != "openstack" ]]; then
38
+ if [[ $infrastructure = "openstack-nova" ]]; then
39
+ echo "Not targeting an OpenStack BOSH. Please use 'bosh target' before running this script."
40
+ exit 1
41
+ fi
42
+ fi
43
+
44
+ templates=$(dirname $0)
45
+ release=$templates/..
46
+ tmpdir=$release/tmp
47
+
48
+ mkdir -p $tmpdir
49
+ cp $templates/stub.yml $tmpdir/stub-with-uuid.yml
50
+ echo $DIRECTOR_NAME $DIRECTOR_CPI $DIRECTOR_UUID
51
+ perl -pi -e "s/PLACEHOLDER-DIRECTOR-UUID/$DIRECTOR_UUID/g" $tmpdir/stub-with-uuid.yml
52
+ perl -pi -e "s/NAME/$NAME/g" $tmpdir/stub-with-uuid.yml
53
+
54
+ spiff merge \
55
+ $templates/deployment.yml \
56
+ $templates/jobs.yml \
57
+ $templates/properties.yml \
58
+ $templates/infrastructure-${infrastructure}.yml \
59
+ $tmpdir/stub-with-uuid.yml \
60
+ $* > $tmpdir/$NAME-manifest.yml
61
+
62
+ bosh deployment $tmpdir/$NAME-manifest.yml
63
+ bosh status
@@ -0,0 +1,5 @@
1
+ properties:
2
+ networks:
3
+ apps: <%= project_name_underscored %>1
4
+
5
+ <%= project_name_underscored %>: {}
@@ -0,0 +1,13 @@
1
+ ---
2
+ meta:
3
+ environment: NAME
4
+ dns_root: microbosh
5
+ network_name: <%= project_name_underscored %>1
6
+ security_groups:
7
+ - <%= project_name_underscored %>
8
+
9
+ director_uuid: PLACEHOLDER-DIRECTOR-UUID
10
+
11
+ releases:
12
+ - name: <%= project_name_underscored %>
13
+ version: latest
@@ -42,6 +42,9 @@ module Bosh::Gen
42
42
  set -e # exit immediately if a simple command exits with a non-zero status
43
43
  set -u # report the usage of uninitialized variables
44
44
 
45
+ # Detect # of CPUs so make jobs can be parallelized
46
+ CPUS=`grep -c ^processor /proc/cpuinfo`
47
+
45
48
  # Available variables
46
49
  # $BOSH_COMPILE_TARGET - where this package & spec'd source files are available
47
50
  # $BOSH_INSTALL_TARGET - where you copy/install files to be included in package
@@ -60,8 +63,7 @@ module Bosh::Gen
60
63
  #{unpack_command} #{name}/#{archive_file}
61
64
  cd #{unpack_base_path}
62
65
  ./configure --prefix=${BOSH_INSTALL_TARGET}
63
- make
64
- make install
66
+ make -j${CPUS} && make install
65
67
  # Alternatively, to copy archive contents:
66
68
  # cp -a #{unpack_base_path}/* $BOSH_INSTALL_TARGET
67
69
  SHELL
@@ -50,8 +50,7 @@ module Bosh::Gen
50
50
  (
51
51
  cd #{package_dir}
52
52
  ./configure --prefix=$BOSH_INSTALL_TARGET
53
- make
54
- make install
53
+ make -j${CPUS} && make install
55
54
  )
56
55
 
57
56
  BASH
@@ -1,5 +1,5 @@
1
1
  module Bosh
2
2
  module Gen
3
- VERSION = "0.13.3"
3
+ VERSION = "0.14.0"
4
4
  end
5
5
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: bosh-gen
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.13.3
4
+ version: 0.14.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Dr Nic Williams
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2013-12-10 00:00:00.000000000 Z
11
+ date: 2014-01-09 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: thor
@@ -162,11 +162,16 @@ files:
162
162
  - lib/bosh/gen/generators/new_release_generator/templates/README.md.tt
163
163
  - lib/bosh/gen/generators/new_release_generator/templates/Rakefile
164
164
  - lib/bosh/gen/generators/new_release_generator/templates/blobs/.gitkeep
165
- - lib/bosh/gen/generators/new_release_generator/templates/examples/bosh-lite-cluster.yml.tt
166
- - lib/bosh/gen/generators/new_release_generator/templates/examples/bosh-lite-solo.yml.tt
167
165
  - lib/bosh/gen/generators/new_release_generator/templates/jobs/.gitkeep
168
166
  - lib/bosh/gen/generators/new_release_generator/templates/packages/.gitkeep
169
167
  - lib/bosh/gen/generators/new_release_generator/templates/src/.gitkeep
168
+ - lib/bosh/gen/generators/new_release_generator/templates/templates/deployment.yml.tt
169
+ - lib/bosh/gen/generators/new_release_generator/templates/templates/infrastructure-aws-ec2.yml.tt
170
+ - lib/bosh/gen/generators/new_release_generator/templates/templates/infrastructure-warden.yml.tt
171
+ - lib/bosh/gen/generators/new_release_generator/templates/templates/jobs.yml.tt
172
+ - lib/bosh/gen/generators/new_release_generator/templates/templates/make_manifest.tt
173
+ - lib/bosh/gen/generators/new_release_generator/templates/templates/properties.yml.tt
174
+ - lib/bosh/gen/generators/new_release_generator/templates/templates/stub.yml.tt
170
175
  - lib/bosh/gen/generators/package_generator.rb
171
176
  - lib/bosh/gen/generators/package_generator/templates/.gitkeep
172
177
  - lib/bosh/gen/generators/package_source_generator.rb
@@ -244,7 +249,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
244
249
  version: '0'
245
250
  requirements: []
246
251
  rubyforge_project:
247
- rubygems_version: 2.1.2
252
+ rubygems_version: 2.1.11
248
253
  signing_key:
249
254
  specification_version: 4
250
255
  summary: ''
@@ -1,67 +0,0 @@
1
- ---
2
- name: <%= project_name %>-cluster
3
- director_uuid: DIRECTOR_UUID
4
- releases:
5
- - name: <%= project_name %>
6
- version: latest
7
- compilation:
8
- workers: 3
9
- network: <%= project_name %>-network
10
- reuse_compilation_vms: true
11
- cloud_properties:
12
- name: random
13
- update:
14
- canaries: 1
15
- max_in_flight: 4
16
- canary_watch_time: 10000-30000
17
- update_watch_time: 10000-30000
18
- resource_pools:
19
- - name: common
20
- network: <%= project_name %>-network
21
- size: 3
22
- stemcell:
23
- name: bosh-stemcell
24
- version: latest
25
- cloud_properties:
26
- name: random
27
- networks:
28
- - name: <%= project_name %>-network
29
- subnets:
30
- <%% (0..28).each_with_index do |i| %>
31
- - range: 10.244.0.<%%= i*4 %>/30
32
- reserved:
33
- - 10.244.0.<%%= i*4 + 1 %>
34
- static:
35
- - 10.244.0.<%%= i*4 + 2 %>
36
- cloud_properties:
37
- name: random
38
- <%% end %>
39
- <%% (29..61).each_with_index do |i| %>
40
- - range: 10.244.0.<%%= i*4 %>/30
41
- reserved:
42
- - 10.244.0.<%%= i*4 + 1 %>
43
- cloud_properties:
44
- name: random
45
- <%% end %>
46
- <%% (62..63).each_with_index do |i| %>
47
- - range: 10.244.0.<%%= i*4 %>/30
48
- reserved:
49
- - 10.244.0.<%%= i*4 + 1 %>
50
- static:
51
- - 10.244.0.<%%= i*4 + 2 %>
52
- cloud_properties:
53
- name: random
54
- <%% end %>
55
- jobs:
56
- - name: <%= project_name %>
57
- template: <%= project_name %>
58
- instances: 3
59
- resource_pool: common
60
- networks:
61
- - name: <%= project_name %>-network
62
- static_ips:
63
- - 10.244.0.6
64
- - 10.244.0.10
65
- - 10.244.0.14
66
- properties:
67
- <%= project_name %>: {}
@@ -1,65 +0,0 @@
1
- ---
2
- name: <%= project_name %>-solo
3
- director_uuid: DIRECTOR_UUID
4
- releases:
5
- - name: <%= project_name %>
6
- version: latest
7
- compilation:
8
- workers: 3
9
- network: <%= project_name %>-network
10
- reuse_compilation_vms: true
11
- cloud_properties:
12
- name: random
13
- update:
14
- canaries: 1
15
- max_in_flight: 4
16
- canary_watch_time: 10000-30000
17
- update_watch_time: 10000-30000
18
- resource_pools:
19
- - name: common
20
- network: <%= project_name %>-network
21
- size: 1
22
- stemcell:
23
- name: bosh-stemcell
24
- version: latest
25
- cloud_properties:
26
- name: random
27
- networks:
28
- - name: <%= project_name %>-network
29
- subnets:
30
- <%% (0..28).each_with_index do |i| %>
31
- - range: 10.244.0.<%%= i*4 %>/30
32
- reserved:
33
- - 10.244.0.<%%= i*4 + 1 %>
34
- static:
35
- - 10.244.0.<%%= i*4 + 2 %>
36
- cloud_properties:
37
- name: random
38
- <%% end %>
39
- <%% (29..61).each_with_index do |i| %>
40
- - range: 10.244.0.<%%= i*4 %>/30
41
- reserved:
42
- - 10.244.0.<%%= i*4 + 1 %>
43
- cloud_properties:
44
- name: random
45
- <%% end %>
46
- <%% (62..63).each_with_index do |i| %>
47
- - range: 10.244.0.<%%= i*4 %>/30
48
- reserved:
49
- - 10.244.0.<%%= i*4 + 1 %>
50
- static:
51
- - 10.244.0.<%%= i*4 + 2 %>
52
- cloud_properties:
53
- name: random
54
- <%% end %>
55
- jobs:
56
- - name: <%= project_name %>
57
- template: <%= project_name %>
58
- instances: 1
59
- resource_pool: common
60
- networks:
61
- - name: <%= project_name %>-network
62
- static_ips:
63
- - 10.244.0.6
64
- properties:
65
- <%= project_name %>: {}