4 Commits

Author SHA1 Message Date
0c605af3ae Check if this role is deployed as part of the cluster
This makes it possible to deploy a galara cluster in one set of hosts
and a separate stand alone mariadb on another host.
2018-05-17 16:12:28 +02:00
ca6adb44f6 It should be include_playbook
... the replacement for impotrt for static includes, that is....
2018-04-04 11:28:16 +02:00
c0d50d7444 include is deprecated. 2018-03-22 09:21:22 +01:00
f8a3179b74 Ensure installation of same openstack client 2018-02-22 16:35:44 +01:00
5 changed files with 59 additions and 40 deletions

View File

@ -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

View File

@ -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,4 @@
owner: root owner: root
group: root group: root
- include: docker.yml - import_tasks: docker.yml

View File

@ -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']) }}
@ -90,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

View File

@ -11,9 +11,9 @@
state: directory state: directory
mode: 0777 mode: 0777
with_items: with_items:
- /srv/mariadb/lib/mysql - /srv/mariadb/lib/mysql
- /srv/mariadb/etc/mysql - /srv/mariadb/etc/mysql
- /srv/mariadb/etc/mysql/conf.d - /srv/mariadb/etc/mysql/conf.d
- name: place settings file - name: place settings file
copy: copy:
@ -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"

View File

@ -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