Percona Xtradb Cluster 安装
Percona Xtradb Cluster 介绍 Percona XtraDB Cluster 简称:PXC,是针对MySQL 用户的高可用性和扩展性解决方案,基于Percona Server。其包括了Write Set REPlication 补丁,使用Galera库,这是一个针对事务性应用程序的同步多主机复制插件。
Percona XtraDB Cluster特点:
  (1)同步复制,事务在所有集群节点要么同时提交,要么不提交。
  (2)多主复制,可以在任意一个节点写入。
  (3)从服务器上的并行应用事件,真正的“并行复制”。
  (4)自动配置节点。
  (5)数据一致性,没有不同步的从服务器。
 
PXC 安装环境需求
 
环境:
CentOS 6.5 64bits
IP:
192.168.1.88
192.168.1.89
192.168.1.90
 
基本架构:
 

PXC 安装基本步骤
Percona-Xtradb-Cluster
5.6 版本下载
wget http://www.percona.com/downloads/Percona-XtraDB-Cluster-56/Percona-XtraDB-Cluster-5.6.21-25.8/binary/tarball/Percona-XtraDB-Cluster-5.6.21-rel70.1-25.8.938.Linux.x86_64.tar.gz
 
1.安装依赖包:(使用系统光盘配置本地yum源即可)
yum -y install perl perl-devel libaio libaio-devel perl-Time-HiRes perl-DBD-MySQL
 
2.安装软件包percona-xtrabackup:
rpm -ivh percona-xtrabackup-2.3.5-1.el6.x86_64.rpm
 
可能需要依赖软件包libev.
rpm -ivh libev-4.04-2.el6.x86_64.rpm
 
3.安装
创建安装目录
mkdir /usr/local/mysql
tar -xvf  Percona-XtraDB-Cluster-5.6.21-rel70.1-25.8.938.Linux.x86_64.tar.gz
mv  Percona-XtraDB-Cluster-5.6.21-rel70.1-25.8.938.Linux.x86_64  /usr/local/mysql
 
创建mysql 的用户及组
groupadd mysql
useradd -g msyql mysql
创建启动文件:
#cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql
创建mysql 需要的基本目录
mkdir -p /data/mysql/mysql_3306
mkdir -p /data/mysql/mysql_3306/data
mkdir -p /data/mysql/mysql_3306/logs
mkdir -p /data/mysql/mysql_3306/tmp
chown mysql:mysql /data -R
chmod 755  /data -R
./mysql_install_db --user=mysql  --defaults-file=/etc/my.cnf --basedir=/usr/local/mysql/
确认结果正确
 
 
4.PXC 配置
cat /etc/my.cnf
[client]
socket=/data/mysql/mysql_3306/tmp/mysql.sock
port            = 3306
 
[mysqld]
server_id=88
basedir         = /usr/local/mysql
port            = 3306
datadir         = /data/mysql/mysql_3306/data
tmpdir          = /data/mysql/mysql_3306/tmp
socket          = /data/mysql/mysql_3306/tmp/mysql.sock
user=mysql
pid-file=/data/mysql/mysql_3306/data/mysqld.pid
log-error=/data/mysql/mysql_3306/logs/mysql.err
general-log-file=/data/mysql/mysql_3306/logs/mysql.log
slow-query-log-file=/data/mysql/mysql_3306/logs/mysql.log
 
default_storage_engine=InnoDB
innodb_locks_unsafe_for_binlog=1
innodb_autoinc_lock_mode=2
wsrep_cluster_name="mycluster"
#cluster 的名字
wsrep_cluster_address=gcomm://192.168.1.88,192.168.1.89,192.168.1.90
#cluster 中的节点ip
wsrep_node_address=192.168.1.88
#cluster 当前节点的ip
wsrep_provider=/usr/local/mysql/lib/libgalera_smm.so
wsrep_sst_method=rsync
wsrep_sst_auth="sstuser:sstuser"
wsrep_node_name=pxc1
 
 
 
有两个地方需要注意:
1、wsrep_node_address=192.168.1.88 安装每个mysql服务时,需要修改为自身的ip
2、wsrep_sst_method:在刚安装时,需要将slave节点设置为rsync,才能同步成功
每台集群中的mysql服务都按以上的步骤安装即可
 
