使用ansible-playbook自动化安装MySQL主从

【使用自动化安装MySQL主从架构】

说明:使用ansible-playbook 自动化安装 MySQL主从 + mysqld-exporter的采集数据 + xtrabackup备份

【剧本说明】

以下文件在roles目录下

tree roles/mysql_ms/
mysql_ms/
├── files
│ ├── mysql.service MySQL服务
│ └── mysql_slave_config.sh 创建主从脚本
├── tasks
│ ├── install_backup.yml 安装备份的剧本
│ ├── install_exporter.yml 安装监控采集的剧本
│ └── main.yml 主剧本
├── templates
│ ├── my.cnf  MySQL的配置文件,可以根据自己实际情况修改配置
│ ├── mysqld-exporter.service 监控采集的服务配置
│ ├── mysql_fullbackup_xtrabackup.sh 备份的脚本
│ ├── readme.md
└── vars
└── main.yml 全局的环境变量

【对应目录创建脚本】

files目录

vim mysql.service
[Unit]
Description=MySQL Server
Documentation=man:mysqld(8)
Documentation=http://dev.mysql.com/doc/refman/en/using-systemd.html
After=network.target
After=syslog.target

[Install]
WantedBy=multi-user.target

[Service]
User=mysql
Group=mysql
ExecStart=/usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf
LimitNOFILE = 65536
Environment=MYSQLD_PARENT_PID=1
vim mysql_slave_config.sh
#!/bin/bash
REPLUSER=$1
REPLPASS=$2
MYSQL_MASTER=$3
MYSQL_PASS=$4
MYSQLBIN=$(/usr/local/mysql/bin/mysql -u ${REPLUSER} -p${REPLPASS} -h${MYSQL_MASTER} -e "show master status\G;"|egrep 'File: .*+'|awk '{print $2}')
BINPOSITION=$(/usr/local/mysql/bin/mysql -uroot -p${MYSQL_PASS} -e "show master status\G;"|egrep 'Position: .*+'|awk '{print $2}')
/usr/local/mysql/bin/mysql -uroot -p${MYSQL_PASS} -e "CHANGE MASTER TO MASTER_HOST='${MYSQL_MASTER}', MASTER_USER='${REPLUSER}', MASTER_PASSWORD='${REPLPASS}', MASTER_LOG_FILE='${MYSQLBIN}', MASTER_LOG_POS=${BINPOSITION};start slave;select sleep(10);show slave status\G;"

 

task目录

vim install_backup.yml
---

- name: Download mysqld xtrabackup soft
  copy: src={{download_target}}/{{mysqlxtrabackup_binary}} dest=/tmp/{{mysqlxtrabackup_binary}} mode=0755

- name: tar xtrabackup binary
  command: tar -zxvf /tmp/percona-xtrabackup-2.4.12-Linux-x86_64.libgcrypt145.tar.gz -C /usr/local/

- name: ln xtrabackup binary
  command: ln -sf /usr/local/percona-xtrabackup-2.4.12-Linux-x86_64/bin/xtrabackup /usr/bin/

- name: Download mysqld qpress soft
  copy: src={{download_target}}/{{mysqlqpress_binary}}     dest=/tmp/{{mysqlqpress_binary}} mode=0755

- name: install qpress  binary
  command: tar -xf /tmp/qpress-11-linux-x64.tar -C /usr/local/bin

- name: create data directory
  file:
    path: '{{backup_dir}}/{{item.0}}/{{item.1}}'
    state: directory
    owner: root
    group: root
    recurse: yes
  with_nested: 
  - ['backup']
  - ['scripts', 'logs', 'innobackupex']
  when: cluster_role == "master"

- name: Add mysqld backup keyfile scripts
  shell: echo -n GCHFLrDFVx6UAsRb88uLVbAVWbK+Yzfs > '{{backup_dir}}/backup/scripts/keyfile'
  when: cluster_role == "master"

- name: Add mysqld backup shell scripts
  template:
    dest: '{{backup_dir}}/backup/scripts/mysql_fullbackup_xtrabackup.sh'
    src: mysql_fullbackup_xtrabackup.sh
    mode: 755
  when: cluster_role == "master"

- name: Mysql xtrabackup
  ansible.builtin.cron:
    name: "Mysql xtrabackup"
    minute: "0"
    hour: "2"
    job: "{{backup_dir}}/backup/scripts/mysql_fullbackup_xtrabackup.sh > /dev/null 2>&1 &"
    disabled: false
  when: cluster_role == "master"
