Compare commits
	
		
			27 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | b75fab3e81 | ||
|  | 25e2467edc | ||
|  | f011919666 | ||
|  | 6cbebf4c91 | ||
|  | 4309956de1 | ||
|  | 51e2bf3544 | ||
|  | 375d5fa4c9 | ||
|  | 4d95b0ddbd | ||
|  | 981b1eff63 | ||
|  | 31e3506d30 | ||
|  | 03a619823d | ||
|  | 0c605af3ae | ||
|  | ca6adb44f6 | ||
|  | c0d50d7444 | ||
|  | f8a3179b74 | ||
|  | 84b901c8b3 | ||
|  | e3f3d5d3b7 | ||
|  | 68ac7a0a6d | ||
|  | 8da96590ac | ||
|  | fea7aaaff6 | ||
|  | fb2bdfe543 | ||
|  | 3347fa7c25 | ||
|  | f776756205 | ||
|  | 59233d8019 | ||
|  | 35551f69c1 | ||
|  | 85dcae1baf | ||
|  | 99eba86794 | 
| @@ -1,2 +1,6 @@ | |||||||
| [defaults] | [defaults] | ||||||
| hostfile = hosts | inventory = hosts | ||||||
|  | stdout_callback = debug | ||||||
|  | vault_password_file = .vault_pass.txt | ||||||
|  | forks = 20 | ||||||
|  | host_key_checking = false | ||||||
|   | |||||||
| @@ -1,7 +1,13 @@ | |||||||
| --- | --- | ||||||
| - hosts: all | - hosts: all | ||||||
|   name: Dummy to gather facts |   name: Dummy to gather facts | ||||||
|   tasks: [] |   tasks: | ||||||
|  |     - name: gather facts even if hosts are excluded. | ||||||
|  |       setup: | ||||||
|  |       delegate_to: "{{item}}" | ||||||
|  |       delegate_facts: True | ||||||
|  |       loop: "{{groups['all']}}" | ||||||
|  |  | ||||||
|  |  | ||||||
| - hosts: cinder-controller | - hosts: cinder-controller | ||||||
|   become: True |   become: True | ||||||
|   | |||||||
| @@ -1,5 +1,11 @@ | |||||||
| --- | --- | ||||||
| - hosts: all | - hosts: all | ||||||
|   become: True |   become: True | ||||||
|  |   vars_prompt: | ||||||
|  |     - name: "docker_user" | ||||||
|  |       prompt: "What is your p number?" | ||||||
|  |     - name: "docker_pass" | ||||||
|  |       prompt: "What is your password?" | ||||||
|  |       private: yes | ||||||
|   roles: |   roles: | ||||||
|       - common |       - common | ||||||
|   | |||||||
							
								
								
									
										26
									
								
								gcc-site.yml
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								gcc-site.yml
									
									
									
									
									
								
							| @@ -1,14 +1,14 @@ | |||||||
