PXC简介

Percona XtraDB Cluster(简称PXC集群)提供了MySQL高可用的一种实现方法。
1.集群是有节点组成的,推荐配置至少3个节点,但是也可以运行在2个节点上。
2.每个节点都是普通的mysql/percona服务器,可以将现有的数据库服务器组成集群,反之,也可以将集群拆分成单独的服务器。
3.每个节点都包含完整的数据副本。
   PXC集群主要由两部分组成:Percona Server with XtraDB和Write Set Replication patches(使用了Galera library,一个通用的用于事务型应用的同步、多主复制插件)。
PXC特性:
1,同步复制,事务要么在所有节点提交或不提交。
2,多主复制,可以在任意节点进行写操作。
3,在从服务器上并行应用事件,真正意义上的并行复制。
4,节点自动配置,数据一致性,不再是异步复制。
PXC劣势:
    1、 当前版本(5.6.20)的复制只支持InnoDB引擎,其他存储引擎的更改不复制。然而,DDL(Data Definition Language) 语句在statement级别被复制,并且,对mysql.*表的更改会基于此被复制。例如CREATE USER...语句会被复制,但是 INSERT INTO mysql.user...语句则不会。(也可以通过wsrep_replicate_myisam参数开启myisam引擎的复制,但这是一个实验性的参数)。
    2、PXC集群一致性控制机制,事有可能被终止,原因如下:集群允许在两个节点上同时执行操作同一行的两个事务,但是只有一个能执行成功,另一个会被终止,集群会给被终止的客户端返回死锁错误(Error: 1213 SQLSTATE: 40001 (ER_LOCK_DEADLOCK)).
    3、写入效率取决于节点中最弱的一台,因为PXC集群采用的是强一致性原则,一个更改操作在所有节点都成功才算执行成功。

原理描述

分布式系统的CAP理论:
C 一致性,所有的节点数据一致
A 可用性,一个或者多个节点失效,不影响服务请求
P 分区容忍性,节点间的连接失效,仍然可以处理请求
任何一个分布式系统,需要满足这三个中的两个

安装部署

环境描述

三个node节点

node #1
hostname: percona1
IP: 192.168.100.7
node #2
hostname: percona2
IP: 192.168.100.8
node #3
hostname: percona3
IP: 192.168.100.9

基础环境包

可以选择源码或者yum,在此使用yum安装。
三个node节点都要执行以下操作。

基础环境

  1. yum -y groupinstall Base Compatibility libraries Debugging Tools Dial-up Networking suppport Hardware monitoring utilities Performance Tools Development tools
组件安装
  1. yum install http://www.percona.com/downloads/percona-release/redhat/0.1-3/percona-release-0.1-3.noarch.rpm -y
  2. yum install Percona-XtraDB-Cluster-55 -y

数据库配置

选择一个node作为名义上的master,咱们以node1为master,以下操作只在node1上执行。

只需要修改mysql的配置文件--/etc/my.cnf

说明:这里的IP地址是内网地址。

  1. [root@i-kysyolko ~]# cat /etc/my.cnf
  2. # Template my.cnf for PXC
  3. # Edit to your requirements.
  4. [mysqld]
  5. datadir=/var/lib/mysql
  6. user=mysql
  7. # Path to Galera library
  8. wsrep_provider=/usr/lib64/libgalera_smm.so
  9. # Cluster connection URL contains the IPs of node#1, node#2 and node#3
  10. wsrep_cluster_address=gcomm://192.168.100.7,192.168.100.8,192.168.100.9
  11. # In order for Galera to work correctly binlog format should be ROW
  12. binlog_format=ROW
  13. # MyISAM storage engine has only experimental support
  14. default_storage_engine=InnoDB
  15. # This changes how InnoDB autoincrement locks are managed and is a requirement for Galera
  16. innodb_autoinc_lock_mode=2
  17. # Node #1 address
  18. wsrep_node_address=192.168.100.7
  19. # SST method
  20. wsrep_sst_method=xtrabackup-v2
  21. # Cluster name
  22. wsrep_cluster_name=my_centos_cluster
  23. # Authentication for SST method
  24. wsrep_sst_auth="sstuser:s3cret"
  25. [mysqld_safe]
  26. pid-file = /run/mysqld/mysql.pid
  27. syslog
  28. !includedir /etc/my.cnf.d

