在四台虚拟机上都安装好docker

一、控制节点

1. 域名解析

[root@d ansible]# vim /etc/hosts

[root@d ansible]# scp /etc/hosts node1:/etc/hosts

[root@d ansible]# scp /etc/hosts node2:/etc/hosts

[root@d ansible]# scp /etc/hosts node2:/etc/hosts

做好ssh免密登陆node1,node2,node3

2. 将镜像解压后放在对应的目录

[root@d ~]# cd /opt/

[root@d opt]# tar xzf ansible-galera.tar.gz

[root@d ~]# yum install ansible -y

[root@d ansible-galera]# cd /etc/ansible/

[root@d ansible]# rm -rf *

[root@d ansible]# mv /opt/ansible-galera/* ./

[root@d bin]# cd /etc/ansible/bin/

[root@d bin]# cd /opt/

[root@d opt]# tar xzf galera.tar.gz

[root@d opt]# mv config.tar.gz mariadb-galera.tar /etc/ansible/bin/

[root@d opt]# cd /etc/ansible/bin/

3. 修改ansible的hosts配置文件

[root@d bin]# cd /etc/ansible/

[root@d ansible]# vim hosts

[all]

192.168.88.51

192.168.88.52

192.168.88.53

[master]

192.168.88.51

[slave1]

192.168.88.52

[slave2]

192.168.88.53

[all:vars]

#定义集群ip

master="192.168.88.51"

slave1="192.168.88.52"

slave2="192.168.88.53"

#部署目录,即 ansible 工作目录

base_dir="/etc/ansible"

#ansible默认软件安装目录

opt_dir="/opt"

[root@d ~]# ansible all -m ping

4. 开始部署

[root@d ~]# cd /etc/ansible/

[root@d ansible]# ansible-playbook install.yml

二、登陆node1,node2,node3查看状态

1. 各个节点上都运行了一个galera的容器

2. 在node1,2,3检查集群状态:

[root@node1 ~]# docker ps -a

[root@node1 ~]# docker exec -it galera1 /bin/bash

root@node1:/# mysql -uroot -p123

MariaDB [(none)]> SHOW STATUS LIKE 'wsrep_cluster_size';

3. 故障恢复

(1)集群中某slave节点down机,重启该节点后,重启docke容器即可;

将node3虚拟机shutdown

[root@d ~]# mysql -h node1 -uroot -p123 #远程登陆其他虚拟机上的数据库

MariaDB [(none)]> SHOW STATUS LIKE 'wsrep_cluster_size';

再将node3开机,查看集群状态

(2)集群中master节点down机,重启该master节点后,master-docker容器不能正常启动,因为这是master节点已经切换,需要将原先master-docker容器删除,再以非wrsep方式启动一个普通容器;

将master节点node1关机

[root@node1 ~]# shutdown -h now

[root@d ~]# mysql -h node2 -uroot -p123

MariaDB [(none)]> SHOW STATUS LIKE 'wsrep_cluster_size';

此时再将node1开机,然后查看集群状态,发现还是2台,没有加入集群中

[root@node1 ~]# docker ps -a

galera1容器启动失败

[root@node1 ~]# docker stop galera1

galera1

[root@node1 ~]# docker rm galera1

galera1

[root@node1 ~]# cd /opt/

[root@node1 opt]# ls

mariadb rh

[root@node1 opt]# cd mariadb/

[root@node1 mariadb]# ls

config mariadb-galera.tar slave1.sh

config.tar.gz master.sh slave2.sh

将上面的配置文件复制粘贴到txt中,然后修改提示信息,然后将修改后的内容再命令行下运行

[root@node1 mariadb]# docker run -d --net host --name galera1 \

> -e WSREP_NODE_ADDRESS=192.168.88.51 \

> -e WSREP_CLUSTER_ADDRESS=gcomm://192.168.88.51:4567,192.168.88.52:4567,192.168.88.53:4567 \

> -p 3306:3306 \

> -p 4567:4567/udp \

> -p 4567-4568:4567-4568 \

> -p 4444:4444 \

> -v /opt/mariadb/config/mysql:/etc/mysql \

> -v /opt/mariadb/config/data:/var/lib/mysql:Z \

> --restart=always \

> panubo/mariadb-galera mysqld

WARNING: Published ports are discarded when using host network mode

e03ee2f6ec1bb2c6e7592d75154cead7bf5dd621a452731e68a0a25d170bf64a

[root@node1 mariadb]# docker ps -a

容器启动成功

再查看集群状态

node1加入成功

(3)集群全部意外down机,强制找一台节点作为master节点;到如下路径,将 safe_to_bootstrap: 0修改为1(平时集群正常时,每个节点都为0)

将node1,node2,node3全部宕机

[root@d ~]# ansible all -m shell -a 'shutdown -h now'

然后,再将三台机子开机恢复

[root@d ~]# ansible all -m shell -a 'docker ps -a'

cat /opt/mariadb/master.sh

docker run -d --net host --name galera1 \

-e WSREP_NODE_ADDRESS=192.168.88.51 \

-e WSREP_CLUSTER_ADDRESS=gcomm://192.168.88.51:4567,192.168.88.52:4567,192.168.88.53:4567 \

-e MYSQL_ROOT_PASSWORD=123 \

-p 3306:3306 \

-p 4567:4567/udp \

-p 4567-4568:4567-4568 \

-p 4444:4444 \

-v /opt/mariadb/config/mysql:/etc/mysql \ # 配置文件所处的位置

-v /opt/mariadb/config/data:/var/lib/mysql:Z \ #数据库表数据,临时数据,数据库集群,运行状态集群

--restart=always \