| --- | --- | ||||||
| - include: common.yml | - import_tasks: common.yml | ||||||
| - include: rabbitmq.yml | - import_tasks: rabbitmq.yml | ||||||
| - include: memcached.yml | - import_tasks: memcached.yml | ||||||
| - include: mariadb.yml | - import_tasks: mariadb.yml | ||||||
| - include: keystone.yml | - import_tasks: keystone.yml | ||||||
| - include: glance-controller.yml | - import_tasks: glance-controller.yml | ||||||
| - include: nova-controller.yml | - import_tasks: nova-controller.yml | ||||||
| - include: neutron-controller.yml | - import_tasks: neutron-controller.yml | ||||||
| - include: cinder-controller.yml | - import_tasks: cinder-controller.yml | ||||||
| - include: cinder-storage.yml | - import_tasks: cinder-storage.yml | ||||||
| - include: nova-compute.yml | - import_tasks: nova-compute.yml | ||||||
| - include: horizon.yml | - import_tasks: horizon.yml | ||||||
| - include: gcc-post-install.yml | - import_tasks: gcc-post-install.yml | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								group_vars/horizon.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								group_vars/horizon.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | |||||||
|  | --- | ||||||
|  | security_fail2ban_enabled: false | ||||||
| @@ -6,4 +6,5 @@ | |||||||
| - hosts: horizon | - hosts: horizon | ||||||
|   become: True |   become: True | ||||||
|   roles: |   roles: | ||||||
|  |      - geerlingguy.security | ||||||
|      - horizon |      - horizon | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								host_vars/openstack03
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								host_vars/openstack03
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | |||||||
|  | --- | ||||||
|  | listen_ip: '172.23.40.243' | ||||||
							
								
								
									
										2
									
								
								host_vars/openstack04
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								host_vars/openstack04
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | |||||||
|  | --- | ||||||
|  | listen_ip: '172.23.40.253' | ||||||
							
								
								
									
										37
									
								
								merlin
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								merlin
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,37 @@ | |||||||
|  | [nova-compute] | ||||||
|  | merlin-managementnode002 physical_interface_mappings=provider:eno3 | ||||||
|  | merlin-managementnode003 physical_interface_mappings=provider:eno3 | ||||||
|  | merlin-node001 physical_interface_mappings=provider:eno3 | ||||||
|  | merlin-node003 physical_interface_mappings=provider:eno3 | ||||||
|  | merlin-node004 physical_interface_mappings=provider:eno3 | ||||||
|  |  | ||||||
|  | [databases] | ||||||
|  | merlin-managementnode001 | ||||||
|  | merlin-managementnode002 | ||||||
|  | merlin-managementnode003 | ||||||
|  |  | ||||||
|  | [rabbitmq] | ||||||
|  | merlin-managementnode001 | ||||||
|  | merlin-managementnode002 | ||||||
|  | merlin-managementnode003 | ||||||
|  |  | ||||||
|  | [horizon] | ||||||
|  | merlin-managementnode001 | ||||||
|  |  | ||||||
|  | [memcached] | ||||||
|  | merlin-managementnode001 | ||||||
|  |  | ||||||
|  | [nova-controller] | ||||||
|  | merlin-managementnode001 | ||||||
|  |  | ||||||
|  | [keystone] | ||||||
|  | merlin-managementnode001 | ||||||
|  |  | ||||||
|  | [neutron-controller] | ||||||
|  | merlin-managementnode001 physical_interface_mappings=provider:eno3 | ||||||
|  |  | ||||||
|  | [heat] | ||||||
|  | merlin-managementnode001 | ||||||
|  |  | ||||||
|  | [glance-controller] | ||||||
|  | merlin-managementnode001 | ||||||
| @@ -5,7 +5,5 @@ | |||||||
|  |  | ||||||
| - hosts: neutron-controller | - hosts: neutron-controller | ||||||
|   become: True |   become: True | ||||||
|   vars_files: |  | ||||||
|     - settings.yml |  | ||||||
|   roles: |   roles: | ||||||
|      - neutron-controller |      - neutron-controller | ||||||
|   | |||||||
| @@ -5,7 +5,5 @@ | |||||||
|  |  | ||||||
| - hosts: nova-compute | - hosts: nova-compute | ||||||
|   become: True |   become: True | ||||||
|   vars_files: |  | ||||||
|     - settings.yml |  | ||||||
|   roles: |   roles: | ||||||
|      - nova-compute |      - nova-compute | ||||||
|   | |||||||
							
								
								
									
										21
									
								
								nuke.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								nuke.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | |||||||