注意下面几个值根据实际情况设置,3台主机需要设置成不同的值:
server_id=88
wsrep_node_address
wsrep_node_name
 
5.启动
# 首先启动第一节点
修改/etc/init.d/mysql配置文件中basedir和datadir的路径
basedir=/usr/local/mysql
datadir=/data/mysql/mysql_3306/data
/etc/init.d/mysql bootstrap-pxc  --wsrep-cluster-address="gcomm://"
tail -f /data/mysql/mysql_3306/logs/mysql.log                                   ----- 观察错误日志
 
# 以上述方式启动完第一个节点后,用命令service mysql start依次启动第二和第三个节点。当全部节点启动完毕后,# 再回过来把第一个节点service mysql restart重新启动。这是因为在集群节点全部关闭状态下,第一个启动的节点# 必须以gcomm://方式启动。
/etc/init.d/mysql start
/etc/init.d/mysql start
/etc/init.d/mysql restart
 
6.验证是否配置成功:
mysql> show global status like 'wsrep_cluster_size';
+--------------------+-------+
| Variable_name      | Value |
+--------------------+-------+
| wsrep_cluster_size | 3     |
+--------------------+-------+
1 row in set (0.00 sec)
 
mysql> show global status like 'wsrep_incoming_addresses';
+--------------------------+-------------------------------------------------------+
| Variable_name            | Value                                                 |
+--------------------------+-------------------------------------------------------+
| wsrep_incoming_addresses | 192.168.1.90:3306,192.168.1.89:3306,192.168.1.88:3306 |
+--------------------------+-------------------------------------------------------+
1 row in set (0.25 sec)
 
# 比较重要的参数状态
mysql> show status like 'wsrep%';
+------------------------------+-------------------------------------------------------------+
| Variable_name                | Value                                                       |
+------------------------------+-------------------------------------------------------------+
| wsrep_cluster_status         | Primary                                                     |
| wsrep_connected              | ON                                                          |
| wsrep_ready                  | ON                                                          |
+------------------------------+-------------------------------------------------------------+
 
测试数据
 
第一个节点:
mysql> create database db1;
Query OK, 1 row affected (0.05 sec)
mysql> use db1;
Database changed
mysql> create table t1(x int);
Query OK, 0 rows affected (0.21 sec)
mysql> insert into t1 values(1);
第二个节点:
mysql> use db1;
 Database changed
 mysql> show tables;
 +---------------+
 | Tables_in_db1 |
 +---------------+
 | t1 |
 +---------------+
 1 row in set (0.00 sec)
 mysql> insert into t1 values(2);
 Query OK, 1 row affected (0.01 sec)
 第三个节点:
 mysql> use db1;
 Database changed
 mysql> show tables;
 +---------------+
 | Tables_in_db1 |
 +---------------+
 | t1 |
 +---------------+
 1 row in set (0.00 sec)
 
mysql> select * from t1;
+------+
| x    |
+------+
|    1 |
|    2 |
|    3 |
+------+
3 rows in set (0.00 sec)
 
遇到的问题及解决办法:
可能提示缺少libssl.so.6和libcrypto.so.6
/usr/local/mysql//bin/my_print_defaults: error while loading shared libraries: libssl.so.6: cannot open shared object file: No such file or directory
/usr/local/mysql//bin/my_print_defaults: error while loading shared libraries: libcrypto.so.6: cannot open shared object file: No such file or directory
安装openssl
# rpm -qa | grep openssl
krb5-pkinit-openssl-1.10.3-65.el6.x86_64
openssl-1.0.1e-57.el6.x86_64
openssl098e-0.9.8e-20.el6.centos.1.i686
 
cd /usr/lib64
# ln -s libssl.so.1.0.1e libssl.so.6
# ln -s libcrypto.so.1.0.1e libcrypto.so.6
 
 
 
 

