blob: 6aa141a75c0b477382672411e0b8168425df70db [file] [log] [blame]
mcordbef65082017-05-24 16:05:07 -07001---
2# vars/cord-pod.yaml
3# Configures an M-CORD pod
4
5# site configuration
6site_name: mysite
7site_humanname: MySite
8deployment_type: MyDeployment
9
10xos_admin_user: xosadmin@opencord.org
11xos_admin_pass: "{{ lookup('password', 'credentials/xosadmin@opencord.org chars=ascii_letters,digits') }}"
12xos_admin_first: XOS
13xos_admin_last: Admin
14
15xos_users: []
16
17use_vtn: True
18
19xos_tosca_config_templates:
20 - openstack.yaml
21 - vtn-service.yaml
22 - fabric-service.yaml
23 - management-net.yaml
Omar Abdelkadercf794522017-07-13 19:44:06 -060024 - shared-net.yaml
25 - wan-net.yaml
26 - vsg-net.yaml
Pingping Linb3e8ded2017-07-25 14:54:24 -070027 - mcord-services.yaml
Matteo Scandolo6f64e292017-08-01 11:02:18 -070028 - xos-gui-extensions.yml
Omar Abdelkader1bd8dad2017-07-27 16:15:01 -070029 #- ng-core.yaml
mcordbef65082017-05-24 16:05:07 -070030
31xos_other_templates:
32 - fabric-network-cfg.json
33
34cord_profile_dir: "{{ ansible_user_dir + '/cord_profile' }}"
35
36xos_docker_volumes:
37 - host: "{{ cord_profile_dir }}/images"
38 container: /opt/xos/images
39
Pingping Lin3d4d8ea2017-06-15 16:24:16 -070040# GUI Config [new GUI]
41gui_project_name: "M-CORD"
42gui_background: "cord-bg.jpg" # TODO find mcord image
43
mcordbef65082017-05-24 16:05:07 -070044# GUI branding [OLD GUI to be removed]
45gui_branding_name: "MCORD"
46gui_branding_icon: "/static/mcord-logo.png"
47gui_branding_favicon: "/static/mcord-favicon.png"
48gui_branding_bg: "/static/mcord-bg.jpg"
49
50enabled_gui_extensions: []
51#enabled_gui_extensions:
52# - name: vtr
53# path: orchestration/xos_services/vtr/xos/gui
54# - name: rcord
55# path: orchestration/profiles/rcord/xos/gui
56
57# paths defined in manifest/default.xml
58xos_services:
59 - name: vtn
60 path: onos-apps/apps/vtn
61 keypair: vsg_rsa
62 synchronizer: true
63 - name: openstack
64 path: orchestration/xos_services/openstack
65 synchronizer: true
66 - name: onos
67 path: orchestration/xos_services/onos-service
68 keypair: onos_rsa
69 synchronizer: true
70 - name: fabric
71 path: orchestration/xos_services/fabric
72 synchronizer: true
Yunpeng Zhang45847142017-07-19 00:53:27 -040073 - name: vbbu
74 path: orchestration/xos_services/vbbu
75 keypair: mcord_rsa
76 synchronizer: true
77 - name: vmme
78 path: orchestration/xos_services/vmme
79 keypair: mcord_rsa
80 synchronizer: true
81 - name: vsgw
82 path: orchestration/xos_services/vsgw
83 keypair: mcord_rsa
84 synchronizer: true
Omar Abdelkaderb5863db2017-07-24 10:20:51 -070085 - name: vpgwc
86 path: orchestration/xos_services/vpgwc
87 keypair: mcord_rsa
88 synchronizer: true
Omar Abdelkader1bd8dad2017-07-27 16:15:01 -070089 - name: vhss
90 path: orchestration/xos_services/vhss
91 keypaird: mcord_rsa
92 synchronizer: true
Yunpeng Zhangecb6feb2017-08-03 18:55:07 -040093 - name: vmm
94 path: orchestration/xos_services/vmm
95 keypaird: mcord_rsa
96 synchronizer: true
97 - name: vsm
98 path: orchestration/xos_services/vsm
99 keypaird: mcord_rsa
100 synchronizer: true
mcordbef65082017-05-24 16:05:07 -0700101# needed onboarding synchronizer doesn't require service code to be present when started
102 - name: exampleservice
103 path: orchestration/xos_services/exampleservice
104 keypair: exampleservice_rsa
105 synchronizer: true
106 - name: monitoring
107 path: orchestration/xos_services/monitoring
108 keypair: monitoringservice_rsa
109 synchronizer: false
110
111xos_service_sshkeys:
112 - name: onos_rsa
113 source_path: "~/.ssh/id_rsa"
114 - name: onos_rsa.pub
115 source_path: "~/.ssh/id_rsa.pub"
116 - name: mcord_rsa
117 source_path: "~/.ssh/id_rsa"
118 - name: mcord_rsa.pub
119 source_path: "~/.ssh/id_rsa.pub"
120# needed onboarding synchronizer doesn't require service code to be present when started
121 - name: exampleservice_rsa
122 source_path: "~/.ssh/id_rsa"
123 - name: exampleservice_rsa.pub
124 source_path: "~/.ssh/id_rsa.pub"
125 - name: monitoringservice_rsa
126 source_path: "~/.ssh/id_rsa"
127 - name: monitoringservice_rsa.pub
128 source_path: "~/.ssh/id_rsa.pub"
129
130# profile_library: "mcord"
131
132# VM networks/bridges on head
133virt_nets:
134 - name: mgmtbr
135 ipv4_prefix: 192.168.122
136 head_vms: true
137
138# site domain suffix
139site_suffix: cord.lab
140
141# resolv.conf settings
142dns_search:
143 - "{{ site_suffix }}"
144
145# SSL server certificate generation
146server_certs:
147 - cn: "keystone.{{ site_suffix }}"
148 subj: "/C=US/ST=California/L=Menlo Park/O=ON.Lab/OU=Test Deployment/CN=keystone.{{ site_suffix }}"
149 altnames:
150 - "DNS:keystone.{{ site_suffix }}"
151 - "DNS:keystone"
152 - cn: "xos-core.{{ site_suffix }}"
153 subj: "/C=US/ST=California/L=Menlo Park/O=ON.Lab/OU=Test Deployment/CN=xos-core.{{ site_suffix }}"
154 altnames:
155 - "DNS:xos-core.{{ site_suffix }}"
156
157# NSD/Unbound settings
158nsd_zones:
159 - name: "{{ site_suffix }}"
160 ipv4_first_octets: 192.168.122
161 name_reverse_unbound: "168.192.in-addr.arpa"
162 soa: ns1
163 ns:
164 - { name: ns1 }
165 nodelist: head_vm_list
166 aliases:
167 - { name: "ns1" , dest: "head" }
168 - { name: "ns" , dest: "head" }
169 - { name: "apt-cache" , dest: "head" }
170
171name_on_public_interface: head
172
173# VTN network configuration
174management_network_cidr: 172.27.0.0/24
175management_network_ip: 172.27.0.1/24
176data_plane_ip: 10.168.0.253/24
177
178# CORD ONOS app version
179cord_app_version: 1.2-SNAPSHOT
180
181# If true, unbound listens on the head node's `ansible_default_ipv4` interface
182unbound_listen_on_default: True
183
184# turn this on, or override it when running the playbook with --extra-vars="on_cloudlab=True"
185on_cloudlab: False
186
187# turn this off, or override when running playbook with --extra-vars="on_maas=False"
188on_maas: True
189
190run_dist_upgrade: False
191
192maas_node_key: /etc/maas/ansible/id_rsa
193
194openstack_version: kilo
195
196juju_config_name: cord
197
198juju_config_path: /usr/local/src/juju_config.yml
199
200# Pull ONOS from local Docker registry rather than Docker Hub
201onos_docker_image: "docker-registry:5000/onosproject/onos:candidate"
202
203# Pull XOS from local Docker registry
204xos_docker_image: "docker-registry:5000/xosproject/xos:candidate"
205
206keystone_admin_password: "{{ lookup('password', 'credentials/cord_keystone_admin chars=ascii_letters,digits') }}"
207
208deployment_flavors:
209 - m1.small
210 - m1.medium
211 - m1.large
212 - m1.xlarge
213
214charm_versions:
215 ceilometer: "cs:trusty/ceilometer-17"
216 ceilometer-agent: "cs:trusty/ceilometer-agent-13"
217 glance: "cs:trusty/glance-28"
218 keystone: "cs:trusty/keystone-33"
219 mongodb: "cs:trusty/mongodb-33"
220 percona-cluster: "cs:trusty/percona-cluster-31"
221 nagios: "cs:trusty/nagios-10"
222 neutron-api: "cs:~cordteam/trusty/neutron-api-5"
223 nova-cloud-controller: "cs:trusty/nova-cloud-controller-64"
224 nova-compute: "cs:~cordteam/trusty/nova-compute-2"
225 nrpe: "cs:trusty/nrpe-4"
226 ntp: "cs:trusty/ntp-14"
227 openstack-dashboard: "cs:trusty/openstack-dashboard-19"
228 rabbitmq-server: "cs:trusty/rabbitmq-server-42"
229
230head_vm_list: []
231
232head_lxd_list:
233 - name: "juju-1"
234 service: "juju"
235 aliases:
236 - "juju"
237 ipv4_last_octet: 10
238
239 - name: "ceilometer-1"
240 service: "ceilometer"
241 aliases:
242 - "ceilometer"
243 ipv4_last_octet: 20
244 forwarded_ports:
245 - { ext: 8777, int: 8777 }
246
247 - name: "glance-1"
248 service: "glance"
249 aliases:
250 - "glance"
251 ipv4_last_octet: 30
252 forwarded_ports:
253 - { ext: 9292, int: 9292 }
254
255 - name: "keystone-1"
256 service: "keystone"
257 aliases:
258 - "keystone"
259 ipv4_last_octet: 40
260 forwarded_ports:
261 - { ext: 35357, int: 35357 }
262 - { ext: 4990, int: 4990 }
263 - { ext: 5000, int: 5000 }
264
265 - name: "percona-cluster-1"
266 service: "percona-cluster"
267 aliases:
268 - "percona-cluster"
269 ipv4_last_octet: 50
270
271 - name: "nagios-1"
272 service: "nagios"
273 aliases:
274 - "nagios"
275 ipv4_last_octet: 60
276 forwarded_ports:
277 - { ext: 3128, int: 80 }
278
279 - name: "neutron-api-1"
280 service: "neutron-api"
281 aliases:
282 - "neutron-api"
283 ipv4_last_octet: 70
284 forwarded_ports:
285 - { ext: 9696, int: 9696 }
286
287 - name: "nova-cloud-controller-1"
288 service: "nova-cloud-controller"
289 aliases:
290 - "nova-cloud-controller"
291 ipv4_last_octet: 80
292 forwarded_ports:
293 - { ext: 8774, int: 8774 }
294
295 - name: "openstack-dashboard-1"
296 service: "openstack-dashboard"
297 aliases:
298 - "openstack-dashboard"
299 ipv4_last_octet: 90
300 forwarded_ports:
301 - { ext: 8080, int: 80 }
302
303 - name: "rabbitmq-server-1"
304 service: "rabbitmq-server"
305 aliases:
306 - "rabbitmq-server"
307 ipv4_last_octet: 100
308
309 - name: "mongodb-1"
310 service: "mongodb"
311 aliases:
312 - "mongodb"
313 ipv4_last_octet: 110
314
315lxd_service_list:
316 - ceilometer
317 - glance
318 - keystone
319 - mongodb
320 - nagios
321 - neutron-api
322 - nova-cloud-controller
323 - openstack-dashboard
324 - percona-cluster
325 - rabbitmq-server
326
327standalone_service_list:
328 - ntp
329 - nrpe
330 - ceilometer-agent
331
332
333service_relations:
334 - name: keystone
335 relations: [ "percona-cluster", "nrpe", ]
336
337 - name: nova-cloud-controller
338 relations: [ "percona-cluster", "rabbitmq-server", "glance", "keystone", "nrpe", ]
339
340 - name: glance
341 relations: [ "percona-cluster", "keystone", "nrpe", ]
342
343 - name: neutron-api
344 relations: [ "keystone", "percona-cluster", "rabbitmq-server", "nova-cloud-controller", "nrpe", ]
345
346 - name: openstack-dashboard
347 relations: [ "keystone", "nrpe", ]
348
349 - name: nagios
350 relations: [ "nrpe", ]
351
352 - name: "percona-cluster:juju-info"
353 relations: [ "nrpe:general-info", ]
354
355 - name: rabbitmq-server
356 relations: [ "nrpe", ]
357
358 - name: ceilometer
359 relations: [ "mongodb", "rabbitmq-server", "nagios", "nrpe", ]
360
361 - name: "ceilometer:identity-service"
362 relations: [ "keystone:identity-service", ]
363
364 - name: "ceilometer:ceilometer-service"
365 relations: [ "ceilometer-agent:ceilometer-service", ]
366
367
368compute_relations:
369 - name: nova-compute
370 relations: [ "ceilometer-agent", "glance", "nova-cloud-controller", "nagios", "nrpe", ]
371
372 - name: "nova-compute:shared-db"
373 relations: [ "percona-cluster:shared-db", ]
374
375 - name: "nova-compute:amqp"
376 relations: [ "rabbitmq-server:amqp", ]
377
378 - name: ntp
379 relations: [ "nova-compute", ]
380
381
382xos_images:
383 - name: "trusty-server-multi-nic"
384 url: "http://www.vicci.org/opencloud/trusty-server-cloudimg-amd64-disk1.img.20170201"
385 checksum: "sha256:ebf007ba3ec1043b7cd011fc6668e2a1d1d4c69c41071e8513ab355df7a057cb"
386
Pingping Line3b18f42017-07-11 15:03:54 -0700387 # How to add local image and dynamically load it into existing XOS
388 # add your private image such as mcord-local-image-name.img to /opt/iamges/ on 'corddev' VM inside cord in a box
389 # uncomment the code blow,and run those two commands:
390 # on corddev VM: vagrant@corddev:/cord/build$ ./gradlew -PdeployConfig=config/mcord_in_a_box.yml PIcreateProfile
391 # on prod VM: compute-node-refresh
392
393 #- name: "mcord-local-image-name"
394 # url: "file://localhost/opt/images/mcord-local-image-name.img"
395 # checksum: "sha256:ebf007ba3ec1043b7cd011fc6668e2a1d1d4c69c41071e8513ab355df7a057cb"
396
mcordbef65082017-05-24 16:05:07 -0700397 - name: "vsg-1.1"
398 url: "http://www.vicci.org/cord/vsg-1.1.img"
399 checksum: "sha256:16b0beb6778aed0f5feecb05f8d5750e6c262f98e6011e99ddadf7d46a177b6f"
400
401 - name: "ceilometer-trusty-server-multi-nic"
402 url: "http://www.vicci.org/cord/ceilometer-trusty-server-multi-nic.compressed.qcow2"
403 checksum: "sha256:b77ef8d692b640568dea13df99fe1dfcb1f4bb4ac05408db9ff77399b34f754f"
404
405 - name: "ceilometer-service-trusty-server-multi-nic"
406 url: "http://www.vicci.org/cord/ceilometer-service-trusty-server-multi-nic.compressed.qcow2.20170131"
407 checksum: "sha256:f0341e283f0f2cb8f70cd1a6347e0081c9c8492ef34eb6397c657ef824800d4f"