启动数据库

CentOS6:/etc/init.d/mysql bootstrap-pxc

CentOS7:systemctl start mysql@bootstrap.service

配置数据库

  1. mysql> show status like 'wsrep%';
  2. +----------------------------+--------------------------------------+
  3. | Variable_name | Value |
  4. +----------------------------+--------------------------------------+
  5. | wsrep_local_state_uuid | c2883338-834d-11e2-0800-03c9c68e41ec |
  6. ...
  7. | wsrep_local_state | 4 |
  8. | wsrep_local_state_comment | Synced |
  9. ...
  10. | wsrep_cluster_size | 1 #主要看这里 |
  11. | wsrep_cluster_status | Primary |
  12. | wsrep_connected | ON |
  13. ...
  14. | wsrep_ready | ON |
  15. +----------------------------+--------------------------------------+
  16. 40 rows in set (0.01 sec)
  17. # 数据库用户名密码的设置
  18. mysql@percona1> UPDATE mysql.user SET password=PASSWORD("Passw0rd") where user='root';
  19. # 创建、授权、同步账号
  20. mysql@percona1> CREATE USER 'sstuser'@'localhost' IDENTIFIED BY 's3cret';
  21. mysql@percona1> GRANT RELOAD, LOCK TABLES, REPLICATION CLIENT ON *.* TO 'sstuser'@'localhost';
  22. mysql@percona1> FLUSH PRIVILEGES;

node2、node3节点配置

接下来进行其它节点的配置,上面的组件都已经安装完成。现在直接进行数据库的配置。
只需要修改第26行,当前node的IP地址。两个node都是只是修改这个地址即可。

wsrep_node_address=192.168.100.8

  1. [root@i-kysyolko ~]# cat /etc/my.cnf
  2. # Template my.cnf for PXC
  3. # Edit to your requirements.
  4. [mysqld]
  5. datadir=/var/lib/mysql
  6. user=mysql
  7. # Path to Galera library
  8. wsrep_provider=/usr/lib64/libgalera_smm.so
  9. # Cluster connection URL contains the IPs of node#1, node#2 and node#3
  10. wsrep_cluster_address=gcomm://192.168.100.7,192.168.100.8,192.168.100.9
  11. # In order for Galera to work correctly binlog format should be ROW
  12. binlog_format=ROW
  13. # MyISAM storage engine has only experimental support
  14. default_storage_engine=InnoDB
  15. # This changes how InnoDB autoincrement locks are managed and is a requirement for Galera
  16. innodb_autoinc_lock_mode=2
  17. # Node #1 address
  18. wsrep_node_address=192.168.100.8
  19. # SST method
  20. wsrep_sst_method=xtrabackup-v2
  21. # Cluster name
  22. wsrep_cluster_name=my_centos_cluster
  23. # Authentication for SST method
  24. wsrep_sst_auth="sstuser:s3cret"
  25. [mysqld_safe]
  26. pid-file = /run/mysqld/mysql.pid
  27. syslog
  28. !includedir /etc/my.cnf.d

启动数据库

CentOS6:/etc/init.d/mysql start

CentOS7:systemctl start mysql.service

说明:

1、除了名义上的master之外,其它的node节点只需要启动mysql即可。

2、节点的数据库的登陆和master节点的用户名密码一致,自动同步。所以其它的节点数据库用户名密码无须重新设置。

测试

在任意一个node上,进行操作,然后去其它的节点上看是否取得相同的结果。

官方引用:

https://www.percona.com/doc/percona-xtradb-cluster/5.5/howtos/centos_howto.html

