1、安装
安装地址:https://www.percona.com/downloads/
yum -y remove Percona-Server*
yum -y install percona-xtrabackup-24*
yum -y install Percona-XtraDB-Cluster-57*
报错:Error: Package: percona-xtrabackup-24-2.4.11-1.el7.x86_64 (percona-cluster)
Requires: libev.so.4()(64bit)
解决:安装 libev-4.15-3.el7.x86_64.rpm
报错:Error: Package: Percona-XtraDB-Cluster-server-57-5.7.21-29.26.1.el7.x86_64 (percona-cluster)
Requires: qpress
解决:安装 qpress-1.1-8.1.x86_64.rpm
2、启动:service mysql start
失败报错:
2018-05-13T17:56:39.752463Z 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
2018-05-13T17:56:39.752477Z 0 [ERROR] WSREP: wsrep_load() failed to load the provider('/usr/lib64/galera3/libgalera_smm.so'): Invalid argument (22). Need to abort.
2018-05-13T17:56:39.752480Z 0 [ERROR] Aborting
解决方法: 升级openssl
安装
openssl-1.0.2k-8.el7.x86_64.rpm
openssl-libs-1.0.2k-8.el7.x86_64.rpm
openssl-devel-1.0.2k-8.el7.x86_64.rpm
可以直接force安装,可以将之前版本覆盖。
3、修改root密码
可以在/vr/log/mysqld.log中找到root的口令
mysql -u root -p
set password=password('123456');flush privileges;quit;
4、 修改wsrep.conf
第一个:
[root@10-248-56-192 percona-xtradb-cluster.conf.d]# cat wsrep.cnf
[mysqld]
#Path to Galera library
wsrep_provider=/usr/lib64/galera3/libgalera_smm.so
#Cluster connection URL contains IPs of nodes
#If no IP is found, this implies that a new cluster needs to be created,
#in order to do that you need to bootstrap this node
wsrep_cluster_address=gcomm://10.248.56.192,10.248.56.195,10.248.56.209
#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
#Slave thread to use
wsrep_slave_threads= 8
wsrep_log_conflicts
#This changes how InnoDB autoincrement locks are managed and is a requirement for Galera
innodb_autoinc_lock_mode=2
#Node IP address
wsrep_node_address=10.248.56.192
#Cluster name
wsrep_cluster_name=pxc-cluster
#If wsrep_node_name is not specified, then system hostname will be used
wsrep_node_name=pxc-cluster-node-1
#pxc_strict_mode allowed values: DISABLED,PERMISSIVE,ENFORCING,MASTER
pxc_strict_mode=ENFORCING
#SST method
wsrep_sst_method=xtrabackup-v2
#Authentication for SST method
wsrep_sst_auth="sstuser:s3cretPass"
第二个:
[root@10-248-56-195 percona-xtradb-cluster.conf.d]# cat wsrep.cnf
[mysqld]
#Path to Galera library
wsrep_provider=/usr/lib64/galera3/libgalera_smm.so
#Cluster connection URL contains IPs of nodes
#If no IP is found, this implies that a new cluster needs to be created,
#in order to do that you need to bootstrap this node
wsrep_cluster_address=gcomm://10.248.56.192,10.248.56.195,10.248.56.209
#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
#Slave thread to use
wsrep_slave_threads= 8
wsrep_log_conflicts
#This changes how InnoDB autoincrement locks are managed and is a requirement for Galera
innodb_autoinc_lock_mode=2
#Node IP address
wsrep_node_address=10.248.56.195
#Cluster name
wsrep_cluster_name=pxc-cluster
#If wsrep_node_name is not specified, then system hostname will be used
wsrep_node_name=pxc-cluster-node-2
#pxc_strict_mode allowed values: DISABLED,PERMISSIVE,ENFORCING,MASTER
pxc_strict_mode=ENFORCING
#SST method
wsrep_sst_method=xtrabackup-v2
#Authentication for SST method
wsrep_sst_auth="sstuser:s3cretPass"
第三个:
[root@10-248-56-192 percona-xtradb-cluster.conf.d]# cat wsrep.cnf
[mysqld]
#Path to Galera library
wsrep_provider=/usr/lib64/galera3/libgalera_smm.so
#Cluster connection URL contains IPs of nodes
#If no IP is found, this implies that a new cluster needs to be created,
#in order to do that you need to bootstrap this node
wsrep_cluster_address=gcomm://10.248.56.192,10.248.56.195,10.248.56.209
#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
#Slave thread to use
wsrep_slave_threads= 8
wsrep_log_conflicts
#This changes how InnoDB autoincrement locks are managed and is a requirement for Galera
innodb_autoinc_lock_mode=2
#Node IP address
wsrep_node_address=10.248.56.209
#Cluster name
wsrep_cluster_name=pxc-cluster
#If wsrep_node_name is not specified, then system hostname will be used
wsrep_node_name=pxc-cluster-node-3
#pxc_strict_mode allowed values: DISABLED,PERMISSIVE,ENFORCING,MASTER
pxc_strict_mode=ENFORCING
#SST method
wsrep_sst_method=xtrabackup-v2
#Authentication for SST method
wsrep_sst_auth="sstuser:s3cretPass"
5、启动第一个节点:
systemctl restart mysql@bootstrap.service
show status like 'wsrep_%'; 查看现在集群状态
6、启动第二个节点:
需要将my.cnf中的sever_id与其他节点不一致
service mysql restart
[root@10-248-56-195 log]# pwd
/var/log/mysqld.log
2018-05-14T09:17:56.600663Z WSREP_SST: [INFO] ............Waiting for SST streaming to complete!
2018-05-14T09:17:57.737279Z 0 [Note] WSREP: (aeddf750, 'tcp://0.0.0.0:4567') turning message relay requesting off
2018-05-14T09:18:06.585389Z WSREP_SST: [ERROR] ******************* FATAL ERROR **********************
2018-05-14T09:18:06.587149Z WSREP_SST: [ERROR] xtrabackup_checkpoints missing. xtrabackup/SST failed on DONOR. Check DONOR log
2018-05-14T09:18:06.588852Z WSREP_SST: [ERROR] ******************************************************
2018-05-14T09:18:06.591227Z WSREP_SST: [ERROR] Cleanup after exit with status:2
2018-05-14T09:18:06.602013Z 0 [ERROR] WSREP: Process completed with error: wsrep_sst_xtrabackup-v2 --role 'joiner' --address '10.248.56.195' --datadir '/data0/mysql/' --defaults-file '/etc/my.cnf' --defaults-group-suffix '' --parent '27460' '' : 2 (No such file or directory)
主节点日志:
[root@10-248-56-192 mysql]#
/data0/mysql/innobackup.backup.log
报错:
180514 17:14:44 version_check Connecting to MySQL server with DSN 'dbi:mysql:;mysql_read_default_group=xtrabackup;mysql_socket=/var/lib/mysql/mysql.sock' as 'sstuser' (using password: YES).
Failed to connect to MySQL server: DBI connect(';mysql_read_default_group=xtrabackup;mysql_socket=/var/lib/mysql/mysql.sock','sstuser',...) failed: Access denied for user 'sstuser'@'localhost' (using password: YES) at - line 1314.
180514 17:14:44 Connecting to MySQL server host: localhost, user: sstuser, password: set, port: not set, socket: /var/lib/mysql/mysql.sock
Failed to connect to MySQL server: Access denied for user 'sstuser'@'localhost' (using password: YES).
解决:
在主节点mysql内添加sstuser 用户:
create user 'sstuser'@'%' identified by 's3cretPass';
报错:180514 17:18:06 Executing LOCK TABLES FOR BACKUP...
Error: failed to execute query LOCK TABLES FOR BACKUP: Access denied; you need (at least one of) the RELOAD privilege(s) for this operation
----提示:缺少reload权限
查看用户权限:
select user,host,Reload_priv from user where user='sstuser';
授权:
GRANT ALL PRIVILEGES ON *.* TO 'sstuser'@'localhost' IDENTIFIED BY 's3cretPass' WITH GRANT OPTION;
Delete FROM user Where User='sstuser' and Host='%';
7、启动第三个节点
service mysql restart
8、测试
需要每个表建立主键
mysql> insert into kangning values (1,'ddd'),(2,'xxx'),(3,'ssss');
ERROR 1105 (HY000): Percona-XtraDB-Cluster prohibits use of DML command on a table (test.kangning) without an explicit primary key with pxc_strict_mode = ENFORCING or MASTER
mysql> alter table kangning add primary key(id);
mysql> insert into kangning values (1,'ddd'),(2,'xxx'),(3,'ssss');
Query OK, 3 rows affected (0.01 sec)
Records: 3 Duplicates: 0 Warnings: 0
- 一、日常运维脚本
- 1.1 批量创建用户并赋予sudo权限
- 1.2 批量主机建立互信
- 1.3create_images.sh
- 1.4monitor.sh
- 1.5ftp脚本
- 1.6格式化分区
- 1.7简单的远程执行脚本
- 二、常用服务使用
- 1 ceph (分布式文件系统)
- 1.1 ceph 简介
- 1.2 准备环境
- 1.3 开始部署
- 1.4 cephfs挂载
- 1.5 RBD块存储
- 1.6 object 对象存储
- 1.7 集群扩展
- 1.7.1 增加删除MON
- 1.7.2 增加删除OSD
- 1.7.3 删除MDS
- 注意事项
- 遇到的问题
- 1.8ceph查找数据文件
- 1.9卸载并清理环境
- 2、mysql (数据库)
- 2.1 搭建
- 2.2 使用教程
- 2.2.1 mysql基础配置
- 2.2.1.1 用户权限管理
- 2.2.1.2用户资源限制
- 2.2.1.3 密码管理
- 2.2.1.4用户lock
- 2.2.2mysql语法详解
- 2.2.1建库、表语句
- 2.2.2.2 插入 insert
- 2.2.2.3更新 update
- 2.2.2.4删除 delete
- 2.2.2.5查询 select
- 2.2.6视图 索引 view index
- 2.2.7 修改 alert
- 2.2.2.8清理 truncate drop
- 2.2.9重命名 rename
- 示例语句
- 2.2.3mysql常用函数
- 2.3.1 对比操作符统概
- 2.3.2对比操作符详解
- 2.3.3逻辑操作符
- 2.2.4分配操作符
- 2.2.5流程控制函数
- 2.2.6字符串函数
- 2.2.7字符串对比函数
- 2.2.8数字函数
- 2.2.9日期和时间函数
- 2.2.10聚合/格式转换函数
- 2.2.11 子查询
- 示例语句
- 2.2.4 mysql 高级应用
- 2.2.4.1 存储过程 函数
- 2.2.4.2流程控制
- 2.2.4.3游标
- 2.2.4.4触发器
- 课堂练习
- 2.2.2.5 数据库设计
- 2.2.5.1 数据类型
- 2.2.5.2存储引擎
- 2.2.6Innodb内核
- 1、innodb事务和多版本控制
- 2、体系结构
- 3、InnoDB配置
- 4、buffer pool设置
- 5、其他配置
- innodb限制
- 2.7 字符集
- 2.8锁机制和事务
- 2.8.1锁机制
- 2.8.2事务
- 2.9分区
- 2.9.1 自动分区
- 2.10复制
- 2.11mysql搬移数据目录
- 2.12组复制 GR
- 简介
- 搭建
- 2.3日常运维
- 2.3.1定时任务
- 2.4mycat
- 2.4.1 报错分析
- 2.4.2 修改字符集
- 2.11 mycat使用
- 2.5遇到问题
- 2.5.1 表名库名忽略大小写
- 3、PAAS平台搭建
- 问题汇总
- 1、docker
- 2、日常运维
- 3.1 Kubernetes
- 3.1 kubernetes 高版本搭建
- 4、GlusterFS搭建
- 5、MooseFS搭建
- 5.1搭建
- 5.2运维
- 5.2.1 mfs日志解析
- 5.2.2清理mfs的垃圾数据
- 5.2.3元数据故障恢复
- 5.2.4 MFS优化
- 5.2.5 配置机架感知
- 5.2.6 客户端工具集
- 6、集群切换命令
- 7、ntp服务
- 8、monggoDB
- 8.1搭建单机
- 2、搭建集群及分片
- 9、MariaDB Galera Cluster
- 9.1源码安装MariaDB
- 9.2galera cluster 优劣
- 9.3 rpm安装mariadb
- 10 HAproxy1.7搭建
- 11、sysbench 搭建使用
- 0.5版本
- 12 percona-xtradb-cluster
- 13http服务相关
- 13.1 http状态码解析
- 14 zookeeper
- 14.1 zookeeper日志查看
- 14.2 配置解析
- 14.3 优化
- 15搭建私有pip源
- 16/var/log的日志文件解释
- 15 ansible的搭建及使用
- 15.1 搭建
- 15.2 使用说明
- 16. 搭建本地yum源
- zookeeper
- 优化
- 四、开发语言
- 1、GO语言
- 1.1go简介
- 1.1.1hello_world初识GO
- 1.1.2并发介绍
- 1.1.3 chan介绍
- 1.1.4多返回值
- 1.2go基础
- 1.2.1数据类型
- 1.2.2 go基础结构
- 1.2.3 const及变量介绍
- 1.2.3os和time介绍
- 1.2.4 字符串
- 1.2.5条件判断
- 1.2.6 homework
- go--help
- 1.3 go基础2
- 1.3.1 数组 array
- 1.3.2切片 slice
- 1.3.3 时间和日期
- 1.3.4指针类型
- 1.3.5函数
- 1.3.6可变参数
- 1.3.7 defer
- 1.3.8递归
- 1.9闭包
- 1.10 map
- 1.11 sort
- 1.12 struct 结构体
- 2.perl语言
- 2.1 安装lib包
- 3 python
- 1.语言基础
- 2、编程教学
- 2.1变量和序列
- 2.2 条件语句