实施PXC 5.7

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: Percona XtraDB Cluster(简称PXC集群)提供了MySQL高可用的一种实现方法。 PXC集群主要由两部分组成:Percona Server with XtraDB和Write Set Replication patches(使用了Galera library,一个通用的用于事务型应用的同步、多主复制插件)。
Percona XtraDB Cluster(简称PXC集群)提供了MySQL高可用的一种实现方法。
  • PXC集群主要由两部分组成:Percona Server with XtraDB和Write Set Replication patches(使用了Galera library,一个通用的用于事务型应用的同步、多主复制插件)。
  • 集群是有节点组成的,推荐3-8个节点,实际环境一般都是3个节点
  • 每个节点都是普通的mysql/percona服务器,可以将现有的数据库服务器组成集群,反之,也可以将集群拆分成单独的服务器。
  • 每个节点都包含完整的数据副本。

PXC特性:
  • 同步复制,事务要么在所有节点提交或不提交。
  • 多主复制,可以在任意节点进行写操作。
  • 在从服务器上并行应用事件,真正意义上的并行复制。
  • 节点自动配置,数据一致性(基于innodb引擎层),不再是异步复制。

PXC限制:
  • 当前版本(5.6.20)的复制只支持InnoDB引擎,其他存储引擎的更改不复制。然而,DDL(Data Definition Language) 语句在statement级别被复制,并且,对mysql.*表的更改会基于此被复制。wsrep_replicate_myisam实验参数能复制,但是不推荐。例如CREATE USER...语句会被复制,但是DML不会被复制,例如INSERT INTO mysql.user...语句则不会。
  • PXC集群一致性控制机制,事有可能被终止,原因如下:集群允许在两个节点上同时执行操作同一行的两个事务,但是只有一个能执行成功,另一个会被终止,集群会给被终止的客户端返回死锁错误(Error: 1213 SQLSTATE: 40001 (ER_LOCK_DEADLOCK)).
  • 写入效率取决于节点中最弱的一台,因为PXC集群采用的是强一致性原则,一个更改操作在所有节点都成功才算执行成功。
  • 在多主环境下LOCK/UNLOCK TABLES不支持。以及锁函数GET_LOCK(), RELEASE_LOCK()…  lock tables操作不能阻塞其他节点继续更新表,只是本机被lock了失去意义了,而且这个也只是针对myisam才有意义,事务型的存储引擎无意义
  • 允许最大的事务大小由wsrep_max_ws_rows和wsrep_max_ws_size定义。LOAD DATA INFILE processing will commit every 10 000 rows. So large transactions due to LOAD DATA will be split to series of small transactions.
  • DELETE操作不支持没有主键的表。没有主键的表在不同的节点顺序将不同,如果执行SELECT…LIMIT… 将出现不同的结果集。
  • 查询日志不能保存在表中。如果开启查询日志,只能保存到文件中。log_output = FILE
  • XA事务不支持,由于在提交上可能回滚。
  • 如果DDL语句有问题将破坏集群。alter table会锁住全部实例,要么死等,要么关闭一个节点,但是最好的还是用pt-online-schmea-change(还是要避免高峰期)
  • 不支持innodb表空间传输


一、安装软件
1、下载Percona-XtraDB-Cluster-5.7.19-rel17-29.22.3.Linux.x86_64.ssl101.tar.gz
  1. 注意一点:centos要下载带ssl101的安装包
  • ssl100: for all supported Debian and Ubuntu versions
  • ssl101: for supported Red Hat Enterprise Linux derivatives

默认端口
  • 3306
  • 4444
  • 4567
  • 4568

[root@my01 ~]# getenforce
Disabled
[root@my01 ~]# /etc/init.d/iptables status
iptables:未运行防火墙。

官方文档已经没有卸载mysql-lib,还是按照以前方法卸载
rpm -qa|grep mysql-libs|xargs rpm -e --nodeps
需要依赖包
perl-Time-HiRes perl-DBD-MySQL.x86_64 perl-IO-Socket-SSL.noarch  nc libev 
socat 提供 两个独立数据的双向传输之间起到中继作用的软件
Percona-XtraDB-Cluster-galera 提供 / usr / lib64 / libgalera_smm . so tarball的lib目录已经包含了这个库文件,所以路径要记得修改


2、第一个节点修改 /etc/my.cnf
mkdir /data/mysql/pxc3306/{data,logs,tmp} -p
chown mysql.mysql /data/mysql/pxc3306/ -R

#其他参数
#pxc from percona
binlog_format=row
wsrep_provider=/usr/local/mysql/lib/libgalera_smm.so
wsrep_cluster_address=gcomm://10.20.30.101,10.20.30.102,10.20.30.103
default_storage_engine=InnoDB
innodb_autoinc_lock_mode=2
wsrep_node_address=10.20.30.101
wsrep_sst_method=xtrabackup-v2
wsrep_cluster_name=my_pxc_cluster
wsrep_sst_auth="sstuser:sstpwd"
3、启动第一个节点
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql
mysqld --defaults-file=/etc/my.cnf --initialize
cat error.log 查看是否有错误和临时root密码