基于PXC的MySQL高可用环境简单部署的更多相关文章

  1. MySQL高可用方案--MHA部署及故障转移

    架构设计及必要配置 主机环境 IP                 主机名             担任角色 192.168.192.128  node_master    MySQL-Master| ...

  2. 基于MHA的MYSQL高可用方案

    一.MHA 简介 MHA (Master High Availability )目前在 MySQL 高可用方面是一个相对成熟的解决方案,它由日本 DeNA 公司的 youshimaton 员工(现就职 ...

  3. 使用KeepAlived搭建MySQL高可用环境

    使用KeepAlived搭建MySQL的高可用环境.首先搭建MySQL的主从复制在Master开启binlog,创建复制帐号,然后在Slave输入命令   2016年7月25日   配置安装技巧:   ...

  4. 基于Keepalived的MySQL高可用

    keepalived负责的是故障转移,至于故障转以后的节点之间数据的一致性问题依赖于具体的复制模式.不管是主从.一主多从还是双主.集群节点个数.主从具体的模式无关(常规复制,半同步复制,GTID复制, ...

  5. 基于keepalived搭建MySQL高可用集群

    MySQL的高可用方案一般有如下几种: keepalived+双主,MHA,MMM,Heartbeat+DRBD,PXC,Galera Cluster 比较常用的是keepalived+双主,MHA和 ...

  6. heatbeat-gui实现基于nfs的mysql高可用集群

    一.简述HA高可用集群 高可用集群就是当集群中的一个节点发生各种软硬件及人为故障时,集群中的其他节点能够自动接管故障节点的资源并向外提供服务.以实现减少业务中断时间,为用户提供更可靠,更高效的服务. ...

  7. MySQL 高可用MHA安装部署以及故障转移详细资料汇总 转

    http://blog.itpub.net/26230597/cid-87082-list-2/ 1,简介 .1mha简介 MHA,即MasterHigh Availability Manager a ...

  8. MySQL之Haproxy+Keepalived+MySQL高可用均衡负载部署 (网络摘抄)

    来源于:https://blog.csdn.net/weisong530624687/article/details/71536837?utm_source=blogxgwz3 一.安装主从MySQL ...

  9. KEEPALIVED+LVS+MYCAT实现MYSQL高可用环境搭建

    一.安装keepalived和ipvsadm 注意:ipvsadm并不是lvs,它只是lvs的配置工具. 为了方便起见,在这里我们使用yum的安装方式 分别在10.18.1.140和10.18.1.1 ...

随机推荐

  1. 为网站添加ico图标

    1.将目标图片装换为.ico格式 在线转换工具:http://www.bitbug.net/ 2.将装换后的图标放入项目文件中,一般命名为favicon 3.在项目文件的index页面中引入 < ...

  2. 与成都的幸福行动家交流GTD

    今年第四次来成都了,通过<小强升职记>的作者邹鑫的撮合,与成都的幸福行动家何平取得了联系,2014年12月6日下午给几个小伙伴们分享了GTD3年来的一点体会.有几位刚接触GTD的朋友,也有 ...

  3. iOS多线程技术

    iOS多线程技术主要分配NSThread.NSOperation和GCD.下边来简单的介绍一下吧. 随性一点,就不按照顺序来了.所以先介绍一下NSOperation. ---------------- ...

  4. Android UI之下拉刷新上拉刷新实现

    在实际开发中我们经常要用到上拉刷新和下拉刷新,因此今天我写了一个上拉和下拉刷新的demo,有一个自定义的下拉刷新控件 只需要在布局文件中直接引用就可以使用,非常方便,非常使用,以下是源代码: 自定义的 ...

  5. IOS之资源收集--很好的github网址

    1.Nick Jensen 2.关于直播的

  6. 阿里云ECS/Ubuntu Server安装Gnome图形桌面

    一.配置好Source源列表 可以参考:http://blog.csdn.net/xukai871105/article/details/24887245 另附一个比较好方便的Source源更新方法: ...

  7. ruby 删除文件

    f = "app/assets/#{vm.uuid}.rrd" if FileTest::exist?(f) File.delete(f) end

  8. SIEBEL应用概述

    Siebel CRM是围绕客户关系管理这个主题建立起来的一系列应用的总和,和一些国内公司的CRM/CALL CENTER产品不一样,Siebel应用远远不是只是接一些电话然后记录下来并进行处理这么简单 ...

  9. Effective Java 14 In public classes, use accessor methods, not public fields

    Principle To offer the benefits of encapsulation you should always expose private field with public ...

  10. Effective Java 38 Check parameters for validity

    For public methods, use the Javadoc @throws tag to document the exception that will be thrown if a r ...