|  | --- | ||||||
|  | # This playbook will reset the instalation to facilitate a new installation. | ||||||
|  | # All data is lost! | ||||||
|  | - hosts: all | ||||||
|  |   become: True | ||||||
|  |   name: Dummy to gather facts | ||||||
|  |   tasks: | ||||||
|  |     - name: Stop docker service | ||||||
|  |       shell: "systemctl stop docker" | ||||||
|  |     - name: Verify docker is stopped. | ||||||
|  |       systemd: | ||||||
|  |         name: docker | ||||||
|  |         state: stopped | ||||||
|  |     - name: remove volumes | ||||||
|  |       shell: "rm -rf /srv" | ||||||
|  |  | ||||||
|  | - hosts: cinder-storage | ||||||
|  |   become: True | ||||||
|  |   tasks: | ||||||
|  |     - name: wipe cinder storage. | ||||||
|  |       shell: "dd if=/dev/zero of={{ storage_volume }} bs=1M count=1 && sync" | ||||||
| @@ -26,10 +26,14 @@ openstack03 | |||||||
| openstack03 | openstack03 | ||||||
|  |  | ||||||
| [cinder-storage] | [cinder-storage] | ||||||
|  | openstack01 storage_volume=/dev/sdc3 | ||||||
|  | openstack02 storage_volume=/dev/sda5 | ||||||
| openstack03 storage_volume=/dev/sdb1 | openstack03 storage_volume=/dev/sdb1 | ||||||
|  | openstack04 storage_volume=/dev/sdb1 | ||||||
|  |  | ||||||
| [nova-compute] | [nova-compute] | ||||||
|  | openstack01 physical_interface_mappings=provider:bond0 | ||||||
|  | openstack02 physical_interface_mappings=provider:enp34s0f1 | ||||||
| openstack03 physical_interface_mappings=provider:enp4s0f0 | openstack03 physical_interface_mappings=provider:enp4s0f0 | ||||||
|  | openstack04 physical_interface_mappings=provider:eno1 | ||||||
|  |  | ||||||
| [all:vars] |  | ||||||
| listen_ip=172.23.40.243 |  | ||||||
|   | |||||||
| @@ -20,20 +20,7 @@ | |||||||
|             openstack subnet create --network provider |             openstack subnet create --network provider | ||||||
|             --allocation-pool start={{ allocation_pool['start'] }},end={{ allocation_pool['end'] }} |             --allocation-pool start={{ allocation_pool['start'] }},end={{ allocation_pool['end'] }} | ||||||
|             --dns-nameserver {{ dns_nameserver }} --gateway {{ gateway }} --subnet-range {{ subnet_range }} providersub |             --dns-nameserver {{ dns_nameserver }} --gateway {{ gateway }} --subnet-range {{ subnet_range }} providersub | ||||||
|       when: "{{ configure_networks }}" == True |  | ||||||
|  |  | ||||||
|  |  | ||||||
| - hosts: keystone |  | ||||||
|   become: True |  | ||||||
|   vars_files: |  | ||||||
|     - settings.yml |  | ||||||
|   tasks: |  | ||||||
|     - name: copy public key |  | ||||||
|       copy: |  | ||||||
|         content: "{{ rsa_pub }}" |  | ||||||
|         dest: /srv/keystone/root/id_rsa.pub |  | ||||||
|     - name: post install configuration |  | ||||||
|       command: docker exec -i keystone.service bash -c "source /root/admin-openrc.sh && {{ item }}" |  | ||||||
|       with_items: |  | ||||||
|         - openstack flavor create --id 0 --vcpus 1 --ram 64 --disk 1 m1.nano |         - openstack flavor create --id 0 --vcpus 1 --ram 64 --disk 1 m1.nano | ||||||
|         - openstack keypair create --public-key /root/id_rsa.pub adminkey |         - openstack keypair create --public-key /root/id_rsa.pub adminkey | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -20,7 +20,9 @@ | |||||||
|         -e "OS_PASSWORD={{ secrets['OS_PASSWORD'] }}" |         -e "OS_PASSWORD={{ secrets['OS_PASSWORD'] }}" | ||||||
|         -e "RABBIT_HOST={{ listen_ip | default(hostvars[groups['rabbitmq'][0]]['ansible_default_ipv4']['address']) }}" |         -e "RABBIT_HOST={{ listen_ip | default(hostvars[groups['rabbitmq'][0]]['ansible_default_ipv4']['address']) }}" | ||||||
|         -e "RABBIT_PASSWORD={{ secrets['RABBIT_PASSWORD'] }}" |         -e "RABBIT_PASSWORD={{ secrets['RABBIT_PASSWORD'] }}" | ||||||
|  |         -e "AVAILABILITY_ZONE={{ ansible_nodename }}" | ||||||
|         -e "RABBIT_USER=openstack" |         -e "RABBIT_USER=openstack" | ||||||
|  |         -e "CINDER_STORAGE_VOLUME={{ storage_volume }}" | ||||||
|   tags: vars |   tags: vars | ||||||
|  |  | ||||||
| - name: pull docker image | - name: pull docker image | ||||||
| @@ -43,7 +45,7 @@ | |||||||
|              --privileged |              --privileged | ||||||
|              {{ env_vars }} |              {{ env_vars }} | ||||||
|              -v /srv/cinder-storage/root:/root \ |              -v /srv/cinder-storage/root:/root \ | ||||||
|              -v "{{ storage_volume }}":/dev/cinder_storage_volume \ |              -v /dev:/dev \ | ||||||
|              {{ docker_image }} /etc/bootstrap.sh |              {{ docker_image }} /etc/bootstrap.sh | ||||||
|   tags: bootstrap |   tags: bootstrap | ||||||
|  |  | ||||||
|   | |||||||
| @@ -11,13 +11,10 @@ ExecStartPre=-/usr/bin/docker rm %n | |||||||
| ExecStart=/usr/bin/docker run --name %n \ | ExecStart=/usr/bin/docker run --name %n \ | ||||||
|   --privileged \ |   --privileged \ | ||||||
|   {{ env_vars | replace('\n', '') }} \ |   {{ env_vars | replace('\n', '') }} \ | ||||||
|   -v "/dev/cinder-volumes/":/dev/cinder-volumes \ |  | ||||||
|   -v /srv/cinder-storage/root:/root \ |   -v /srv/cinder-storage/root:/root \ | ||||||
|   -v "{{ storage_volume }}":/dev/cinder_storage_volume \ |   -v "/dev":/dev \ | ||||||
|   -v "/dev/lvm":/dev/lvm \ |   -v "/var/lib/cinder:/var/lib/cinder" \ | ||||||
|   -v "/srv/cinder-storage/volumes/:/var/lib/cinder/volumes/" \ |   --network=host \ | ||||||
|   -p 8777:8776 \ |  | ||||||
|   -p 3260:3260 \ |  | ||||||
|   {{ docker_image }} |   {{ docker_image }} | ||||||
|  |  | ||||||
| [Install] | [Install] | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
| - name: Passwordless sudo for admins | - name: Passwordless sudo for admins | ||||||
|   lineinfile: dest=/etc/sudoers line="%admin  ALL=(ALL:ALL) NOPASSWD:ALL" |   lineinfile: dest=/etc/sudoers line="%admin  ALL=(ALL:ALL) NOPASSWD:ALL" | ||||||
|  |  | ||||||
| - include: users.yml | - import_tasks: users.yml | ||||||
|  |  | ||||||
| - name: common | install packages | - name: common | install packages | ||||||
|   apt: pkg={{ item }} state=latest update_cache=yes |   apt: pkg={{ item }} state=latest update_cache=yes | ||||||
| @@ -26,4 +26,11 @@ | |||||||
|     owner: root |     owner: root | ||||||
|     group: root |     group: root | ||||||
|  |  | ||||||
| - include: docker.yml |     #- import_tasks: docker.yml | ||||||
|  |  | ||||||
|  |  | ||||||
|  | - name: Log into DockerHub | ||||||
|  |   docker_login: | ||||||
|  |     registry: registry.webhosting.rug.nl | ||||||
|  |     username: "{{ docker_user }}" | ||||||
|  |     password: "{{ docker_pass }}" | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| [Unit] | [Unit] | ||||||
| Description=Openstack Glance Container | Description=Openstack Horizon Container | ||||||
| After=docker.service | After=docker.service | ||||||
| Requires=docker.service | Requires=docker.service | ||||||
|  |  | ||||||
|   | |||||||
| @@ -52,7 +52,7 @@ | |||||||
|   delay: 3 |   delay: 3 | ||||||
|   ignore_errors: yes |   ignore_errors: yes | ||||||
|  |  | ||||||
| - name: keystone manage commands to setup db | - name: keystone manage commands to setup db_sync | ||||||
|   command: > |   command: > | ||||||
|              /usr/bin/docker run --rm |              /usr/bin/docker run --rm | ||||||
|              --add-host=mariadb:{{ listen_ip | default(hostvars[groups['databases'][0]]['ansible_default_ipv4']['address']) }} |              --add-host=mariadb:{{ listen_ip | default(hostvars[groups['databases'][0]]['ansible_default_ipv4']['address']) }} | ||||||
| @@ -69,6 +69,11 @@ | |||||||
|                     --bootstrap-internal-url http://{{ listen_ip | default(hostvars[groups['keystone'][0]]['ansible_default_ipv4']['address']) }}:35357/v3/ |                     --bootstrap-internal-url http://{{ listen_ip | default(hostvars[groups['keystone'][0]]['ansible_default_ipv4']['address']) }}:35357/v3/ | ||||||
|                     --bootstrap-public-url http://{{ listen_ip | default(hostvars[groups['keystone'][0]]['ansible_default_ipv4']['address']) }}:5000/v3/ |                     --bootstrap-public-url http://{{ listen_ip | default(hostvars[groups['keystone'][0]]['ansible_default_ipv4']['address']) }}:5000/v3/ | ||||||
|                     --bootstrap-region-id RegionOne |                     --bootstrap-region-id RegionOne | ||||||
|  |   # sometimes the initial connect fails. | ||||||
|  |   # Retry until it succeeds. | ||||||
|  |   retries: 7 | ||||||
|  |   delay: 3 | ||||||
|  |   ignore_errors: yes | ||||||
|  |  | ||||||
| - name: make sure service is started | - name: make sure service is started | ||||||
|   systemd: |   systemd: | ||||||
| @@ -85,12 +90,18 @@ | |||||||
|              -e "OS_AUTH_URL=http://${KEYSTONE_HOST}:35357/v3" |              -e "OS_AUTH_URL=http://${KEYSTONE_HOST}:35357/v3" | ||||||
|              -e "OS_PASSWORD={{ secrets['OS_PASSWORD'] }}" |              -e "OS_PASSWORD={{ secrets['OS_PASSWORD'] }}" | ||||||
|              {{ docker_image }} bash /etc/bootstrap.sh |              {{ docker_image }} bash /etc/bootstrap.sh | ||||||
|  |   register: result | ||||||
|  |   retries: 7 | ||||||
|  |   delay: 3 | ||||||
|  |  | ||||||
|  | - name: install openstack repo host key. | ||||||
|  |   command: apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 5EDB1B62EC4926EA | ||||||
|  |   tags: openstackclient | ||||||
|  |  | ||||||
| - name: install openstack repo on host. | - name: install openstack repo on host. | ||||||
|   command: > |   apt_repository: | ||||||
|       echo "deb http://ubuntu-cloud.archive.canonical.com/ubuntu xenial-updates/ocata main" > /etc/apt/sources.list.d/ocata.list && |       repo: "deb http://ubuntu-cloud.archive.canonical.com/ubuntu xenial-updates/ocata main" | ||||||
|       apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 5EDB1B62EC4926EA |       filename: ocata | ||||||
|   tags: openstackclient |   tags: openstackclient | ||||||
|  |  | ||||||
| - name: install openstack client for management | - name: install openstack client for management | ||||||
|   | |||||||
| @@ -1,3 +1,5 @@ | |||||||
|  | export OS_PROJECT_DOMAIN_NAME=Default | ||||||
|  | export OS_USER_DOMAIN_NAME=Default | ||||||
| export OS_TENANT_NAME=admin | export OS_TENANT_NAME=admin | ||||||
| export OS_USERNAME=admin | export OS_USERNAME=admin | ||||||
| export OS_PASSWORD={{ hostvars[groups['keystone'][0]]['OS_PASSWORD'] }} | export OS_PASSWORD={{ hostvars[groups['keystone'][0]]['OS_PASSWORD'] }} | ||||||
|   | |||||||
| @@ -21,12 +21,14 @@ | |||||||
|     dest: /srv/mariadb/etc/mysql/conf.d/my.cnf |     dest: /srv/mariadb/etc/mysql/conf.d/my.cnf | ||||||
|     mode: 660 |     mode: 660 | ||||||
|  |  | ||||||
| - name: Set galara.cnf on node if we have at least three nodes. | - name: > | ||||||
|  |         Set galara.cnf on node if we have at least three nodes. | ||||||
|  |         And we're part of the cluster. | ||||||
|   template: |   template: | ||||||
|     src: files/galera.cnf |     src: files/galera.cnf | ||||||
|     dest: /srv/mariadb/etc/mysql/conf.d/galera.cnf |     dest: /srv/mariadb/etc/mysql/conf.d/galera.cnf | ||||||
|     mode: 660 |     mode: 660 | ||||||
|   when: groups['databases'] | length >= 3 |   when: "'databases' in group_names and groups['databases'] | length >= 3" | ||||||
|  |  | ||||||
|   # This mimics galera_new_cluster.sh |   # This mimics galera_new_cluster.sh | ||||||
| - name: Initialize a new cluster. | - name: Initialize a new cluster. | ||||||
| @@ -47,7 +49,8 @@ | |||||||
|         name: mysql.service |         name: mysql.service | ||||||
|         state: started |         state: started | ||||||
|  |  | ||||||
|   when: groups['databases'] | length >= 3 and ansible_hostname == hostname_node0 |   when: "'databases' in group_names and groups['databases'] \ | ||||||
|  |          | length >= 3 and ansible_hostname == hostname_node0" | ||||||
|  |  | ||||||
| - name: install service file. | - name: install service file. | ||||||
|   block: |   block: | ||||||
| @@ -61,12 +64,22 @@ | |||||||
|         group: root |         group: root | ||||||
|  |  | ||||||
| - name: Give the master node some time to initialize the cluster. | - name: Give the master node some time to initialize the cluster. | ||||||
|   command: bash -c "sleep 60 && systemctl daemon-reload" |   command: bash -c "sleep 60" | ||||||
|  |   when: "'databases' in group_names and groups['databases'] \ | ||||||
|  |          | length >= 3" | ||||||
|  |  | ||||||
|  | - name: Daemon reload (the implicit doesn't work) | ||||||
|  |   command: bash -c "systemctl daemon-reload" | ||||||
|  |  | ||||||
| - name: make sure service is started | - name: make sure service is started | ||||||
|   systemd: |   systemd: | ||||||
|     name: mysql.service |     name: mysql.service | ||||||
|     state: started |     state: started | ||||||
|  |     daemon_reload: yes | ||||||
|  |  | ||||||
| - name: start service at boot. | - name: start service at boot. | ||||||
|   command: systemctl reenable mysql.service |   command: systemctl reenable mysql.service | ||||||
|  |  | ||||||
|  | - name: Give the cluster some time to initialize replication. | ||||||
|  |   command: bash -c "sleep 60 && systemctl daemon-reload" | ||||||
|  |   when: "'databases' in group_names and groups['databases'] | length >= 3" | ||||||
|   | |||||||
| @@ -16,7 +16,6 @@ | |||||||
|  |  | ||||||
| - set_fact: | - set_fact: | ||||||
|     env_vars: > |     env_vars: > | ||||||
|         -e "GLOBAL_PHYSNET_MTU={{ global_physnet_mtu }}" |  | ||||||
|         -e "KEYSTONE_HOST={{ listen_ip | default(hostvars[groups['keystone'][0]]['ansible_default_ipv4']['address']) }}" |         -e "KEYSTONE_HOST={{ listen_ip | default(hostvars[groups['keystone'][0]]['ansible_default_ipv4']['address']) }}" | ||||||
|         -e "MEMCACHED_HOST={{ listen_ip | default(hostvars[groups['memcached'][0]]['ansible_default_ipv4']['address']) }}" |         -e "MEMCACHED_HOST={{ listen_ip | default(hostvars[groups['memcached'][0]]['ansible_default_ipv4']['address']) }}" | ||||||
|         -e "METADATA_SECRET={{ secrets['METADATA_SECRET'] }}" |         -e "METADATA_SECRET={{ secrets['METADATA_SECRET'] }}" | ||||||
|   | |||||||
| @@ -10,8 +10,6 @@ ExecStartPre=-/usr/bin/docker kill %n | |||||||
| ExecStartPre=-/usr/bin/docker rm %n | ExecStartPre=-/usr/bin/docker rm %n | ||||||
| ExecStart=/usr/bin/docker run --name %n \ | ExecStart=/usr/bin/docker run --name %n \ | ||||||
|     -e "GLANCE_CONTROLLER_HOST={{ hostvars[groups['glance-controller'][0]]['listen_ip'] | default(hostvars[groups['glance-controller'][0]]['ansible_default_ipv4']['address']) }}" \ |     -e "GLANCE_CONTROLLER_HOST={{ hostvars[groups['glance-controller'][0]]['listen_ip'] | default(hostvars[groups['glance-controller'][0]]['ansible_default_ipv4']['address']) }}" \ | ||||||
|     -e "GLOBAL_PHYSNET_MTU={{ global_physnet_mtu }}" \ |  | ||||||
|     -e "GLOBAL_PHYSNET_MTU={{ global_physnet_mtu }}" \ |  | ||||||
|     -e "KEYSTONE_HOST={{ hostvars[groups['keystone'][0]]['listen_ip'] | default(hostvars[groups['keystone'][0]]['ansible_default_ipv4']['address']) }}" \ |     -e "KEYSTONE_HOST={{ hostvars[groups['keystone'][0]]['listen_ip'] | default(hostvars[groups['keystone'][0]]['ansible_default_ipv4']['address']) }}" \ | ||||||
|     -e "METADATA_SECRET={{ secrets['METADATA_SECRET'] }}" \ |     -e "METADATA_SECRET={{ secrets['METADATA_SECRET'] }}" \ | ||||||
|     -e "MEMCACHED_HOST={{ hostvars[groups['memcached'][0]]['listen_ip'] | default(hostvars[groups['memcached'][0]]['ansible_default_ipv4']['address']) }}" \ |     -e "MEMCACHED_HOST={{ hostvars[groups['memcached'][0]]['listen_ip'] | default(hostvars[groups['memcached'][0]]['ansible_default_ipv4']['address']) }}" \ | ||||||
| @@ -33,6 +31,7 @@ ExecStart=/usr/bin/docker run --name %n \ | |||||||
|     -e "RABBIT_HOST={{ hostvars[groups['rabbitmq'][0]]['listen_ip'] | default(hostvars[groups['rabbitmq'][0]]['ansible_default_ipv4']['address']) }}" \ |     -e "RABBIT_HOST={{ hostvars[groups['rabbitmq'][0]]['listen_ip'] | default(hostvars[groups['rabbitmq'][0]]['ansible_default_ipv4']['address']) }}" \ | ||||||
|     -e "RABBIT_PASSWORD={{ secrets['RABBIT_PASSWORD'] }}" \ |     -e "RABBIT_PASSWORD={{ secrets['RABBIT_PASSWORD'] }}" \ | ||||||
|     -e "RABBIT_USER=openstack" \ |     -e "RABBIT_USER=openstack" \ | ||||||
|  |     -e "AVAILABILITY_ZONE={{ ansible_nodename }}" \ | ||||||
|     --add-host=keystone:{{ hostvars[groups['keystone'][0]]['listen_ip'] | default(hostvars[groups['keystone'][0]]['ansible_default_ipv4']['address']) }} \ |     --add-host=keystone:{{ hostvars[groups['keystone'][0]]['listen_ip'] | default(hostvars[groups['keystone'][0]]['ansible_default_ipv4']['address']) }} \ | ||||||
|     --add-host=mariadb:{{ hostvars[groups['databases'][0]]['listen_ip'] | default(hostvars[groups['databases'][0]]['ansible_default_ipv4']['address']) }} \ |     --add-host=mariadb:{{ hostvars[groups['databases'][0]]['listen_ip'] | default(hostvars[groups['databases'][0]]['ansible_default_ipv4']['address']) }} \ | ||||||
|     --privileged \ |     --privileged \ | ||||||
|   | |||||||
							
								
								
									
										60
									
								
								secrets.yml
									
									
									
									
									
								
							
							
						
						
									
										60
									
								
								secrets.yml
									
									
									
									
									
								
							| @@ -1,30 +1,32 @@ | |||||||
| $ANSIBLE_VAULT;1.1;AES256 | $ANSIBLE_VAULT;1.1;AES256 | ||||||
| 35643437313834633532373265366630663035336231306639623561613765386332663334343237 | 32313865346461323861313234623330633830663561353636396161643566353733393931303232 | ||||||
| 3339363162303463353437326331656532336138373066620a623137643762383532376361353364 | 3134353364393034626564333866383065633162383561390a656463303464616434303435303037 | ||||||
| 37646236386466353636396535376463333133323664316634663466663164303063383830653039 | 63313232373630616136626464373464646535353030396136656361343162666165366566383737 | ||||||
| 3535666361303562630a316137376531636537383138663662373865383431343035646539356137 | 6133326539393432390a386162393639636137326532393939633665326637373461663766656565 | ||||||
| 38323866643831353537366630363333663865383261633938346664633362343661343839383766 | 36636661653939373134313165383261353832373362613533366431626330313831643836363932 | ||||||
| 66363733356333303334323136376136353738376362376231353338343763663131363731343639 | 38623937663335646134323130636539333335636265313564323032623065393031343235633832 | ||||||
| 61383138626235633663666430383964616239363035663663646133636434363032626633663865 | 33336138653336633932383133366566656464356331306265663662356166613135663234326434 | ||||||
| 30663732646630393163653461626435333463396463333236313930346461626364626166386365 | 64343765366439303766613062363830346238376435366138323662366463353634623937376663 | ||||||
| 66323736316230376165666366363136666533376335316132343361393532616536383965363339 | 39313263613764623533323562333932656564346462333961663538353366313065343263383431 | ||||||
| 30376362356665633630393561653532613139366236663961643864383738353430666562623730 | 39643734353632336134663965343062373933656461393264323938303261316563313962343837 | ||||||
| 34663166393665653265663836623731386235633062306562373935633737363639383336303539 | 66623562333031646633643734383439386130653033343962633930613031313433633033383561 | ||||||
| 37663763623664623038316438356138363134646230643261646262353163333430616462393866 | 65366230663263346661343339636537336332323266623230646534323563373934356332663136 | ||||||
| 31666233636233356464633436626637313633623736343264613037353432386131393964386663 | 30626231623534616562323033333437353239306538653835623931363164383536336562336136 | ||||||
| 36353236613662633764366437306461316138366461653731373436613039346663663536653362 | 30666265366536313436646535383632626137613831633132666666653830383566323532306332 | ||||||
| 38656636303935626563303732666261373665303035333661643865393166653330646336393961 | 34353534336331653330663137323936303337306134333036633932363664643864333534316438 | ||||||
| 31646539396131626464313733383638656438613530663166393035343630353764313232323432 | 31623062303137376637353061643838383831663561663436663130663064323665316261316531 | ||||||
| 34386334666231323261343765623636313032373835396332623037613866613636393038653266 | 32616533333165636130623334373130316339326538343330646366383933353137623631323530 | ||||||
| 36336531356534633933383432646663663364376130386239613836336263623161326563346661 | 39653437343432383161323661643931346664663265326664336461373033646563666333353661 | ||||||
| 33636232313866613662353661373533383138393434396338343934326333326238336638396462 | 61633865373764346131623131346266373331626336663735303439376230333537386562303939 | ||||||
| 65376133343038313437343934373265333632663133653133656130636533663237623839623634 | 65363139346564653464663633326639323930333464376136353064393039373535613231623138 | ||||||
| 35363764363763363465363437623964363362616261663166633066373033633864336532633031 | 61373434323065646238356436373730333939613965666237616265653033333230353466316266 | ||||||
| 32323733616562663031303230383561373637326436336462363461313532623262653866323862 | 30383939376335656632626232663061623332636337646234653565363561353334643462376666 | ||||||
| 34643631333533626537373538353564306261313035303530666462326534633638363932363037 | 30326438303333336265306463313137656334313235643434616238333564373761333235633639 | ||||||
| 65336230373034643966656561303164373463353638316632613431643535303930373334383134 | 66346161316130633463623435646639366136386335386139613230653064663230366265633036 | ||||||
| 38323731363535313065326330653666323934636466386238616664316635303333653631396639 | 33613132633035393337653436613031383765616638323663363866393165613030306637393134 | ||||||
| 39303737613361653862343964303231393164346134633366633262326230643137303331373231 | 38333734373939626364343533306662393463646264666161346434363832623239643864303431 | ||||||
| 31323832363937663935333737613133323265323863623933633962633230386339636432643937 | 39383931333139633338663761646335613935636239636439383333313531633364653439323036 | ||||||
| 66653763376663666637353738646565343835333937343765356539383734316231623466343634 | 35373639363164386666366335313934336231333261623763633133393562656237313761356631 | ||||||
| 30663135663938393561333133663737653635393432333534306466366332333338 | 39663234653339313466326534333435306662316461333035623339353435383137383735373733 | ||||||
|  | 32373535303338646266346539386364356233616631316661633037346665353762353138376538 | ||||||
|  | 386535333439313233663464353534376535 | ||||||
|   | |||||||
							
								
								
									
										13
									
								
								settings.yml
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								settings.yml
									
									
									
									
									
								
							| @@ -1,7 +1,4 @@ | |||||||
| --- | --- | ||||||
|  |  | ||||||
| - configure_networks: "True" |  | ||||||
| # Allocation pool for a flat provider network. |  | ||||||
| - allocation_pool: | - allocation_pool: | ||||||
|     start: 172.23.128.50 |     start: 172.23.128.50 | ||||||
|     end: 172.23.128.249 |     end: 172.23.128.249 | ||||||
| @@ -12,12 +9,4 @@ | |||||||
|  |  | ||||||
| - subnet_range: 172.23.128.0/24 | - subnet_range: 172.23.128.0/24 | ||||||
|  |  | ||||||
| - global_physnet_mtu: 9000 | - rsa_pub: ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDStPUPXkcu81onUm/le54JCu174yXJJDsthDr96Mv8irBVBWuy5FxnaASuDpmC4QE4s0UAIg1iq/SWrr8qdBQ4OVuYFiW0S7ZJvcoKr/40Wh+T5MeltGQfmkDp6kBsfaMSo6M4tF1c8i+XgOgxb4fxHYb8mFhseztRLx6McxJJJLB0nu+T12WQ01nl0XtwD+3EsZWfxRH0KA59VHZSe3Anc5z+Fm7WU+1Vzy6/pkiIhVReI1L6VVhZsIdSu3fQK6fHQcujtfuw6RKEpisZQqnxMUviWQ98yeQXHk6Nx840WCh3vvKveEAoC4Y/UEZa1TMe6PczfUaLjaidUkpulJsP egon@egon-pc | ||||||
|  |  | ||||||
| - rsa_pub: > |  | ||||||
|     ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDStPUPXkcu81onUm/le54JCu174yXJJDsthDr9 |  | ||||||
|     6Mv8irBVBWuy5FxnaASuDpmC4QE4s0UAIg1iq/SWrr8qdBQ4OVuYFiW0S7ZJvcoKr/40Wh+T5Mel |  | ||||||
|     tGQfmkDp6kBsfaMSo6M4tF1c8i+XgOgxb4fxHYb8mFhseztRLx6McxJJJLB0nu+T12WQ01nl0Xtw |  | ||||||
|     D+3EsZWfxRH0KA59VHZSe3Anc5z+Fm7WU+1Vzy6/pkiIhVReI1L6VVhZsIdSu3fQK6fHQcujtfuw |  | ||||||
|     6RKEpisZQqnxMUviWQ98yeQXHk6Nx840WCh3vvKveEAoC4Y/UEZa1TMe6PczfUaLjaidUkpulJsP |  | ||||||
|      egon@egon-pc |  | ||||||
|   | |||||||
							
								
								
									
										28
									
								
								site.yml
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								site.yml
									
									
									
									
									
								
							| @@ -1,15 +1,15 @@ | |||||||
| --- | --- | ||||||
| - include: common.yml | - import_playbook: common.yml | ||||||
| - include: rabbitmq.yml | - import_playbook: rabbitmq.yml | ||||||
| - include: memcached.yml | - import_playbook: memcached.yml | ||||||
| - include: mariadb.yml | - import_playbook: mariadb.yml | ||||||
| - include: keystone.yml | - import_playbook: keystone.yml | ||||||
| - include: glance-controller.yml | - import_playbook: glance-controller.yml | ||||||
| - include: nova-controller.yml | - import_playbook: nova-controller.yml | ||||||
| - include: neutron-controller.yml | - import_playbook: neutron-controller.yml | ||||||
| - include: cinder-controller.yml | - import_playbook: cinder-controller.yml | ||||||
| - include: cinder-storage.yml | - import_playbook: cinder-storage.yml | ||||||
| - include: nova-compute.yml | - import_playbook: nova-compute.yml | ||||||
| - include: horizon.yml | - import_playbook: horizon.yml | ||||||
| - include: heat.yml | - import_playbook: heat.yml | ||||||
| - include: post-install.yml | - import_playbook: post-install.yml | ||||||
|   | |||||||
							
								
								
									
										48
									
								
								test_hosts
									
									
									
									
									
								
							
							
						
						
									
										48
									
								
								test_hosts
									
									
									
									
									
								
							| @@ -1,36 +1,48 @@ | |||||||
| [databases] | [databases] | ||||||
| ansible-test | openstack-test05 | ||||||
| ansible-test-2 | openstack-test06 | ||||||
| ansible-test-3 | openstack-test07 | ||||||
|  |  | ||||||
| [keystone] | [keystone] | ||||||
| ansible-test-3 | openstack-test05 | ||||||
|  |  | ||||||
| [glance-controller] | [glance-controller] | ||||||
| ansible-test-2 | openstack-test05 | ||||||
|  |  | ||||||
| [horizon] | [horizon] | ||||||
| ansible-test-3 | openstack-test05 | ||||||
|  |  | ||||||
| [rabbitmq] | [rabbitmq] | ||||||
| ansible-test | openstack-test05 | ||||||
| ansible-test-2 | openstack-test06 | ||||||
| ansible-test-3 | openstack-test07 | ||||||
|  |  | ||||||
| [cinder-storage] |  | ||||||
| ansible-test |  | ||||||
|  |  | ||||||
| [memcached] | [memcached] | ||||||
| ansible-test-3 | openstack-test05 | ||||||
|  |  | ||||||
| [neutron-controller] | [neutron-controller] | ||||||
| ansible-test physical_interface_mappings=provider:ens10 | openstack-test05 physical_interface_mappings=provider:enp4s0f0 | ||||||
|  |  | ||||||
| [nova-controller] | [nova-controller] | ||||||
| ansible-test | openstack-test05 | ||||||
|  |  | ||||||
| [nova-compute] | [cinder-controller] | ||||||
| ansible-test-2 physical_interface_mappings=provider:ens10 | openstack-test05 | ||||||
|  |  | ||||||
| [heat] | [heat] | ||||||
| ansible-test | openstack-test05 | ||||||
|  |  | ||||||
|  | [cinder-storage] | ||||||
|  | openstack-test05 storage_volume=/dev/openstack-test05-vg/cinder | ||||||
|  | openstack-test06 storage_volume=/dev/openstack-test06-vg/cinder | ||||||
|  | openstack-test07 storage_volume=/dev/openstack-test07-vg/cinder | ||||||
|  | openstack-test08 storage_volume=/dev/openstack-test08-vg/cinder | ||||||
|  | openstack-test09 storage_volume=/dev/openstack-test09-vg/cinder | ||||||
|  | openstack-test10 storage_volume=/dev/openstack-test10-vg/cinder | ||||||
|  |  | ||||||
|  | [nova-compute] | ||||||
|  | openstack-test06 physical_interface_mappings=provider:enp4s0f0 | ||||||
|  | openstack-test07 physical_interface_mappings=provider:enp4s0f0 | ||||||
|  | openstack-test08 physical_interface_mappings=provider:enp4s0f0 | ||||||
|  | openstack-test09 physical_interface_mappings=provider:enp4s0f0 | ||||||
|  | openstack-test10 physical_interface_mappings=provider:enp4s0f0 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user