hpc-cloud/roles/mariadb/tasks/main.yml

77 lines
1.7 KiB
YAML
Raw Normal View History

# Install a docker based mariadb.
---
- name: include secrets
include_vars:
file: ../../secrets.yml
name: secrets
- name: make mariadb settings volume
file:
2017-08-02 15:22:10 +02:00
path: "{{ item }}"
state: directory
mode: 0777
2017-08-02 15:22:10 +02:00
with_items:
- /srv/mariadb/lib/mysql
- /srv/mariadb/etc/mysql
- /srv/mariadb/etc/mysql/conf.d
- name: place settings file
copy:
src: files/my.cnf
dest: /srv/mariadb/etc/mysql/conf.d/my.cnf
2017-10-17 17:12:52 +02:00
mode: 660
- name: Set galara.cnf on node if we have at least three nodes.
template:
src: files/galera.cnf
2017-10-17 17:12:52 +02:00
dest: /srv/mariadb/etc/mysql/conf.d/galera.cnf
mode: 660
when: groups['databases'] | length >= 3
2017-10-17 17:12:52 +02:00
# This mimics galera_new_cluster.sh
- name: Initialize a new cluster.
block:
- set_fact:
mariadb_args: "--wsrep-new-cluster"
- template:
src: templates/mysql.service
dest: /etc/systemd/system/mysql.service
mode: 644
owner: root
group: root
- command: systemctl daemon-reload
- systemd:
name: mysql.service
state: started
when: groups['databases'] | length >= 3 and ansible_hostname == hostname_node0
- name: install service file.
block:
- set_fact:
mariadb_args: ""
- template:
src: templates/mysql.service
dest: /etc/systemd/system/mysql.service
mode: 644
owner: root
group: root
2017-10-31 13:23:27 +01:00
- name: give the galera master node some time to Initialize
pause:
minutes: 1
when: ansible_hostname != hostname_node0
- command: systemctl daemon-reload
- name: make sure service is started
systemd:
name: mysql.service
state: started
- name: start service at boot.
command: systemctl reenable mysql.service