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