uoi-io.galera

Ansible Galera(适用于 OpenStack)

该模块支持 Galera 集群的设置。

将向打包系统添加两个软件源:

  • MariaDB (MariaDB, Galera)
  • Percona (xtrabackup)

支持的发行版:

  • CentOS 7.x
  • RedHat EL 7.x
  • Debian 8.x

支持的功能:

  • Firewalld (服务器上需要安装 iptables 和 firewalld 包)
  • SELinux
  • Pacemaker

Pacemaker 支持提供 clustercheck 工具和 xinetd 的必需配置。

当定义 Pacemaker 支持时,Galera 集群将被停止,并且 MariaDB 配置中的 wsrep_cluster_address 选项将被移除,以便 Pacemaker 自行决定。

需求

该模块至少需要 3 个节点和 Ansible 2.0。

角色变量

如果 galera_reset_cluster 设置为 true,所有数据库将会被 删除,请务必小心!

配置

### MARIADB
master: ctrl01
mariadb_bind_address: 0.0.0.0
mariadb_port: 3306
mariadb_max_connections: 4096
mariadb_query_cache_size: 0
mariadb_default_storage_engine: InnoDB
mariadb_maintenance_password: I3uL6AqJLHInv85x
mariadb_root_password: 3248ew7dsYUG762
mariadb_hosts_allow: 192.168.% 
mariadb_datadir: /var/lib/mysql

### GALERA
galera_node_address: "{{ ansible_eth0.ipv4.address }}"
galera_pacemaker_support: false
galera_clustercheck_user: clustercheck
galera_clustercheck_password: Y3aH1l0ved2CH3CK
galera_reset_cluster: false
galera_selinux: true
galera_firewalld: true
galera_cluster_name: uoi-sql-cluster
galera_sst_method: xtrabackup-v2
galera_sst_user: sst-replication
galera_sst_password: gr34tp4ss0rd
galera_cluster_nodes:
  - ctrl01
  - ctrl02
  - ctrl03
galera_provider_options: 'pc.ignore_quorum=true; gcache.size=1G'
galera_retry_autocommit: 10
galera_slave_threads: 8

变量

因为该模块支持 RedHat 和 Debian 发行版,所以我们需要根据操作系统家族定义一些值。

### REDHAT
# 文件: roles/galera/vars/RedHat.yml
galera_packages:
  - MariaDB-server
  - percona-xtrabackup
  - socat
  - MySQL-python
  - percona-toolkit
  - galera
  - policycoreutils-python
  - checkpolicy
  - xinetd
mariadb_svc_name: mariadb
mariadb_config: my.cnf.d/server.cnf
galera_provider: /usr/lib64/galera/libgalera_smm.so
percona_package: https://www.percona.com/redir/downloads/percona-release/redhat/latest/percona-release-0.1-3.noarch.rpm
### DEBIAN
# 文件: roles/galera/vars/Debian.yml
galera_packages:
  - mariadb-server
  - xtrabackup
  - socat
  - python-mysqldb
  - percona-toolkit
  - xinetd
mariadb_svc_name: mysql
mariadb_config: mysql/conf.d/galera.cnf
galera_provider: /usr/lib/galera/libgalera_smm.so
## 主要
# 文件: roles/galera/vars/main.yml
galera_xinet_port: 9200

# 防火墙端口
fw_mysql: "{{ mariadb_port }}"
fw_mysql_ist: 4568
fw_mysql_sst: 4444
fw_galera: 4567
fw_xinetd: "{{ galera_xinet_port }}"

依赖

无。

示例剧本

master: node1
mariadb_bind_address: 0.0.0.0
mariadb_max_connections: 4096
mariadb_maintenance_password: I3uL6AqJLHInv85x
mariadb_root_password: 3248ew7dsYUG762
mariadb_hosts_allow: 10.0.%

galera_node_address: "{{ ansible_eth0.ipv4.address }}"
galera_pacemaker_support: false
galera_clustercheck_user: clustercheck
galera_clustercheck_password: Y3aH1l0ved2CH3CK
galera_cluster_name: uoi-sql-cluster
galera_sst_password: gr34tp4ss0rd
galera_cluster_nodes:
  - node-1
  - node-2
  - node-3
  - node-4
  - node-5

galera-status

当部署完成后,请运行 galera-status 命令以获取 Galera 集群的清晰状态。

# galera-status

许可证

Apache

作者信息

该角色由 Gaëtan Trellu (goldyfruit) 于 2016 年创建。

关于项目

Deploy a Galera 3 cluster with MariaDB 10.1, supports SELinux, firewalld, Pacemaker

安装
ansible-galaxy install uoi-io.galera
许可证
apache-2.0
下载
126