|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234 |
- {%- from "galera/map.jinja" import slave with context %}
- {%- if slave.get('enabled', False) %}
-
- {%- if slave.get('ssl', {}).get('enabled', False) %}
- include:
- - galera._ssl
- {%- endif %}
-
- {%- if grains.os_family == 'RedHat' %}
- xtrabackup_repo:
- pkg.installed:
- - sources:
- - percona-release: {{ slave.xtrabackup_repo }}
- - require_in:
- - pkg: galera_packages
-
-
- xtrabackup_repo_fix:
- cmd.run:
- - name: |
- sed -i 's,enabled\ =\ 1,enabled\ =\ 1\nexclude\ =\ Percona-XtraDB-\*\ Percona-Server-\*,g' /etc/yum.repos.d/percona-release.repo
- - unless: 'grep "exclude = Percona-XtraDB-\*" /etc/yum.repos.d/percona-release.repo'
- - watch:
- - pkg: xtrabackup_repo
- - require_in:
- - pkg: galera_packages
- {%- endif %}
-
- galera_packages:
- pkg.installed:
- - names: {{ slave.pkgs }}
- - refresh: true
- - force_yes: True
-
- galera_dirs:
- file.directory:
- - names: ['/var/log/mysql', '/etc/mysql']
- - makedirs: true
- - mode: 755
- - require:
- - pkg: galera_packages
-
- {%- if grains.os_family == 'Debian' %}
- galera_run_dir:
- file.directory:
- - name: /var/run/mysqld
- - makedirs: true
- - mode: 755
- - user: mysql
- - group: root
- - require:
- - pkg: galera_packages
-
- {%- if grains.get('init', None) == "upstart" %}
-
- galera_purge_init:
- file.absent:
- - name: /etc/init.d/mysql
- - require:
- - pkg: galera_packages
-
- galera_overide:
- file.managed:
- - name: /etc/init/mysql.override
- - contents: |
- limit nofile 102400 102400
- exec /usr/bin/mysqld_safe
- - require:
- - pkg: galera_packages
-
- {%- elif grains.get('init', None) == "systemd" %}
-
- galera_systemd_directory_present:
- file.directory:
- - name: /etc/systemd/system/mysql.service.d
- - user: root
- - group: root
- - mode: 755
- - require:
- - pkg: galera_packages
-
- galera_override_limit_no_file:
- file.managed:
- - name: /etc/systemd/system/mysql.service.d/override.conf
- - contents: |
- [Service]
- LimitNOFILE=1024000
- - require:
- - pkg: galera_packages
- - file: galera_systemd_directory_present
- - watch_in:
- - service: galera_service
-
- mysql_restart_systemd:
- module.wait:
- - name: service.systemctl_reload
- - watch:
- - file: /etc/systemd/system/mysql.service.d/override.conf
- - require_in:
- - service: galera_service
-
- {%- endif %}
-
- galera_conf_debian:
- file.managed:
- - name: /etc/mysql/debian.cnf
- - template: jinja
- - source: salt://galera/files/debian.cnf
- - mode: 640
- - require:
- - pkg: galera_packages
-
- {%- endif %}
-
- galera_init_script:
- file.managed:
- - name: /usr/local/sbin/galera_init.sh
- - mode: 755
- - source: salt://galera/files/init_bootstrap.sh
- - defaults:
- service: {{ slave|yaml }}
- - template: jinja
-
- galera_bootstrap_script:
- file.managed:
- - name: /usr/local/sbin/galera_bootstrap.sh
- - mode: 755
- - defaults:
- service: {{ slave|yaml }}
- - source: salt://galera/files/bootstrap.sh
- - template: jinja
-
- {%- if salt['cmd.shell']('test -e /var/lib/mysql/.galera_bootstrap; echo $?') != '0' %}
-
-
- galera_pre_config:
- file.managed:
- - name: {{ slave.config }}
- - source: salt://galera/files/my.cnf.pre
- - mode: 644
- - template: jinja
- - makedirs: true
- - require_in:
- - pkg: galera_packages
-
- galera_init_start_service:
- cmd.run:
- - name: /usr/local/sbin/galera_init.sh
- {%- if grains.get('noservices') %}
- - onlyif: /bin/false
- {%- endif %}
- - require:
- - file: galera_run_dir
- - file: galera_init_script
- - timeout: 1800
-
- galera_bootstrap_set_root_password:
- cmd.run:
- - name: mysqladmin password "{{ slave.admin.password }}"
- {%- if grains.get('noservices') %}
- - onlyif: /bin/false
- {%- endif %}
- - require:
- - cmd: galera_init_start_service
-
- mysql_bootstrap_update_maint_password:
- cmd.run:
- - name: mysql -u root -p{{ slave.admin.password }} -e "GRANT ALL PRIVILEGES ON *.* TO 'debian-sys-maint'@'localhost' IDENTIFIED BY '{{ slave.maintenance_password }}';"
- {%- if grains.get('noservices') %}
- - onlyif: /bin/false
- {%- endif %}
- - require:
- - cmd: galera_bootstrap_set_root_password
-
- galera_bootstrap_stop_service:
- service.dead:
- - name: {{ slave.service }}
- {%- if not grains.get('noservices', False) %}
- - require:
- - cmd: mysql_bootstrap_update_maint_password
- {%- else %}
- - onlyif: /bin/false
- {%- endif %}
-
- galera_bootstrap_init_config:
- file.managed:
- - name: {{ slave.config }}
- - source: salt://galera/files/my.cnf
- - mode: 644
- - template: jinja
- - require:
- - service: galera_bootstrap_stop_service
-
- galera_bootstrap_start_service_final:
- cmd.run:
- - name: /usr/local/sbin/galera_bootstrap.sh
- {%- if grains.get('noservices') %}
- - onlyif: /bin/false
- {%- endif %}
- - require:
- - file: galera_bootstrap_init_config
- - file: galera_bootstrap_script
- - timeout: 1800
-
- galera_bootstrap_finish_flag:
- file.touch:
- - name: /var/lib/mysql/.galera_bootstrap
- - require:
- - cmd: galera_bootstrap_start_service_final
- - watch_in:
- - file: galera_config
-
- {%- endif %}
-
- galera_config:
- file.managed:
- - name: {{ slave.config }}
- - source: salt://galera/files/my.cnf
- - mode: 644
- - template: jinja
- - require_in:
- - service: galera_service
-
- galera_service:
- service.running:
- - name: {{ slave.service }}
- - enable: true
- - reload: true
- {%- if grains.get('noservices') %}
- - onlyif: /bin/false
- {%- endif %}
-
- {%- endif %}
-
|