vim install_exporter.yml 
---

- name: Download mysqld Exporter
  copy: src={{download_target}}/{{exporter_binary}} dest=/usr/local/bin/{{exporter_binary}} mode=0755

- name: Add mysqld exporter system server
  template:
    dest: /etc/systemd/system/mysqld-exporter.service
    src: mysqld-exporter.service

- name: Ensure mysqld exporter is enabled
  systemd:
    daemon_reload: yes
    name: mysqld-exporter
    enabled: yes

- name: Start mysqld exporter
  service: 
    name: mysqld-exporter
    state: restarted
    enabled: yes
vim main.yml
---


- name: Gathering info
  action: setup

- name: create mysql user and group
  user:
    name: mysql
    shell: /sbin/nologin

- name: download installation media
  copy:
    src: "{{download_target}}/{{mysql_tgz}}"
    dest: /tmp/mysql.tar.gz

- name: install binary
  command: tar -xzf /tmp/mysql.tar.gz -C /usr/local/
- template:
    src: my.cnf
    dest: /etc/my.cnf
    owner: mysql
    group: mysql
- file:
    src: /usr/local/{{tgz_extracted}}
    dest: /usr/local/mysql
    owner: mysql
    group: mysql
    state: link
- file:
    path: /data/mysql
    state: directory
    owner: mysql
    group: mysql
    recurse: True
- file:
    path: /var/run/mysqld/
    owner: mysql
    group: mysql
    state: directory
    recurse: True
- file:
    path: /var/log/mysql
    owner: mysql
    group: mysql
    state: directory
    recurse: True
- file:
    path: /etc/my.cnf
    owner: mysql
    group: mysql
    state: touch
- file:
    path: /usr/local/{{tgz_extracted}}
    owner: mysql
    group: mysql
    state: directory
    recurse: True

- name: mysql initialization and reset password
  copy:
    src: mysql.service
    dest: /etc/systemd/system/mysql.service
- command: /usr/local/mysql/bin/mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql
- command: systemctl daemon-reload
- service: 
    name: mysql
    state: started
    enabled: yes
- command: sleep 10s
- command: /usr/local/mysql/bin/mysqladmin -uroot password {{mysql_pass}}
- name: repl configuration on master side
  command: /usr/local/mysql/bin/mysql -uroot -p{{mysql_pass}} -e "CREATE USER {{repl_user}}@'%' IDENTIFIED BY '{{repl_pass}}';GRANT REPLICATION SLAVE ON *.* TO {{repl_user}}@'%';GRANT REPLICATION CLIENT ON *.* TO {{repl_user}}@'%';flush privileges;"
  when: cluster_role == "master"

- name: repl configuration on slave side
  copy:
    src: mysql_slave_config.sh
    dest: /tmp/mysql_slave_config.sh
    mode: 755
  when: cluster_role == "slave"

- command: /tmp/mysql_slave_config.sh {{repl_user}} {{repl_pass}} {{groups['mysql_ms'][0]}} {{mysql_pass}}
  when: cluster_role == "slave"

- name: repl configuration read_only
  command: /usr/local/mysql/bin/mysql -uroot -p{{mysql_pass}} -e "set global read_only=on;"
  when: cluster_role == "slave"

- name: install Exporter
  include: install_exporter.yml
  tags:
    - mysqld_exporter

- name: install backup files
  include: install_backup.yml
  tags:
    - mysqld_backup

 

templates目录

vim my.cnf
# For advice on how to change settings please see
# http://dev.mysql.com/doc/refman/5.7/en/server-configuration-defaults.html
[client]
port = 3306
socket = /data/mysql/mysql.sock

[mysqld]
datadir=/data/mysql
socket=/data/mysql/mysql.sock
pid-file=/var/run/mysqld/mysqld.pid

# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0

character_set_server=utf8
gtid_mode = ON
enforce-gtid-consistency = ON
lower_case_table_names = 1
sql_mode = STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
log_bin_trust_function_creators = ON
log_timestamps = SYSTEM

