Compare commits
16 Commits
fb2bdfe543
...
merlin-dev
Author | SHA1 | Date | |
---|---|---|---|
6453f1c468 | |||
3001fb8d57 | |||
a150b58aaa | |||
cc18e247c4 | |||
7114509697 | |||
6a6ebd0c60 | |||
7a41ca4187 | |||
469bcd769c | |||
598cbeec9d | |||
20ce7bcfc3 | |||
1bbf1e4270 | |||
84b901c8b3 | |||
e3f3d5d3b7 | |||
68ac7a0a6d | |||
8da96590ac | |||
fea7aaaff6 |
14
gcc-site.yml
14
gcc-site.yml
@ -1,14 +0,0 @@
|
|||||||
---
|
|
||||||
- include: common.yml
|
|
||||||
- include: rabbitmq.yml
|
|
||||||
- include: memcached.yml
|
|
||||||
- include: mariadb.yml
|
|
||||||
- include: keystone.yml
|
|
||||||
- include: glance-controller.yml
|
|
||||||
- include: nova-controller.yml
|
|
||||||
- include: neutron-controller.yml
|
|
||||||
- include: cinder-controller.yml
|
|
||||||
- include: cinder-storage.yml
|
|
||||||
- include: nova-compute.yml
|
|
||||||
- include: horizon.yml
|
|
||||||
- include: gcc-post-install.yml
|
|
38
merlin
38
merlin
@ -1,37 +1,39 @@
|
|||||||
[nova-compute]
|
[nova-compute]
|
||||||
merlin-managementnode002 physical_interface_mappings=provider:eno3
|
merlin-node012 physical_interface_mappings=provider:enp129s0f1 overlay_ip=172.23.43.12
|
||||||
merlin-managementnode003 physical_interface_mappings=provider:eno3
|
merlin-node013 physical_interface_mappings=provider:enp129s0f1 overlay_ip=172.23.43.13
|
||||||
merlin-node001 physical_interface_mappings=provider:eno3
|
merlin-node006 physical_interface_mappings=provider:enp130s0f0 overlay_ip=172.23.43.6
|
||||||
merlin-node003 physical_interface_mappings=provider:eno3
|
merlin-node007 physical_interface_mappings=provider:enp130s0f0 overlay_ip=172.23.43.7
|
||||||
merlin-node004 physical_interface_mappings=provider:eno3
|
merlin-node008 physical_interface_mappings=provider:enp130s0f0 overlay_ip=172.23.43.8
|
||||||
|
merlin-node009 physical_interface_mappings=provider:enp130s0f0 overlay_ip=172.23.43.9
|
||||||
|
merlin-node010 physical_interface_mappings=provider:enp130s0f0 overlay_ip=172.23.43.10
|
||||||
|
|
||||||
[databases]
|
[databases]
|
||||||
merlin-managementnode001
|
merlin-node011
|
||||||
merlin-managementnode002
|
merlin-node012
|
||||||
merlin-managementnode003
|
merlin-node013
|
||||||
|
|
||||||
[rabbitmq]
|
[rabbitmq]
|
||||||
merlin-managementnode001
|
merlin-node011
|
||||||
merlin-managementnode002
|
merlin-node012
|
||||||
merlin-managementnode003
|
merlin-node013
|
||||||
|
|
||||||
[horizon]
|
[horizon]
|
||||||
merlin-managementnode001
|
merlin-node011
|
||||||
|
|
||||||
[memcached]
|
[memcached]
|
||||||
merlin-managementnode001
|
merlin-node011
|
||||||
|
|
||||||
[nova-controller]
|
[nova-controller]
|
||||||
merlin-managementnode001
|
merlin-node011
|
||||||
|
|
||||||
[keystone]
|
[keystone]
|
||||||
merlin-managementnode001
|
merlin-node011
|
||||||
|
|
||||||
[neutron-controller]
|
[neutron-controller]
|
||||||
merlin-managementnode001 physical_interface_mappings=provider:eno3
|
merlin-node011 physical_interface_mappings=provider:enp129s0f1 overlay_ip=172.23.43.11
|
||||||
|
|
||||||
[heat]
|
[heat]
|
||||||
merlin-managementnode001
|
merlin-node011
|
||||||
|
|
||||||
[glance-controller]
|
[glance-controller]
|
||||||
merlin-managementnode001
|
merlin-node011
|
||||||
|
39
merlin-bagpipe
Normal file
39
merlin-bagpipe
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
[nova-compute]
|
||||||
|
merlin-managementnode002 physical_interface_mappings=provider:enp5s0f1 overlay_ip=129.125.60.109
|
||||||
|
merlin-managementnode003 physical_interface_mappings=provider:enp5s0f1 overlay_ip=129.125.60.110
|
||||||
|
merlin-node001 physical_interface_mappings=provider:enp130s0f0 overlay_ip=129.125.60.117
|
||||||
|
merlin-node002 physical_interface_mappings=provider:enp130s0f0 overlay_ip=129.125.60.118
|
||||||
|
merlin-node003 physical_interface_mappings=provider:enp130s0f0 overlay_ip=129.125.60.119
|
||||||
|
merlin-node004 physical_interface_mappings=provider:enp130s0f0 overlay_ip=129.125.60.122
|
||||||
|
merlin-node005 physical_interface_mappings=provider:enp130s0f0 overlay_ip=129.125.60.123
|
||||||
|
|
||||||
|
[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:enp5s0f1 overlay_ip=129.125.60.108
|
||||||
|
|
||||||
|
[heat]
|
||||||
|
merlin-managementnode001
|
||||||
|
|
||||||
|
[glance-controller]
|
||||||
|
merlin-managementnode001
|
5
nuke.yml
5
nuke.yml
@ -1,10 +1,13 @@
|
|||||||
---
|
---
|
||||||
|
# This playbook will reset the instalation to facilitate a new installation.
|
||||||
|
# All data is lost!
|
||||||
- hosts: all
|
- hosts: all
|
||||||
become: True
|
become: True
|
||||||
name: Dummy to gather facts
|
name: Dummy to gather facts
|
||||||
tasks:
|
tasks:
|
||||||
- shell: "systemctl stop docker"
|
|
||||||
- name: Stop docker service
|
- name: Stop docker service
|
||||||
|
shell: "systemctl stop docker"
|
||||||
|
- name: Verify docker is stopped.
|
||||||
systemd:
|
systemd:
|
||||||
name: docker
|
name: docker
|
||||||
state: stopped
|
state: stopped
|
||||||
|
@ -16,10 +16,7 @@
|
|||||||
command: docker exec -i keystone.service bash -c "source /root/admin-openrc.sh && {{ item }}"
|
command: docker exec -i keystone.service bash -c "source /root/admin-openrc.sh && {{ item }}"
|
||||||
with_items:
|
with_items:
|
||||||
- openstack network create --share --external --provider-physical-network provider --provider-network-type flat provider
|
- openstack network create --share --external --provider-physical-network provider --provider-network-type flat provider
|
||||||
- >
|
- openstack network set --external provider
|
||||||
openstack subnet create --network provider
|
|
||||||
--allocation-pool start={{ allocation_pool['start'] }},end={{ allocation_pool['end'] }}
|
|
||||||
--dns-nameserver {{ dns_nameserver }} --gateway {{ gateway }} --subnet-range {{ subnet_range }} providersub
|
|
||||||
- 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
|
||||||
|
|
||||||
|
@ -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,19 @@
|
|||||||
-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 key host.
|
||||||
|
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
|
||||||
|
@ -70,3 +70,8 @@
|
|||||||
|
|
||||||
- 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: groups['databases'] | length >= 3
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
name: secrets
|
name: secrets
|
||||||
|
|
||||||
- set_fact:
|
- set_fact:
|
||||||
docker_image: "registry.webhosting.rug.nl/hpc/openstack-neutron-controller:latest"
|
docker_image: "registry.webhosting.rug.nl/hpc/openstack-neutron-controller-merlin:latest"
|
||||||
|
|
||||||
- name: pull docker image
|
- name: pull docker image
|
||||||
docker_image:
|
docker_image:
|
||||||
@ -29,6 +29,7 @@
|
|||||||
-e "NOVA_CONTROLLER_HOST={{ listen_ip | default(hostvars[groups['nova-controller'][0]]['ansible_default_ipv4']['address']) }}"
|
-e "NOVA_CONTROLLER_HOST={{ listen_ip | default(hostvars[groups['nova-controller'][0]]['ansible_default_ipv4']['address']) }}"
|
||||||
-e "NOVA_PLACEMENT_PASSWORD={{ secrets['NOVA_PLACEMENT_PASSWORD'] }}"
|
-e "NOVA_PLACEMENT_PASSWORD={{ secrets['NOVA_PLACEMENT_PASSWORD'] }}"
|
||||||
-e "NOVA_PLACEMENT_USER=placement"
|
-e "NOVA_PLACEMENT_USER=placement"
|
||||||
|
-e "OVERLAY_IP={{ overlay_ip }}"
|
||||||
-e "OS_PASSWORD={{ secrets['OS_PASSWORD'] }}"
|
-e "OS_PASSWORD={{ secrets['OS_PASSWORD'] }}"
|
||||||
-e "PHYSICAL_INTERFACE_MAPPINGS={{ physical_interface_mappings }}"
|
-e "PHYSICAL_INTERFACE_MAPPINGS={{ physical_interface_mappings }}"
|
||||||
-e "RABBIT_PASSWORD={{ secrets['RABBIT_PASSWORD'] }}"
|
-e "RABBIT_PASSWORD={{ secrets['RABBIT_PASSWORD'] }}"
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
tags: vars
|
tags: vars
|
||||||
|
|
||||||
- set_fact:
|
- set_fact:
|
||||||
docker_image: registry.webhosting.rug.nl/hpc/openstack-nova-compute:latest
|
docker_image: registry.webhosting.rug.nl/hpc/openstack-nova-compute-merlin:latest
|
||||||
tags: vars
|
tags: vars
|
||||||
|
|
||||||
- name: pull docker image
|
- name: pull docker image
|
||||||
|
@ -26,6 +26,7 @@ ExecStart=/usr/bin/docker run --name %n \
|
|||||||
-e "NOVA_PLACEMENT_PASSWORD={{ secrets['NOVA_PLACEMENT_PASSWORD'] }}" \
|
-e "NOVA_PLACEMENT_PASSWORD={{ secrets['NOVA_PLACEMENT_PASSWORD'] }}" \
|
||||||
-e "NOVA_PLACEMENT_USER=placement" \
|
-e "NOVA_PLACEMENT_USER=placement" \
|
||||||
-e "NOVA_USER=nova" \
|
-e "NOVA_USER=nova" \
|
||||||
|
-e "OVERLAY_IP={{ overlay_ip }}" \
|
||||||
-e "OS_PASSWORD={{ secrets['OS_PASSWORD'] }}" \
|
-e "OS_PASSWORD={{ secrets['OS_PASSWORD'] }}" \
|
||||||
-e "PHYSICAL_INTERFACE_MAPPINGS={{ physical_interface_mappings }}" \
|
-e "PHYSICAL_INTERFACE_MAPPINGS={{ physical_interface_mappings }}" \
|
||||||
-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']) }}" \
|
||||||
|
2
site.yml
2
site.yml
@ -12,4 +12,4 @@
|
|||||||
- include: nova-compute.yml
|
- include: nova-compute.yml
|
||||||
- include: horizon.yml
|
- include: horizon.yml
|
||||||
- include: heat.yml
|
- include: heat.yml
|
||||||
- include: post-install.yml
|
#- include: 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