原理:多个msyql/mariadb之间可以实时同步,任意节点的操作可以立即同步到其他节点,底层采用galera插件同步,类似rsync,上层mysql相对于galera是透明的,可以实现多节点同时读写(无法实现读写分离)。

NOTE:普通的msyql/mariadb无法集成galera,要想使用galera必须编译msyql/mariadb让其拥有调用galera 的能力,或者可以直接下载支持galera的mysql/mariadb。

环境:

1.采用三节点

节点一:192.168.85.136

节点二:192.168.85.137

节点三:192.168.85.138

2.系统平台:

Red Hat Enterprise Linux Server release 6.7 (Santiago)

3.关闭防火墙(所有节点执行)

/etc/rc.d/init.d/iptables stop

setenforce 0

4.设置galera.repo

http://releases.galeracluster.com//mysql-wsrep-5.5/redhat/6/x86_64/      #mysql-server软件包
http://releases.galeracluster.com//galera-3/redhat/6/x86_64/                   #galera组件

将上面地址加入yum repo

5.查看libgalera_smm.so路径(mysql 会调用此模块像其他节点同步数据)

rpm -ql galera-3-25.3.25-2.el6.x86_64 | grep smm.so

/usr/lib64/galera-3/libgalera_smm.so

6.配置my.cnf

[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock wsrep_node_name=node1
wsrep_provider=/usr/lib64/galera-/libgalera_smm.so
wsrep_sst_method=rsync
port=
user=mysql
default_storage_engine=InnoDB
innodb_autoinc_lock_mode=
innodb_locks_unsafe_for_binlog=
innodb_flush_log_at_trx_commit=
innodb_doublewrite=
innodb_file_per_table=
binlog_format=ROW
log-bin=mysql-bin
server-id=
relay-log=mysql-relay-bin
log-slave-updates=
symbolic-links= [mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

三个节点全部同步此配置文件,需注意:

wsrep_node_name=node1     #配置成节点node名称
wsrep_provider=/usr/lib64/galera-3/libgalera_smm.so    #就是刚才我们查出的模块路径

7.启动mysql:
node1:service mysql start --wsrep_cluster_address=gcomm://
node2:service mysql start --wsrep_cluster_address=gcomm://192.168.85.136
node3:service mysql start --wsrep_cluster_address=gcomm://192.168.85.137 8.验证:
在node1上创建数据库:


在其余node查看:

node2:

node3:

接下来可以将集群信息写入到my.cnf
在每个节点中my.cnf 文件mysqld段中加入:
wsrep_cluster_address="gcomm://192.168.85.136,192.168.85.137,192.168.85.138" ################################################################################
排错:
  启动mysql出现without updating PID file (/var/lib/mysql/node1.pid):
解决:
  注释my.cnf中
wsrep_cluster_address="gcomm://192.168.85.136,192.168.85.137,192.168.85.138"
启动第一个node:
  /etc/rc.d/init.d/mysql start --wsrep_cluster_address=gcomm://
启动第二个node:
/etc/rc.d/init.d/mysql start --wsrep_cluster_address=gcomm://192.168.85.136
启动第三个node:
  /etc/rc.d/init.d/mysql start --wsrep_cluster_address=gcomm://192.168.85.136
全部启动完成后将
wsrep_cluster_address="gcomm://192.168.85.136,192.168.85.137,192.168.85.138" 加入到每个节点中 NOTE:导致上述问题的原因未知,也未去深入研究,只要三个节点不同时启动就不会有问题,如果三个节点同时启动就会出现上述问题(重启三节点任意一个节点不会出现任何问题)。
 

mysql 多主的更多相关文章

  1. mySQL 中主键值自动增加

    转  http://stevenjohn.iteye.com/blog/976397 MySql 主键自动增长 博客分类: DataBase MySQLSQL  创建数据库,创建表. mysql> ...

  2. MySQL双主(主主)架构方案

    在企业中,数据库高可用一直是企业的重中之重,中小企业很多都是使用mysql主从方案,一主多从,读写分离等,但是单主存在单点故障,从库切换成主库需要作改动.因此,如果是双主或者多主,就会增加mysql入 ...

  3. 分布式数据存储 - MySQL双主复制

    上篇文章<分布式数据存储 - MySQL主从复制>,我们说到MySQL主从复制很好的保障了从库,读的高可用性.so,问题来了: 1.针对主库,写的高可用性又是如何做到高可用性? 2.如果需 ...

  4. MySQL双主配置

    MySQL双主配置 准备环境:服务器操作系统为RHEL6.4 x86_64,为最小化安装.主机A和主机B均关闭防火墙和SELINUX ,IP地址分别为192.168.131.129和192.168.1 ...

  5. Mysql增加主键或者更改表的列为主键的sql语句

                                                                                                        ...

  6. Keepalived+MySQL双主

    一.Keepalived+MySQL Replication的应用场景 MySQL的高可用方案有cluster,MMM,MHA等,这些高可用方案都要三台服务器以上,成本有点高,今天介绍一个低成本高可用 ...

  7. keepalived+mysql双主复制高可用方案

    MySQL双主复制,即互为Master-Slave(只有一个Master提供写操作),可以实现数据库服务器的热备,但是一个Master宕机后不能实现动态切换.而Keepalived通过虚拟IP,实现了 ...

  8. MySQL集群(四)之keepalived实现mysql双主高可用

    前面大家介绍了主从.主主复制以及他们的中间件mysql-proxy的使用,这一篇给大家介绍的是keepalived的搭建与使用! 一.keepalived简介 1.1.keepalived介绍 Kee ...

  9. 配置mysql为主主复制步骤

    mysql版本:mysql-5.6.24-solaris10-sparc-64bit.tar 操作系统:solaris 11g u10 操作用户:使用非root进行操作安装,a路服务器ip地址为192 ...

  10. MYSQL 双主配置

    MYSQL1. 版本号:5.7.243. 部署方式:双主部署,两台机器即是主又是备 ,双向拷贝,可以同时写入.4. 安装部署路径: a) /home/softb) 配置路径 /etc/my.cnfc) ...