#####################innodata engine########################
innodata_buffer_pool_size = {{ (ansible_memtotal_mb * 0.6 // 128 ) | int * 128 }}M
innodata_buffer_pool_instances = 4
innodata_log_file_size = 2G
max_connections = 3000

#####################bin log##############################
server_id = {{server_id}}
log-bin = mysqlbin
expire_logs_days = 7
max_binlog_size = 1024M
binlog_format = row
sync_binlog = 1
max_allowed_packet = 1024M
log_slave_updates = on

#####################replication conf##############################
master_info_repository =table
relay_log_info_repository =table
slave_parallel_type =logical_clock
slave_parallel_workers =4
rpl_semi_sync_master_enabled =1
rpl_semi_sync_slave_enabled =1
rpl_semi_sync_master_timeout =5000
plugin_load_add =semisync_master.so
plugin_load_add =semisync_slave.so
binlog_group_commit_sync_delay =500
binlog_group_commit_sync_no_delay_count = 13
binlog_transaction_dependency_tracking = WRITESET
transaction_write_set_extraction = XXHASH64

#####################readonly conf##############################
#read_only = on
#super_read_only=on

#####################slow log##############################
slow_query_log = ON
long_query_time = 2
slow_query_log_file = /data/mysql/mysql01_slow.log

#####################error log##############################
log-error = /var/log/mysql/mysqld.log
explicit_defaults_for_timestamp = OFF

[mysql]
auto-rehash
prompt = "\u@\h:3306(production)\\d \\R:\\m:\\s>"
default-character-set = utf8
vim mysqld-exporter.service
[Unit]
Description=https://prometheus_exporter.io
[Service]
Environment=DATA_SOURCE_NAME=monitor:monitor@(localhost:3306)/
ExecStart=/usr/local/bin/mysqld-exporter --web.listen-address=0.0.0.0:9104
Restart=on-failure
[Install]
WantedBy=multi-user.target

var 目录

vim main.yml
---

mysql_tgz: mysql-5.7.36-linux-glibc2.12-x86_64.tar.gz
tgz_extracted: mysql-5.7.36-linux-glibc2.12-x86_64
mysql_pass: Root_1234
repl_user: repl
repl_pass: Repl_1234
download_target: /tmp/soft
exporter_binary: mysqld-exporter
mysqlxtrabackup_binary: percona-xtrabackup-2.4.12-Linux-x86_64.libgcrypt145.tar.gz
mysqlqpress_binary: qpress-11-linux-x64.tar
backup_dir: /backup

【安装包及配置】

环境变量说明,这里默认数据目录为/data:可以直接修改my.cnf修改目录,后续使用环境变量替换 sed -i  's/\data/\你的目录名称/g'   templates/my.cnf  sed -i  's/\db/\data/g'   tasks/main.yml

cat var/main.yml
---

mysql_tgz: mysql-5.7.36-linux-glibc2.12-x86_64.tar.gz
tgz_extracted: mysql-5.7.36-linux-glibc2.12-x86_64
mysql_pass: Root_1234
repl_user: repl
repl_pass: Repl_1234
download_target: /tmp/soft
exporter_binary: mysqld-exporter
mysqlxtrabackup_binary: percona-xtrabackup-2.4.12-Linux-x86_64.libgcrypt145.tar.gz
mysqlqpress_binary: qpress-11-linux-x64.tar
backup_dir: /backup

将安装包放在download_target目录下,以上变量可以自己定义:

mysql,mysqld-exporter,percona-xtrabackup,qpress

 

创建ansible的hosts文件,前面换成你的IP,root用户root密码,cluster_role后面定义了master节点,server_id不重复即可

vim /etc/ansible/hosts

[mysql_ms]
IPXX1 ansible_user=root ansible_ssh_pass=xxx cluster_role=master server_id=90
IPXX2 ansible_user=root ansible_ssh_pass=xxx cluster_role=slave server_id=91
IPXX3 ansible_user=root ansible_ssh_pass=xxx cluster_role=slave server_id=92

 

创建playbook文件

vim  mysql_ms.yaml 
---
- hosts: mysql_ms
  gather_facts: no
  roles:
    - mysql_ms

然后执行自动化安装,等待安装完成即可

ansible-playbook mysql_ms.yaml

 【检查】

查看数据库服务:systemctl status  mysql

查看监控服务:systemctl status  mysqld-exporter

查看备份信息:crontab -l

posted @ 2023-01-04 12:02  zetan·chen  阅读(924)  评论(0编辑  收藏  举报