CentOS 7 搭建PXC 数据库集群
PXC( Percona XtraDB Cluster ) 特点如下:

1.同步复制,事务要么在所有节点提交或不提交,保证了数据的强一致性。
2.多主复制,可以在任意节点进行写操作。
3.在从服务器上并行应用事件,真正意义上的并行复制。
Percona 下载地址

https://www.percona.com/downloads/Percona-XtraDB-Cluster-LATEST/

所有下载安装包如下:

Percona-XtraDB-Cluster

Percona-XtraBackup

jemalloc

qpress

#修改静态IP

ip addr

vi /etc/sysconfig/network-scripts/ifcfg-ens32

#修改并添加

BOOTPROTO=static

IPADDR=192.168.0.3
NETMASK=255.255.255.0
GATEWAY=192.168.0.1
DNS1=192.168.0.1
DNS2=8.8.8.8

service network restart

#先删除预装的 MariaDB
yum -y remove mari*

#解压所有安装包,到 /home 目录,执行批量安装
yum localinstall *.rpm

#查看 root 密码
cat /var/log/mysqld.log | grep "A temporary password"

#修改 root 密码,建议先创建快照,以便恢复.
mysql_secure_installation

#登录 mysql
mysql -h127.0.0.1  -u root  -p

#创建 admin 帐号
mysql> CREATE USER 'admin'@'%' IDENTIFIED BY 'Abc_123456';
mysql> GRANT all privileges ON *.* TO 'admin'@'%';
mysql> FLUSH PRIVILEGES;

mysql>exit

#修改 mysql 配置文件
vi /etc/percona-xtradb-cluster.conf.d/mysqld.cnf
===>添加在 [mysqld] 下面:
[mysqld]
character_set_server=utf8
bind-address=0.0.0.0
#跳过DNS解析
skip-name-resolve
 
#修改集群配置文件
vi /etc/percona-xtradb-cluster.conf.d/wsrep.cnf
 
===>对照配置文件,修改这些地方(红色标记是要改的地方)
 
[mysqld]

#集群名称
wsrep_cluster_name=pxc-cluster

#节点名称(每个节点不同)
wsrep_node_name=pxc-cluster-node-1

#节点IP
wsrep_node_address=192.168.0.11

#集群IP地址列表(3,4,5 最少三个节点)
wsrep_cluster_address=192.168.0.3,192.168.0.4,192.168.0.5

#同步数据时的帐户
wsrep_sst_auth="admin:Abc_123456"

#Galera 库
wsrep_provider=/usr/lib64/galera3/libgalera_smm.so

#基于ROW复制(安全可靠)
binlog_format=ROW

#默认存储引擎,目前MyISAM 还处于实验阶段
default_storage_engine=InnoDB

#从节点线程数
wsrep_slave_threads= 8

#是否记录有关冲突的其他信息
wsrep_log_conflicts=OFF

#主键自增长不锁表
innodb_autoinc_lock_mode=2

#同步严厉模式(DISABLED,PERMISSIVE,ENFORCING,MASTER)
pxc_strict_mode=ENFORCING

#同步方法(mysqldump、rsync、xtrabackup)
wsrep_sst_method=xtrabackup-v2

 
#把 SELINUX 值设置成 disabled
vi /etc/selinux/config
 
#禁止 mysql 自启动
chkconfig mysqld off
 
#开放端口
firewall-cmd --zone=public --add-port=3306/tcp --permanent
firewall-cmd --zone=public --add-port=4444/tcp --permanent
firewall-cmd --zone=public --add-port=4567/tcp --permanent
firewall-cmd --zone=public --add-port=4568/tcp --permanent
 
#重启服务器
reboot
 
至此,第一个节点服务器就建好了,如果你用的虚拟机的话,克隆该系统两份.这个时候是不无法通过 service mysql 启动的,因为当前是集群配置,没有没有集群的存在,当然启动失败.
接下来,再配置两台机器,可以直接克隆,然后改改.
 
如果是克隆的话,我说一个注意事项,首先,机器启动之前,把网卡地址改一下,不然,与前一台机器冲突了.然后再启动机器,修改静态IP.
 
#修改 server-id,每个集群中,编号唯一,可改成1.2.3编号
vi /etc/percona-xtradb-cluster.conf.d/mysqld.cnf
 
准备就位后,把其中一台作为主节点启动,以创建集群,命令分别如下.
 
#主节点启动
systemctl start mysql@bootstrap.service
 
#非主节点启动
service  mysql start
 
另外注意一点,集群中,半数或半数以上的节点挂了,集群也就挂了.当重新启动集群时,能作为主节点启动的,往往是那台最后挂的服务器,因为它保存的数据是最完整的.
 
#查看哪能节点服务器能作为主节点启动
vi /var/lib/mysql/grastate.dat
 
找到 "safe_to_bootstrap: 0"  如果是 1 表示可以作为主节点启动,当三个节点同时挂了,那么全都是0,这时手动修改其中一个为1就好了.
最终实现的效果是数据库管理工具连接这三个数据库节点,然后,任意操作其中一个数据库,刷新另外两个,都能看到变一致的改变.
 
 