panubo/mariadb-galera mysqld --wsrep-new-cluster

选择一台虚拟机作为master节点

[root@node1 ~]# cd /opt/mariadb/config/data/

[root@node1 data]# vim grastate.dat

[root@node1 data]# docker stop galera1

galera1

[root@node1 data]# docker rm galera1

galera1

[root@node1 mariadb]# vim master.sh

[root@node1 mariadb]# sh master.sh

登陆节点查看数据库集群状态

[root@d ~]# mysql -h node1 -uroot -p123

MariaDB [(none)]> SHOW STATUS LIKE 'wsrep_cluster_size';

添加成功

Ansible-galera的更多相关文章

  1. Docker 版ansible galera集群

    1. 部署galera集群 利用四台主机cicd.node1.node2.node3来搭建galera集群. 1> 上传压缩包至cicd,解压得到ansible配置文件 [root@cicd ~ ...

  2. ansible无网络安装openstack(Newton)

    概要 apt使用本地源,pip使用本地源 网络环境 物理机环境 网络名 网络地址 VLAN br-ex 192.168.200.250/24 90 br-mgmt 92.0.0.100/24 92 a ...

  3. 如何利用ansible callback插件对执行结果进行解析

    最近在写一个批量巡检工具,利用ansible将脚本推到各个机器上执行,然后将执行的结果以json格式返回来. 如下所示: # ansible node2 -m script -a /root/pyth ...

  4. 《Ansible权威指南》笔记(2)——Inventory配置

    四.Inventory配置ansible通过Inventory来定义主机和组,使用时通过-i指定读取,默认/etc/ansible/hosts.可以存在多个Inventory,支持动态生成.1.定义主 ...

  5. useful Ansible commands

    This article includes some useful Ansible commands. I will try to write blogs by English. You may wa ...

  6. 《Ansible权威指南》笔记(4)——Playbook

    七.Playbook1.语法特性如下:(1)"---"首行顶格开始(2)#号注释(3)缩进统一,不同的缩进代表不同的级别,缩进要对齐,空格和tab不能混用(4)区别大小写,键值对k ...

  7. 《Ansible权威指南》笔记(3)——Ad-Hoc命令集,常用模块

    五.Ad-Hoc命令集1.Ad-Hoc命令集通过/usr/bin/ansible命令实现:ansible <host-pattern> [options]    -v,--verbose  ...

  8. 《Ansible权威指南》笔记(1)——安装,ssh密钥登陆,命令

    2016-12-23 读这本<Ansible权威指南>学习ansible,根据本书内容和网上的各种文档,以及经过自己测试,写出以下笔记.另,这本书内容很好,但印刷错误比较多,作者说第二版会 ...

  9. 自动化运维工具ansible部署以及使用

    测试环境master 192.168.16.74webserver1 192.168.16.70webserver2 192.168.16.72安装ansiblerpm -Uvh http://ftp ...

  10. Ansible Ubuntu 安装部署

    一.安装: $ sudo apt-get install ansible 二.配置: a.基本配置 $ cd /etc/ansible/ $ sudo cp hosts hosts_back 备份一个 ...

随机推荐

  1. Ubuntu 18.04实现实时显示网速

    1.添加源 sudo add-apt-repository ppa:fossfreedom/indicator-sysmonitor 2.更新源 sudo apt-get update 3.安装sys ...

  2. 微信小程序 base64ToArrayBuffer

    base64ToArrayBuffer 将 base64 的字符串转化为 ArrayBuffer 对象 示例代码: 使用位置:在 JS文件的任意函数中使用 const base64 = 'CxYh'; ...

  3. 服务器上的UID按钮

    定位用的,比如你机柜上有很多台机器,你在前面按下UID灯,机器后面也有一个UID灯会亮起来,这样当你到后面去的时候你就知道刚才在前面看的是哪一台,另外,有人通过ILO远程端口连接到你的服务器的时候,U ...

  4. 编辑器 --- Visual Studio Code 英文界面转换成中文(简体)

    打开编辑器 同时按下Ctrl+Shift+P打开命令面板: 之后输入"config"筛选可用命令表,最后选择配置语言命令进行选择或安装插件

  5. swoole 协程channel乱测

    channel和数组差不多,可以被用作队列,属性capacity是设置容量,isEmpty() isFull() 用来判断队列是空还是满,push()加入队列 pop()弹出队列 interface ...

  6. Bootstrap-轮播图-No.7

    <!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8&quo ...

  7. mySql数据重复数据去重

    1.问题来源:数据中由于并发问题,数据存在多次调用接口,插入了重复数据,需要根据多条件删除重复数据: 2.参考博客文章地址:https://www.cnblogs.com/jiangxiaobo/p/ ...

  8. 第二个爬虫之爬取知乎用户回答和文章并将所有内容保存到txt文件中

    自从这两天开始学爬虫,就一直想做个爬虫爬知乎.于是就开始动手了. 知乎用户动态采取的是动态加载的方式,也就是先加载一部分的动态,要一直滑道底才会加载另一部分的动态.要爬取全部的动态,就得先获取全部的u ...

  9. OBDSTAR X300 PRO3详细评论

    OBDSTAR 公司的X300 PRO3钥匙主控系统具有SKP900的防盗锁钥匙编程功能,以及新功能,例如,测速计调节,EEPROM / PIC和OBDII.它的风格完全符合工业惯例,例如,它采用双边 ...

  10. 2 MVC设计模式

    0 基础知识 (1)B/S与C/S结构 C/S(客户机/服务器 client/service):分为客户机和服务器两层,应用软件安装在客户端通过网络与服务器通信 B/S(liulanq/服务器 bro ...