转载来源:https://blog.csdn.net/robinson_0612/article/details/78962190

基于CentOS 7 安装Percona XtraDB Cluster(PXC) 5.7

Percona XtraDB Cluster(简称PXC)是很多企业基于MySQL实现集群方案的不二选择。PXC它支持服务高可用,数据同步复制(并发复制),几乎无延迟;多个可同时读写节点,可实现写扩展等等。之前整理过一篇PXC 5.6的文章,本文是基于CentOS 7 PXC 5.7版一个更为标准的安装,可供大家参考。

一、当前OS环境

[root@node142 ~]# more /etc/redhat-release
CentOS Linux release 7.2.1511 (Core)

二、配置运行环境

1、修改主机hosts文件

[root@node142 ~]# vim /etc/hosts
127.0.0.1 localhost.localdomain localhost
192.168.81.142 node142.example.com node142
192.168.81.146 node146.example.com node146
192.168.81.147 node147.example.com node147

2、修改selinux配置文件

[root@node142 ~]# vim /etc/selinux/config
SELINUX=disabled

3、分发配置文件到其余节点

[root@node142 ~]# scp /etc/hosts 192.168.81.146:/etc/hosts
[root@node142 ~]# scp /etc/hosts 192.168.81.147:/etc/hosts
[root@node142 ~]# scp /etc/selinux/config 192.168.81.146:/etc/selinux/config
[root@node142 ~]# scp /etc/selinux/config 192.168.81.147:/etc/selinux/config

4、分别3节点配置防火墙,如下示例(仅列出一个节点)

[root@node142 ~]# firewall-cmd --add-port=3306/tcp --permanent
[root@node142 ~]# firewall-cmd --add-port=4567/tcp --permanent
[root@node142 ~]# firewall-cmd --add-port=4568/tcp --permanent
[root@node142 ~]# firewall-cmd --add-port=4444/tcp --permanent
[root@node142 ~]# firewall-cmd --reload

5、配置时间同步服务

[root@node248 ~]# crontab -e
*/10 * * * * ntpdate ntp3.aliyun.com

6、分别重启3节点

[root@node142 ~]# reboot
[root@node146 ~]# reboot
[root@node147 ~]# reboot 

三、安装Percona XtraDB Cluster 5.7

1、3节点分别安装Percona XtraDB Cluster 5.7 (如下示例)

[root@node142 ~]# rpm -Uvh https://www.percona.com/downloads/percona-release/redhat/latest/percona-release-0.1-4.noarch.rpm
[root@node142 ~]# yum install Percona-XtraDB-Cluster-57 -y

yum安装时会提示UDFs功能,根据需要可以在mysql启动后执行以下语句

Percona XtraDB Cluster is distributed with several useful UDFs from Percona Toolkit.
Run the following commands to create these functions:
mysql -e "CREATE FUNCTION fnv1a_64 RETURNS INTEGER SONAME 'libfnv1a_udf.so'"
mysql -e "CREATE FUNCTION fnv_64 RETURNS INTEGER SONAME 'libfnv_udf.so'"
mysql -e "CREATE FUNCTION murmur_hash RETURNS INTEGER SONAME 'libmurmur_udf.so'"

四、配置mysql及集群配置文件

主要包括mysqld.cnf,mysqld_safe.cnf,wsrep.cnf 
在当前的这个版本中,my.cnf为主配置文件,其余的配置文件放在/etc/percona-xtradb-cluster.conf.d目录 
在这几个配置文件中,大家根据自己的需要定制,本演示仅作基本修改

1、备份配置文件

[root@node142 ~]# cp /etc/percona-xtradb-cluster.conf.d/mysqld.cnf{,.org}
[root@node142 ~]# cp /etc/percona-xtradb-cluster.conf.d/mysqld_safe.cnf{,.org}
[root@node142 ~]# cp /etc/percona-xtradb-cluster.conf.d/wsrep.cnf{,.org}

2、修改配置文件

