我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MYSQL高可用之PXC

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MYSQL高可用之PXC

简介

Percona XtraDB Cluster是针对MySQL用户的高可用性和扩展性解决方案,基于Percona Server 。其包括了Write Set REPlication补丁,使用Galera 2.0库,这是一个针对事务性应用程序的同步多主机复制插件。

Percona XtraDB Cluster特点:

  (1)同步复制,事务在所有集群节点要么同时提交,要么不提交。

  (2)多主复制,可以在任意一个节点写入。

  (3)从服务器上的并行应用事件,真正的“并行复制”。

  (4)自动配置节点。

  (5)数据一致性,没有不同步的从服务器。

pxc框架图

MYSQL高可用之PXC

优点总结:

  1. 可以达到时时同步,无延迟现象发生

  2. 完全兼容MySQL

  3. 对于集群中新节点的加入,维护起来很简单

  4. 数据的强一致性

不足之处总结:

  1. 只支持Innodb存储引擎

  2. 最大的缺点是多写问题,最短板性能上限问题

  3. 在线DDL语句,锁表问题

  4. sst针对新节点加入的传输代价过高的问题

测试场景测试:

  1. 在我们硬件水平是256G内存,32核CPU,SSD硬件,单行数据大概1K,单表1千万,512表。 QPS在2.5k写+5K读时,就会有节点同步阻塞问题。当时我们临时切成只读(不执行写SQL)10分钟后,才缓解过来。写queue配置参数在下面。

  2. 建议场景:低写QPS的DB,使用PXC集群,以防硬件故障,达到高可用。


一、环境准备

1、系统环境

[root@master ~]# cat /etc/redhat-release

CentOS Linux release 7.5.1804 (Core)

MYSQL高可用之PXCMYSQL高可用之PXC

2、数据库环境

数据库IP地址

数据库版本

主机名

server_id

192.168.56.129

master

129

192.168.56.130

slave1

130

192.168.56.131

slave2

131

3、注意事项

暂时关闭防火墙和selinux服务

使用端口 3306 、4444、4567、4568

二、搭建(yum安装)(三台都要)

1、安装percona环境

1.1、配置yum源

[root@master ~]# yum install http://www.percona.com/downloads/percona-release/redhat/0.1-4/percona-release-0.1-4.noarch.rpm

[root@master ~]# yum install perl-IO-Socket-SSL perl-DBD-MySQL perl-Time-HiRes socat nc openssl -y

1.3、下载安装Percona-XtraDB-Cluster

[root@master ~]# yum install -y libaio*

[root@master ~]# yum groupinstall -y 'Development tools'

[root@master ~]# yum install -y libssl.so.6

[root@master lib64]# ln -sf /usr/lib64/libssl.so.10 /usr/lib64/libssl.so.6

[root@master lib64]# ln -sf /usr/lib64/libcrypto.so.10 /usr/lib64/libcrypto.so.6

yum安装

[root@master ~]# yum install Percona-XtraDB-Cluster-57

MYSQL高可用之PXCMYSQL高可用之PXC

2、启动服务

[root@master ~]# systemctl start mysqld.service (第一个节点启动方式不一样)

查看默认密码

[root@master ~]# grep "temporary password" /var/log/mysqld.log

3、登录数据库修改

MYSQL高可用之PXCMYSQL高可用之PXC

mysql> alter user 'root'@'localhost' identified by 'Jsq@2018';

Query OK, 0 rows affected (0.00 sec)

mysql> flush privileges;

Query OK, 0 rows affected (0.00 sec)

4、创建sst账号密码(只在第一个节点添加,其他同步即可)

mysql> GRANT RELOAD,LOCK TABLES,PROCESS,REPLICATION CLIENT ON *.* TO 'sstuser1'@'localhost' IDENTIFIED BY '123456';

mysql> FLUSH PRIVILEGES;

MYSQL高可用之PXCMYSQL高可用之PXC

5、配置mysqld.cnf文件

cat /etc/percona-xtradb-cluster.conf.d/mysqld.cnf

默认状态

MYSQL高可用之PXCMYSQL高可用之PXC

现在在/etc/my.cnf第一行添加[mysqld],然后重新启动服务成功(节点2和节点3的也需要参照节点1在配置文件/etc/my.cnf的第一行添加[mysqld])。

master配置如下:

[mysqld]

#!includedir /etc/my.cnf.d/

#!includedir /etc/percona-xtradb-cluster.conf.d/

#PXC

# Path to Galera library

wsrep_provider=/usr/lib64/galera3/libgalera_smm.so

# Cluster connection URL contains the IPs of node#1, node#2 and node#3

wsrep_cluster_address=gcomm://192.168.56.129,192.168.56.130,192.168.56.131

# In order for Galera to work correctly binlog format should be ROW