CentOS 7 搭建PXC 数据库集群的更多相关文章

  1. CentOS完美搭建Redis3.0集群并附测试

    线上的统一聊天和推送项目使用的是redis主从,redis版本2.8.6 redis主从和mysql主从目的差不多,但redis主从配置很简单,主要在从节点配置文件指定主节点ip和端口:slaveof ...

  2. docker应用-6(mysql+mycat 搭建数据库集群)

    上一节,通过使用overlay网络,搭建了跨主机的docker容器集群.下面,在这个跨主机的docker容器集群环境下,搭建mysql 数据库集群. mysql主从自动备份和自动切换 从数据安全性考虑 ...

  3. 【Data Cluster】真机环境下MySQL数据库集群搭建

    真机环境下MySQL-Cluster搭建文档  摘要:本年伊始阶段,由于实验室对不同数据库性能测试需求,才出现MySQL集群搭建.购置主机,交换机,双绞线等一系列准备工作就绪,也就开始集群搭建.起初笔 ...

  4. Redis 非关系性数据库集群的搭建与常用方法

    redis 非关系型数据库,内存型数据库,现在大家都不陌生了,无论大中小型企业,都会将redis应用到自己的项目中,以此来减轻数据库的压力 安装步骤: 1.安装gcc 安装c语言的编译环境 yum i ...

  5. 超详细!CentOS 7 + Hadoop3.0.0 搭建伪分布式集群

    超详细!CentOS 7 + Hadoop3.0.0 搭建伪分布式集群 ps:本文的步骤已自实现过一遍,在正文部分避开了旧版教程在新版使用导致出错的内容,因此版本一致的情况下照搬执行基本不会有大错误. ...

  6. 手把手教你用Mysql-Cluster-7.5搭建数据库集群

    前言 当你的业务到达一定的当量,肯定需要一定数量的数据库来负载均衡你的数据库请求,我在之前的博客中已经说明了,如何实现负载均衡,但是还有一个问题就是数据同步,因为负载均衡的前提就是,各个服务器的数据库 ...

  7. 简单使用Mysql-Cluster-7.5搭建数据库集群

    阅读目录 前言 mysql cluster中的几个概念解释 架构图及说明 下载mysql cluster 安装mysql cluster之前 安装配置管理节点 安装配置数据和mysql节点 测试 启动 ...

  8. 【转】MYSQL-CLUSTER-7.5搭建数据库集群

    阅读目录 前言 mysql cluster中的几个概念解释 架构图及说明 下载mysql cluster 安装mysql cluster之前 安装配置管理节点 安装配置数据和mysql节点 测试 启动 ...

  9. 基于keepalived搭建MySQL热机集群

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

随机推荐

  1. webpack快速入门——CSS进阶:消除未使用的CSS

    使用PurifyCSS可以大大减少CSS冗余 1.安装 cnpm i purifycss-webpack purify-css --save-dev 2.引入glob,因为我们需要同步检查html模板 ...

  2. HTML简单登录和注册页面及input标签诠释

    今天第一次接触HTML这种语言,虽然不能完全理解其中的意思,过去学的英语单词几乎也忘了差不多了,但是感觉进入这门语言学习之后就没有那么难了,一步一步来吧!下面巩固下今天学内容: HTML是一种超文本标 ...

  3. mysql主从同步详细教程

    1.安装好主数据库和从数据库,这个大家肯定都会,如果不是很明白,可以参考我前面的安装教程. 例子: 假如我需要同步test1.test2数据库 系统:centos7 主库主机:192.168.1.25 ...

  4. iOS 枚举讲解

    枚举增强程序的可读性,用法上还是需要注意的 1.C语言的写法 enum XMPPReconnectFlags { kShouldReconnect = 1 << 0, // If set, ...

  5. MySQL索引(六)

    一.什么是索引 索引就像一本书的目录一样,如果在字段上建立索引,那么以索引为列的查询条件时可以加快查询的速度,这个就是MySQL优化的重要部分 二.创建主键索引 整个表的每一条记录的主键值在表内都是唯 ...

  6. 【PaddlePaddle系列】CIFAR-10图像分类

    前言 本文与前文对手写数字识别分类基本类似的,同样图像作为输入,类别作为输出.这里不同的是,不仅仅是使用简单的卷积神经网络加上全连接层的模型.卷积神经网络大火以来,发展出来许多经典的卷积神经网络模型, ...

  7. Dubbo与Zookeeper、SpringMVC整合和使用(负载均衡、容错)(略有修改)

    对应项目的代码地址为:https://github.com/liuxiaoming7708/springboot-dubbo-parent Dubbo与Zookeeper.SpringMVC整合和使用 ...

  8. chrome 下修改 agent 的方法

    前言 这篇文章和 tiankonguse 的个人网站里的文章保持同步. 很早之前,在 chrome 下修改 agent 的方法是使用 chrome 插件. 后来 chrome 的某一个版本中自带这个功 ...

  9. Nodejs学习笔记(十四)—Mongoose介绍和入门

    简介 Mongoose是在node.js异步环境下对mongodb进行便捷操作的对象模型工具 那么要使用它,首先你得装上node.js和mongodb,关于mongodb的安装和操作介绍可以参考:ht ...

  10. Install Tomcat 6 on CentOS or RHEL --转载

    source:http://www.davidghedini.com/pg/entry/install_tomcat_6_on_centos This post will cover installa ...