[root@node142 ~]# vim /etc/percona-xtradb-cluster.conf.d/mysqld.cnf
[root@node142 ~]# more /etc/percona-xtradb-cluster.conf.d/mysqld.cnf
# Template my.cnf for PXC
# Edit to your requirements.[client]
socket=/var/lib/mysql/mysql.sock[mysqld]
server-id=142    #这个参数3个节点要使用不同的id
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
log-bin=/var/lib/mysqlbin
log_slave_updates
expire_logs_days=7
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
log_bin_trust_function_creators=on
character_set_server = utf8  ##Author : Leshami
collation_server = utf8_bin  ##Blog : http://blog.csdn.net/leshami
[root@node142 ~]# vim /etc/percona-xtradb-cluster.conf.d/wsrep.cnf
[root@node142 ~]# grep -vE "^#|^$" /etc/percona-xtradb-cluster.conf.d/wsrep.cnf
[mysqld]
wsrep_provider=/usr/lib64/galera3/libgalera_smm.so
wsrep_cluster_address=gcomm://192.168.81.142,192.168.81.146,192.168.81.147
binlog_format=ROW
default_storage_engine=InnoDB
wsrep_slave_threads= 8
wsrep_log_conflicts
innodb_autoinc_lock_mode=2
wsrep_node_address=192.168.81.142 ##这个参数要改成相应的IP
wsrep_cluster_name=pxc-cluster
wsrep_node_name=node142               ##这个参数要改成相应的节点名称
pxc_strict_mode=PERMISSIVE
wsrep_sst_method=xtrabackup-v2
wsrep_sst_auth="sstuser:s3cretPass"

3、修改剩余节点配置文件

[root@node142 ~]# cp /etc/percona-xtradb-cluster.conf.d/mysqld.cnf{,.146}
[root@node142 ~]# cp /etc/percona-xtradb-cluster.conf.d/mysqld.cnf{,.147}
[root@node142 ~]# cp /etc/percona-xtradb-cluster.conf.d/wsrep.cnf{,.146}
[root@node142 ~]# cp /etc/percona-xtradb-cluster.conf.d/wsrep.cnf{,.147}
[root@node142 ~]# vim /etc/percona-xtradb-cluster.conf.d/mysqld.cnf.146  #修改对应的server_id
[root@node142 ~]# vim/etc/percona-xtradb-cluster.conf.d/mysqld.cnf.147  #修改对应的server_id# 以下操作,分别修改wsrep_node_name,wsrep_node_address至相应的节点名称以及IP地址
[root@node142 ~]# vim /etc/percona-xtradb-cluster.conf.d/wsrep.cnf.146
[root@node142 ~]# vim  /etc/percona-xtradb-cluster.conf.d/wsrep.cnf.147

4、比较配置文件,并将配置文件分发到各个节点

[root@node142 ~]# cd /etc/percona-xtradb-cluster.conf.d/
[root@node142 percona-xtradb-cluster.conf.d]# diff mysqld.cnf mysqld.cnf.146
7c7
< server-id=142
---
> server-id=146
[root@node142 percona-xtradb-cluster.conf.d]# diff mysqld.cnf mysqld.cnf.147
7c7
< server-id=142
---
> server-id=147
[root@node142 percona-xtradb-cluster.conf.d]# diff wsrep.cnf wsrep.cnf.146
28c28
< wsrep_node_address=192.168.81.142
---
> wsrep_node_address=192.168.81.146
32c32
< wsrep_node_name=node142
---
> wsrep_node_name=node146
[root@node142 percona-xtradb-cluster.conf.d]# diff wsrep.cnf wsrep.cnf.147
28c28
< wsrep_node_address=192.168.81.142
---
> wsrep_node_address=192.168.81.147
32c32
< wsrep_node_name=node142
---
> wsrep_node_name=node147[root@node142 percona-xtradb-cluster.conf.d]# scp mysqld.cnf.146 node146:/etc/percona-xtradb-cluster.conf.d/mysqld.cnf
[root@node142 percona-xtradb-cluster.conf.d]# scp wsrep.cnf.146 node146:/etc/percona-xtradb-cluster.conf.d/wsrep.cnf
[root@node142 percona-xtradb-cluster.conf.d]# scp mysqld.cnf.147 node147:/etc/percona-xtradb-cluster.conf.d/mysqld.cnf
[root@node142 percona-xtradb-cluster.conf.d]# scp wsrep.cnf.147 node147:/etc/percona-xtradb-cluster.conf.d/wsrep.cnf