binlog_format=ROW

# MyISAM storage engine has only experimental support

default_storage_engine=InnoDB

# This changes how InnoDB autoincrement locks are managed and is a requirement for Galera

innodb_autoinc_lock_mode=2

# Node #1 address

wsrep_node_address=192.168.56.129

wsrep_node_name=pxc1

# SST method

wsrep_sst_method=xtrabackup-v2

# Cluster name

wsrep_cluster_name=pxc-cluster

# Authentication for SST method

wsrep_sst_auth="sstuser1:123456"

slave1配置如下:

[mysqld]

#PXC

wsrep_provider=/usr/lib64/galera3/libgalera_smm.so

wsrep_cluster_address=gcomm://192.168.56.129,192.168.56.130,192.168.56.131

binlog_format=ROW

default_storage_engine=InnoDB

innodb_autoinc_lock_mode=2

wsrep_node_address=192.168.56.130

wsrep_node_name=pxc2

wsrep_sst_method=xtrabackup-v2

wsrep_cluster_name=pxc-cluster

wsrep_sst_auth="sstuser1:123456"

slave2配置如下:

[mysqld]

#PXC

wsrep_provider=/usr/lib64/galera3/libgalera_smm.so

wsrep_cluster_address=gcomm://192.168.56.129,192.168.56.130,192.168.56.131

binlog_format=ROW

default_storage_engine=InnoDB

innodb_autoinc_lock_mode=2

wsrep_node_address=192.168.56.131

wsrep_node_name=pxc3

wsrep_sst_method=xtrabackup-v2

wsrep_cluster_name=pxc-cluster

wsrep_sst_auth="sstuser1:123456"

启动第一个节点

[root@master ~]# systemctl start mysql@bootstrap.service

[root@master ~]# systemctl status mysql@bootstrap.service

MYSQL高可用之PXCMYSQL高可用之PXC

[root@master ~]# ss -tnl

MYSQL高可用之PXCMYSQL高可用之PXC

其他节点采用正确方式启动

[root@slave1 ~]# systemctl start mysqld.service

[root@slave2 ~]# systemctl start mysqld.service

6、查看三个节点状态

mysql> show status like '%wsrep%';

MYSQL高可用之PXCMYSQL高可用之PXC

三、测试

在master更新数据

MYSQL高可用之PXCMYSQL高可用之PXC

在slave1更新数据

MYSQL高可用之PXCMYSQL高可用之PXC

在slave2更新数据

MYSQL高可用之PXCMYSQL高可用之PXC

到此即可!!!!!!!!!!!!!!!!!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MYSQL高可用之PXC

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL高可用架构-MMM、MHA、MGR、PXC

主从复制如何工作在主库把数据记录到binlog(二进制日志)。备库开IO线程把binlog复制到自己的relaylog(中继日志)。备库读取中继日志,重放到备库上。半同步复制半同步复制可以确保备库拥有主库数据的拷贝,减少了数据丢失的危险。半同步复制在提交过程中
MySQL高可用架构-MMM、MHA、MGR、PXC
2015-08-21

MySQL高可用架构-MMM、MHA、MGR、PXC(补小结,laoqi)

小结MMM是MHA是MGR是主从复制如何工作在主库把数据记录到binlog(二进制日志)。备库开IO线程把binlog复制到自己的relaylog(中继日志)。备库读取中继日志,重放到备库上。半同步复制半同步复制可以确保备库拥有主库数据的拷贝,减少了数据丢失的
MySQL高可用架构-MMM、MHA、MGR、PXC(补小结,laoqi)
2019-01-17

MySQL 高可用之MMM

原文地址:
MySQL 高可用之MMM
2021-09-05

PXC高可用数据库安装部署

说明Percona XtraDB Cluster(简称PXC),是由percona公司推出的mysql集群解决方案。特点是每个节点都能进行读写,且都保存全量的数据。也就是说在任何一个节点进行写入操作,都会同步给其它所有节点写入到自己的磁盘。这点跟Oracle

	PXC高可用数据库安装部署
2021-03-14

MySQL高可用架构之MHA

一、MHA介绍  MHA(Master High Availability)目前在MySQL高可用方面是一个相对成熟的解决方案,它由日本DeNA公司youshimaton(现就职于Facebook公司)开发,是一套优秀的作为MySQL高可用性环境下故障切换和主
MySQL高可用架构之MHA
2019-01-11

MySQL高可用篇之MHA集群

1 准备工作1.1 修改主机名vim /etc/hosts# 添加对应主机192.168.28.128 mha1192.168.28.131 mha2192.168.28.132 mha31.2 关闭防火墙及修改selinux# 关闭防火墙systemctl
MySQL高可用篇之MHA集群
2016-10-07

编程热搜

目录