随机推荐

  1. oracle启动的三个阶段

    startup nomount 时,数据库状态为 started; alter database mount 时, 状态为 mounted; alter database open 时,状态为 ope ...

  2. Gogs基本使用介绍

    Gogs简介 Gogs 是一款类似GitHub的开源文件/代码管理系统(基于Git),Gogs 的目标是打造一个最简单.最快速和最轻松的方式搭建自助 Git 服务.使用 Go 语言开发使得 Gogs ...

  3. UVA12171-Sculpture(离散化+floodfill)

    Problem UVA12171-Sculpture Accept: 196  Submit: 1152 Time Limit: 3000 mSec Problem Description Imagi ...

  4. 数位dp小练

    最近刷题的同时还得填填坑,说来你们也不信,我还不会数位dp. 照例推几篇博客: 数位DP讲解 数位dp 的简单入门 这两篇博客讲的都很好,不过代码推荐记搜的形式,不仅易于理解,还短. 数位dp的式子一 ...

  5. 【Java123】Java基础知识点

    https://github.com/xbox1994/2018-Java-Interview 虽说不为面试做准备,仅仅就工作中遇到的很多Java问题,总是模棱两可的擦肩而过,真不是自己的风格. 还是 ...

  6. 转载 多线程实际运用<第七篇>

    多线程实际运用<第七篇> 1.单线程采集100个页面 class Program { static int i = 6991275; static void Main(string[] a ...

  7. B类——Stas and the Queue at the Buffet

    http://codeforces.com/contest/1151/problem/D 题意: n个学生,每个学生都有自己的位置,最后要使

  8. 3分钟学会做智能插座(DIY)

    转载请注明:@小五义http://www.cnblogs.com/xiaowuyiQQ群:64770604 感谢博达科技提供的技术支持,博达科技新出了turnip智能插座,通过微信控制,实现了语音控制 ...

  9. MySQL(四)字段及常用函数

    一.字段 数据库表中的每一行叫做一个“记录”,每一个记录包含这行中的所有信息,但记录在数据库中并没有专门的记录名,常常用它所在的行数表示这是第几个记录. 在数据库中存放在表行列交叉处的数据叫做“值”, ...

  10. SkylineGlobe6.5版本,在矿山、石油、天然气等能源行业的最新应用DEMO演示

    SkylineGlobe6.5版本,在矿山.石油.天然气等能源行业的最新应用DEMO演示: http://v.youku.com/v_show/id_XNTc3Njc1OTEy.html 一个Pres ...