五、启动PXC集群

1、启动第一个节点

[root@node142 ~]# systemctl start mysql@bootstrap.service
[root@node142 ~]# grep "temporary password" /var/log/mysqld.log
2017-12-28T08:57:24.231185Z 1 [Note] A temporary password is generated for root@localhost: wj!v<z/2)ctZ[root@node142 ~]# mysql -uroot -p
Enter password:
mysql> alter user 'root'@'localhost' identified by '123456';
mysql> create user 'sstuser'@'localhost' identified by 's3cretpass';
mysql> grant reload, lock tables, replication client, process on *.* to 'sstuser'@'localhost';

2、启动剩余节点

[root@node146 ~]# systemctl start mysql
[root@node147 ~]# systemctl start mysql  

注,如果你使用的是CentOS7.2.1511,会发现mysql可以正常启动,但是未加入集群的情况
需要升级openssl,建议全部升级后再启动集群,这问题在CentOS 7.4.1708不存在即openssl版本较新

六、验证集群

在146上完成如下操作

[root@node146 ~]# mysql -uroot -p
mysql> show variables like 'version';
+---------------+--------------+
| Variable_name | Value |
+---------------+--------------+
| version | 5.7.19-17-57 |
+---------------+--------------+
1 row in set (0.00 sec)mysql> create database pxcdb;
mysql> use pxcdb;
mysql> create table t1(id tinyint,ename varchar(20));
mysql> insert into t1 values(1,'Leshami');

在147上进行验证

[root@node147 ~]# mysql -uroot -p
mysql> show databases;
+--------------------+
| Database       |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| pxcdb |
| sys |
+--------------------+
5 rows in set (0.00 sec)mysql> show variables like 'server_id';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| server_id    | 147 |
+---------------+-------+
1 row in set (0.01 sec)mysql> select * from pxcdb.t1;
+------+---------+
| id | ename |
+------+---------+
| 1 | Leshami |
+------+---------+
1 row in set (0.00 sec)

--查看集群状态

mysql> show status like '%wsrep_clust%';
+--------------------------+--------------------------------------+
| Variable_name | Value |
+--------------------------+--------------------------------------+
| wsrep_cluster_conf_id | 13 |  ## Author : Leshami
| wsrep_cluster_size | 3 |         ## Blog : http://blog.csdn.net/leshami
| wsrep_cluster_state_uuid | aeb87793-ebb2-11e7-b33e-eeaf4988bbe4 |
| wsrep_cluster_status | Primary |   ## Weixin/QQ : 645746311
+--------------------------+--------------------------------------+
4 rows in set (0.00 sec)mysql> show status like 'wsrep_connected';
+-----------------+-------+
| Variable_name | Value |
+-----------------+-------+
| wsrep_connected | ON |
+-----------------+-------+
1 row in set (0.00 sec)

七、openssl版本过低导致的错误

2017-12-28T09:23:19.605353Z 0 [ERROR] WSREP: wsrep_load(): dlopen(): /usr/lib64/galera3/libgalera_smm.so:
symbol SSL_COMP_free_compression_methods, version libssl.so.10 not defined in file libssl.so.10 with link time reference
2017-12-28T09:23:19.605379Z 0 [ERROR] WSREP: Failed to load wsrep_provider (/usr/lib64/galera3/libgalera_smm.so).Error: Invalid argument (code: 22). Reverting to no provider.
2017-12-28T09:23:19.605386Z 0 [Note] WSREP: Setting wsrep_ready to false[root@node146 ~]# rpm -qa|grep openssl
openssl-1.0.1e-42.el7.9.x86_64
openssl-libs-1.0.1e-42.el7.9.x86_64
[root@node146 ~]# yum update openssl -y

作者:Leshami   原文:https://blog.csdn.net/leshami/article/details/78962190 