percona-xtradb-cluster安装部署的更多相关文章

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

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

  2. 搭建高可用mysql系列(2)-- Percona XtraDB Cluster 安装

    本文主要介绍在 centos 下 Percona XtraDB Cluster(下文简称PXC) 的安装, 个人的系统版本信息如下: [root@c2-d09 worker]# more /etc/r ...

  3. MySQL集群Percona XtraDB Cluster安装搭建步骤详解

    http://www.linuxidc.com/Linux/2017-05/143501.htm http://blog.csdn.net/thundermeng/article/details/52 ...

  4. PXC(Percona XtraDB Cluster)集群的安装与配置

    Percona XtraDB Cluster是针对MySQL用户的高可用性和扩展性解决方案,基于Percona Server .其包括了Write Set REPlication补丁,使用Galera ...

  5. docker1.12 安装pxc(Percona XtraDB Cluster )测试

    docker1.12 安装pxc(Percona XtraDB Cluster )测试

  6. PXC5.7(Percona XtraDB Cluster)+HAproxy+Keepalived 集群部署

    Percona-XtraDB-Cluster+Haproxy 搭建集群环境 环境准备及服务器信息: 配置防火墙 firewall-cmd --add-port=3306/tcp --permanent ...

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

    Percona XtraDB Cluster(PXC)   ---服务安装篇   1.测试环境搭建: Ip 角色 OS PXC-version 172.16.40.201 Node1 Redhat/C ...

  8. Percona XtraDB Cluster简易入门 - 安装篇

    说明 Percona XtraDB Cluster(简称PXC),是由percona公司推出的mysql集群解决方案.特点是每个节点都能进行读写,且都保存全量的数据.也就是说在任何一个节点进行写入操作 ...

  9. kubernetes部署Percona XtraDB Cluster集群

    PXC介绍 全称percona-xtradb-cluster,提供了MySQL高可用的一种实现方法.PXC集群以节点组成(推荐至少3节点,便于故障恢复),每个节点都是基于常规的 MySQL Serve ...

  10. Installing Percona XtraDB Cluster on CentOS

    PXC简介 Percona XtraDB Cluster(简称PXC集群)提供了MySQL高可用的一种实现方法. 1.集群是有节点组成的,推荐配置至少3个节点,但是也可以运行在2个节点上. 2.每个节 ...

随机推荐

  1. preg_match_all匹配网络上文件

    <?php$ssa=file_get_contents("http://www.oschina.net/code/snippet_4873_5256");preg_match ...

  2. 通过DOM实现点击隐藏父元素

    HTML代码简单如下: <ul id='ul1'> <li><a href="javascript:">1</a></li&g ...

  3. 修改DIV滚动条样式

    /*滚动条样式*/ div::-webkit-scrollbar { /*滚动条整体样式*/ width: 5px; /*高宽分别对应横竖滚动条的尺寸*/ height: 5px; } div::-w ...

  4. ThreadLocal类详解

    学习一个东西首先要知道为什么要引入它,就是我们能用它来干什么.所以我们先来看看ThreadLocal对我们到底有什么用,然后再来看看它的实现原理. ThreadLocal如果单纯从名字上来看像是“本地 ...

  5. BZOJ 4562 搜索...

    思路: 统计入度&出度 每搜到一个点 in[v[i]]--,f[v[i]]+=f[t]; if(!in[v[i]])if(out[v[i]])q.push(v[i]);else ans+=f[ ...

  6. rabbit channel参数

    channel.exchangeDeclare() channel.ExchangeDeclare(string exchange: "cjlTest",string  type: ...

  7. python--3、函数

    定义: 定义函数时,也相当于定义变量.会把函数体内的代码存入开辟的内存空间中.使用函数时,通过func() 声明是函数,其对应的值为代码.函数是指将一组语句的集合通过一个名字(函数名)封装起来,要想执 ...

  8. 【SQL】CONNECT BY 层次化查询

    层次化查询,顾名思义就是把查询结果有层次的呈现出来.层次化查询结果类似于树状结构,最顶端的是“根节点”,下面是“父节点”,没有子节点的是“叶节点”. 为了让一个或多个表具有层次关系,必须使用相关的字段 ...

  9. Glitch-free clock switch

    With multi-frequency clocks being used in today’s devices, it's necessary to switch the source of a ...

  10. 【技术累积】【点】【sql】【17】了解索引

    先上结论 数据库数据以平衡树进行聚合索引--主键的作用: 数据每行都存在叶子节点: 单独字段的索引,单独存在,且将该字段值取出: 单独字段的索引,查到对应的主键id,再通过聚合索引查到数据: 多字段索 ...