Ansible-galera

在四台虚拟机上都安装好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的更多相关文章
- Docker 版ansible galera集群
1. 部署galera集群 利用四台主机cicd.node1.node2.node3来搭建galera集群. 1> 上传压缩包至cicd,解压得到ansible配置文件 [root@cicd ~ ...
- ansible无网络安装openstack(Newton)
概要 apt使用本地源,pip使用本地源 网络环境 物理机环境 网络名 网络地址 VLAN br-ex 192.168.200.250/24 90 br-mgmt 92.0.0.100/24 92 a ...
- 如何利用ansible callback插件对执行结果进行解析
最近在写一个批量巡检工具,利用ansible将脚本推到各个机器上执行,然后将执行的结果以json格式返回来. 如下所示: # ansible node2 -m script -a /root/pyth ...
- 《Ansible权威指南》笔记(2)——Inventory配置
四.Inventory配置ansible通过Inventory来定义主机和组,使用时通过-i指定读取,默认/etc/ansible/hosts.可以存在多个Inventory,支持动态生成.1.定义主 ...
- useful Ansible commands
This article includes some useful Ansible commands. I will try to write blogs by English. You may wa ...
- 《Ansible权威指南》笔记(4)——Playbook
七.Playbook1.语法特性如下:(1)"---"首行顶格开始(2)#号注释(3)缩进统一,不同的缩进代表不同的级别,缩进要对齐,空格和tab不能混用(4)区别大小写,键值对k ...
- 《Ansible权威指南》笔记(3)——Ad-Hoc命令集,常用模块
五.Ad-Hoc命令集1.Ad-Hoc命令集通过/usr/bin/ansible命令实现:ansible <host-pattern> [options] -v,--verbose ...
- 《Ansible权威指南》笔记(1)——安装,ssh密钥登陆,命令
2016-12-23 读这本<Ansible权威指南>学习ansible,根据本书内容和网上的各种文档,以及经过自己测试,写出以下笔记.另,这本书内容很好,但印刷错误比较多,作者说第二版会 ...
- 自动化运维工具ansible部署以及使用
测试环境master 192.168.16.74webserver1 192.168.16.70webserver2 192.168.16.72安装ansiblerpm -Uvh http://ftp ...
- Ansible Ubuntu 安装部署
一.安装: $ sudo apt-get install ansible 二.配置: a.基本配置 $ cd /etc/ansible/ $ sudo cp hosts hosts_back 备份一个 ...
随机推荐
- C# 接口的作用浅谈举例(转)
转:http://blog.csdn.net/liuqinghui1990/article/details/77171051 我初次接触接口(Interface),对接口的作用有点迷茫,C#接口中包含 ...
- JavaScript教程——实例对象与 new 命令
典型的面向对象编程语言(比如 C++ 和 Java),都有“类”(class)这个概念.所谓“类”就是对象的模板,对象就是“类”的实例.但是,JavaScript 语言的对象体系,不是基于“类”的,而 ...
- Spring-简介-IOC理论推导
1.Spring 1.1.简介 Spring:春天----->给软件行业带来了春天! 2002,首次推出了Spring框架的雏形:interface21框架! Spring框架即以interfa ...
- connect: network is unreachable
解决方法: 在确保完善网卡驱动,以及确保将网卡驱动编译进内核后,检查 ls /etc/sysconfig/network-script/ifcfg-eth0 一.看是否在上述目录下存在ifcfg-et ...
- tar命令--数据解档(三)解压.tar.gz文件报错 gzip:stdin:not in gzip format
毕竟是生产..... 提示以下信息: gzip: stdin: not in gzip format tar: Child returned status 1 tar: Error is not ...
- Codeforces Round #586 (Div. 1 + Div. 2) A. Cards
链接: https://codeforces.com/contest/1220/problem/A 题意: When Serezha was three years old, he was given ...
- jmeter-post请求自动变成get,提示请求方式错误,修改协议即可
修改协议: http 改为 https 或反之
- msyql笔记
CREATE TABLE class ( cid int(11) NOT NULL AUTO_INCREMENT, caption varchar(32) NOT NULL, PRIMARY KEY ...
- Flutter常见数据类型及数据类型转换
简介 既然 Dart 是一门语言,那么就和我们所知道语言一样,有基本的数据类型以及常见的流程处理语法,那么我们就来了解下. Dart 的所有东西都是对象,包括数字,函数等.它们都继承自 Object ...
- QObject 的拷贝构造和赋值操作
QOject 中没有提供一个拷贝构造函数和赋值操作符给外界使用,其实拷贝构造和赋值的操作都是已经声明了的,但是它们被使用了Q_DISABLE_COPY () 宏放在了private区域.因此所有继承自 ...