基于CentOS 7 安装Percona XtraDB Cluster(PXC) 5.7相关推荐

  1. CentOS 7 安装 Percona XtraDB Cluster 5.7

    前言 CentOS 7 安装 Percona XtraDB Cluster(PXC) 5.7,记录一下安装过程. 主要安装过程 Percona 的官方文档 Percona XtraDB Cluster ...

  2. Percona XtraDB Cluster(PXC) Mysql 集群

    Percona XtraDB Cluster(PXC)   ---原理介绍篇         目录 一.简介 1 二.优缺点 2 三.区别/局限性 3 四. PXC复制原理 4 五. 服务解释 5   ...

  3. 如何在Debian 8上安装Percona XtraDB Cluster for MySQL

    翻译&转载来源:https://www.howtoforge.com/tutorial/how-to-install-percona-xtradb-cluster-for-mysql/ 在本文 ...

  4. 在CentOS上配置Percona XtraDB集群(Percona XtraDB Cluster)

    原作者:Percona官网 翻译&转载来源:https://www.percona.com/doc/percona-xtradb-cluster/LATEST/howtos/centos_ho ...

  5. Mysql搭建PXC集群 - Percona XtraDB Cluster

    转载来源:https://blog.csdn.net/lvshaorong/article/details/80501905  pxc集群是Percona XtraDB Cluster的缩写,是基于p ...

  6. 如何在CentOS 7上安装Percona XtraDB集群

    原作者:Muhammad Arul  转载&翻译来源:https://www.howtoforge.com/tutorial/how-to-install-percona-xtradb-clu ...

  7. PXC(Percona XtraDB Cluster)集群安装

    作者在2014Oracle数据库嘉年华中有幸听到了关于去哪网的MySQL数据库基于PXC的高可用架构设计主题. MySQL和Oracle是完全不同的两种数据库,Oracle重于管理,而MySQL更重要 ...

  8. Percona XtraDB Cluster 集群参数配置说明(PXC 5.7)

    从PXC5.7版本开始,集群的配置主要是通过wsrep.cnf配置来实现.这个文件有几个常用的参数配置.下文对其做简要说明. 一.PXC 5.7集群配置文件 如果是直接通过yum方式安装,那么配置文件 ...

  9. MySQL高可用方案-PXC(Percona XtraDB Cluster)环境部署详解

    MySQL高可用方案-PXC(Percona XtraDB Cluster)环境部署详解 Percona XtraDB Cluster简称PXC.Percona Xtradb Cluster的实现是在 ...

最新文章

  1. RESTful Web Services in Spring 3(下)转载
  2. 论文阅读——《Robust Superpixel Tracking》
  3. 训练FCN时遇到的问题总结
  4. mysql创建账号并赋予权限
  5. 计算机知识应用,计算机知识应用基础复习大纲
  6. 'staticfiles' is not a registered tag library. Must be one of:
  7. C#调用Python模块
  8. 你会感觉容器使用起来很痛苦吗?
  9. 客户端脚本调用服务器端动态内容,移动到链接显示预览
  10. Java基础学习总结(97)——合格的Java的架构师需要具备的技术知识
  11. windows form参数传递过程
  12. 新泰一中2021年高考成绩查询,牛!泰安新泰一中2018年高考一班级62人全部上本科线...
  13. 如何使用PyTorch torch.max()
  14. 书单丨上过太空的JavaScript用着就是香!
  15. JAVAWeb使用POI做导出Excel
  16. 大数据-Hive开窗函数
  17. 乐高叉车wedo教案_乐高wedo20课程教案
  18. excel根据html生成表头c,excel表头的制作 怎样在Excel里面制作表头?
  19. 小米-测试工程师面试20190418
  20. potplayer默认专辑加载同一文件夹下所有视频,只读取一部分视频,加载视频目录不完整

热门文章

  1. 为 Windows 用户准备的简明 Linux 词汇表
  2. 反应器(Reactor):用于事件多路分离和分派的体系结构模式
  3. restorecon命令
  4. mysql忘记密码恢复
  5. LeetCode刷题(Python)——汉明距离
  6. cookie 原理及应用
  7. ubuntu 使用apt-get install安装特定版本
  8. 【AI视野·今日NLP 自然语言处理论文速览 第二十六期】Wed, 3 Nov 2021
  9. Ubuntu 16.04 开机自动锁定数字键盘
  10. ubuntu 安装软件到一半被中断的解决办法