[root@my01 data]# /etc/init.d/mysql bootstrap-pxc
Bootstrapping PXC (Percona XtraDB Cluster)Starting MySQL (Percona XtraDB Cluster).2018-01-02T09:21:15.749596Z mysqld_safe The file /mnt/workspace/percona-xtradb-cluster-5.7-binary-tarball/label_exp/centos6-64/Percona-XtraDB-Cluster-5.7.19-29.22/374/usr/local/Percona-XtraDB-Cluster-5.7.19-rel17-29.22.3.Linux.x86_64.ssl101/bin/mysqld
does not exist or is not executable. Please cd to the mysql installation
directory and restart this script from there as follows:
./bin/mysqld_safe&
The server quit without updating PID file (/data/mysql/pxc3[失败]ta/mysql.pid).
MySQL (Percona XtraDB Cluster) server startup failed!      [失败]


代码写死了,需要执行替换
cp mysqld_safe mysqld_safe.bak
sed -i 's#/mnt/workspace/percona-xtradb-cluster-5.7-binary-tarball/label_exp/centos6-64/Percona-XtraDB-Cluster-5.7.19-29.22/374/usr/local/Percona-XtraDB-Cluster-5.7.19-rel17-29.22.3.Linux.x86_64.ssl101#/usr/local/mysql#g' /usr/local/mysql/bin/mysqld_safe

/etc/init.d/mysql bootstrap-pxc
centos7应该这样启动   systemctl start mysql@bootstrap.serv ice

mysql -S /tmp/pxc3306.sock -uroot -p
>alter user user() identified by 'gouliping';
>flush privileges;

Akv3y0f4SAEKUIACFKAABShAAQpQgAK1SYCBtdp0


> CREATE USER 'sstuser'@'localhost' IDENTIFIED BY 'sstpwd';
> GRANT RELOAD, LOCK TABLES, REPLICATION CLIENT, PROCESS ON *.* TO 'sstuser'@'localhost';        # 比官方文档中多了PROCESS权限
> FLUSH PRIVILEGES;

mysql -usstuser -psstpwd -e 'show databases'

4、第二个节点配置
  • 修改my.cnf    (改server_uuid和wsrep_node_address)
  • 初始化(不需要修改密码,启动起来后,会同步)
  • 启动
    • cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql
  • /etc/init.d/mysql start

5、第三个节点配置
同第二个节点一样

Abylj5+HEEssAAAAAElFTkSuQmCC

6、建表测试同步

root@ localhost@pxc3306.sock [(none)]>create database pxc;
Query OK, 1 row affected (0.04 sec)

root@ localhost@pxc3306.sock [(none)]>use pxc;
Database changed
root@ localhost@pxc3306.sock [pxc]>create table exp (node_id int primary key,node_name varchar(30));
Query OK, 0 rows affected (0.02 sec)

root@ localhost@pxc3306.sock [pxc]>insert into exp values(1,'my03');
Query OK, 1 row affected (0.01 sec)

root@ localhost@pxc3306.sock [(none)]>select * from pxc.exp;
+---------+-----------+
| node_id | node_name |
+---------+-----------+
|       1 | my03      |
+---------+-----------+
1 row in set (0.00 sec) 
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2月前
|
监控 安全 关系型数据库
在规划阿里云RDS跨区迁移资源和服务可用性
在规划阿里云RDS跨区迁移资源和服务可用性
260 4
|
7月前
|
运维 监控 关系型数据库
OBCP第八章 OB运维、监控与异常处理-灾难恢复
OBCP第八章 OB运维、监控与异常处理-灾难恢复
75 0
|
2月前
|
安全 关系型数据库 MySQL
rds迁移评估与规划
rds迁移评估与规划
36 1
|
2月前
|
监控 容灾 安全
规划阿里云RDS跨区迁移并构建容灾与备份策略
规划阿里云RDS(Relational Database Service)跨区迁移并构建容灾与备份策略
109 2
|
2月前
|
存储 运维 关系型数据库
规划阿里云RDS跨区迁移业务需求业务影响分析
规划阿里云RDS跨区迁移业务需求业务影响分析
24 4
|
运维 网络协议 安全
MySQL PXC 集群运维指南
MySQL PXC 集群运维指南
430 11
|
运维 关系型数据库 MySQL
PXC集群第3个节点无法加入故障处理
PXC集群第3个节点无法加入故障处理
353 0
|
SQL 监控 Cloud Native
MSE 治理中心重磅升级-流量治理、数据库治理、同 AZ 优先
本次 MSE 治理中心在限流降级、数据库治理及同 AZ 优先方面进行了重磅升级,对微服务治理的弹性、依赖中间件的稳定性及流量调度的性能进行全面增强,致力于打造云原生时代的微服务治理平台。
MSE 治理中心重磅升级-流量治理、数据库治理、同 AZ 优先
|
存储 安全 关系型数据库
阿里云DRDS备份策略方案
1. DRDS备份策略初衷 基于很多客户从云下迁移到上云(公共云or专有云)后,DRDS以及后端RDS都已经标准化成产品,默认会存在备份策略保障数据的安全,因此需要进行备份策略的整理,结合当前业务数据的实际情况,在保障数据安全的情况下,尽量节省支出来考虑备份策略; 2.
4565 0
阿里云DRDS备份策略方案
|
容灾
面向失败的设计-故障与攻防演练锤炼容灾应急能力
阿里巴巴经过多年的技术演进,系统工具和架构已经高度垂直化,服务器规模也达到了比较大的体量。当服务规模大于10000台时,小概率的硬件故障每天都会发生。这时如果需要人的干预,系统就无法可靠的伸缩。为此每一层的系统都会面向失败做设计,对下游组件零信任,确保在故障发生时可以快速的发现和处理。
3123 0