PXC(Percona XtraDB Cluster)、部署PX

2021-08-17  本文已影响0人  秋天丢了李姑娘

PXC(Percona XtraDB Cluster)

概述

PXC介绍

PXC特点

相应端口

部署PXC

服务器角色

初始环境准备

[root@mysql1 ~]# for i in {1..3}
> do
> echo -e "192.168.1.1$i\tmysql$i" >> /etc/hosts
> done

[root@mysql2 ~]# for i in {1..3}
> do
> echo -e "192.168.1.1$i\tmysql$i" >> /etc/hosts
> done

[root@mysql3 ~]# for i in {1..3}
> do
> echo -e "192.168.1.1$i\tmysql$i" >> /etc/hosts
> done
[root@zzgrhel8 mysql_soft]# cd pxc
[root@zzgrhel8 pxc]# tar xf Percona-XtraDB-Cluster-5.7.25-31.35-r463-el7-x86_64-bundle.tar
[root@zzgrhel8 pxc]# cp *.rpm /var/www/html/mysql/
[root@zzgrhel8 pxc]# cd /var/www/html/mysql/
[root@zzgrhel8 mysql]# createrepo -v .
[root@mysql1 ~]# yum clean all
[root@mysql1 ~]# yum remove -y mysql-community-*
[root@mysql1 ~]# yum install -y qpress-1.1-14.11 Percona-XtraDB-Cluster-*

[root@mysql2 ~]# yum clean all
[root@mysql2 ~]# yum remove -y mysql-community-*
[root@mysql2 ~]# yum install -y qpress-1.1-14.11 Percona-XtraDB-Cluster-*

[root@mysql3 ~]# yum clean all
[root@mysql3 ~]# yum remove -y mysql-community-*
[root@mysql3 ~]# yum install -y qpress-1.1-14.11 Percona-XtraDB-Cluster-*

配置服务

# 如果服务器之前安装过mysql,把数据目录清空
[root@mysql{1..3} ~]# rm -rf /var/lib/mysql/*

[root@mysql1 ~]# vim /etc/percona-xtradb-cluster.conf.d/mysqld.cnf
... ...
[mysqld]
server-id=11
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
log_slave_updates
expire_logs_days=7
... ...

[root@mysql2 ~]# vim /etc/percona-xtradb-cluster.conf.d/mysqld.cnf
... ...
[mysqld]
server-id=12
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
log_slave_updates
expire_logs_days=7
... ...

[root@mysql3 ~]# vim /etc/percona-xtradb-cluster.conf.d/mysqld.cnf
... ...
[mysqld]
server-id=13
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
log_slave_updates
expire_logs_days=7
... ...
[root@mysql1 ~]# vim /etc/percona-xtradb-cluster.conf.d/mysqld_safe.cnf
[mysqld_safe]
pid-file = /var/run/mysqld/mysqld.pid
socket   = /var/lib/mysql/mysql.sock
nice     = 0

[root@mysql2 ~]# vim /etc/percona-xtradb-cluster.conf.d/mysqld_safe.cnf
[mysqld_safe]
pid-file = /var/run/mysqld/mysqld.pid
socket   = /var/lib/mysql/mysql.sock
nice     = 0

[root@mysql3 ~]# vim /etc/percona-xtradb-cluster.conf.d/mysqld_safe.cnf
[mysqld_safe]
pid-file = /var/run/mysqld/mysqld.pid
socket   = /var/lib/mysql/mysql.sock
nice     = 0
[root@mysql1 ~]# vim /etc/percona-xtradb-cluster.conf.d/wsrep.cnf
# 修改以下内容:
wsrep_cluster_address=gcomm://192.168.1.11,192.168.1.12,192.168.1.13  # 集群成员
wsrep_node_address=192.168.1.11   # 本节点IP地址
wsrep_cluster_name=pxc-cluster    # 集群名
wsrep_node_name=mysql1            # 本节点名
wsrep_sst_auth="sstuser:NSD2021@tedu.cn"   # SST数据同步授权用户及密码

[root@mysql2 ~]# vim /etc/percona-xtradb-cluster.conf.d/wsrep.cnf
# 修改以下内容:
wsrep_cluster_address=gcomm://192.168.1.11,192.168.1.12,192.168.1.13  # 集群成员
wsrep_node_address=192.168.1.12   # 本节点IP地址
wsrep_cluster_name=pxc-cluster    # 集群名
wsrep_node_name=mysql2            # 本节点名
wsrep_sst_auth="sstuser:NSD2021@tedu.cn"   # SST数据同步授权用户及密码

[root@mysql3 ~]# vim /etc/percona-xtradb-cluster.conf.d/wsrep.cnf
# 修改以下内容:
wsrep_cluster_address=gcomm://192.168.1.11,192.168.1.12,192.168.1.13  # 集群成员
wsrep_node_address=192.168.1.13   # 本节点IP地址
wsrep_cluster_name=pxc-cluster    # 集群名
wsrep_node_name=mysql3            # 本节点名
wsrep_sst_auth="sstuser:NSD2021@tedu.cn"   # SST数据同步授权用户及密码

启动服务

# 首次启动服务时间比较长
[root@mysql1 ~]# systemctl  start mysql@bootstrap.service
[root@mysql1 ~]# grep password /var/log/mysqld.log
[root@mysql1 ~]# mysql -uroot -p'!Yo.e(qv:0pH'
mysql> alter user  root@'localhost' identified by 'NSD2021@tedu.cn';
mysql> grant reload, lock tables,replication client,process on *.*  to
    -> sstuser@'localhost' identified by 'NSD2021@tedu.cn';
Query OK, 0 rows affected, 1 warning (0.20 sec)
[root@mysql2 ~]# systemctl start mysql
[root@mysql2 ~]# netstat -utnlp  | grep :3306
tcp6       0      0 :::3306                 :::*                    LISTEN      18875/mysqld
[root@mysql2 ~]# netstat -utnlp  | grep :4567
tcp        0      0 0.0.0.0:4567            0.0.0.0:*               LISTEN      18875/mysqld

[root@mysql3 ~]# systemctl  start mysql
[root@mysql3 ~]# netstat -utnlp  | grep :3306
tcp6       0      0 :::3306                 :::*                    LISTEN      18465/mysqld
[root@mysql3 ~]# netstat -utnlp  | grep :4567
tcp        0      0 0.0.0.0:4567            0.0.0.0:*               LISTEN      18465/mysqld

测试配置

查看集群信息

[root@mysql2 ~]# mysql -uroot -pNSD2021@tedu.cn
mysql> show status like "%wsrep%";  # 找到以下信息
| wsrep_incoming_addresses         | 192.168.1.11:3306,192.168.1.12:3306,192.168.1.13:3306 |
| wsrep_cluster_weight             | 3                                                     |
| wsrep_cluster_status             | Primary                                               |
| wsrep_connected                  | ON                                                    |
| wsrep_ready                      | ON                                                    |
mysql> grant all on db1.* to dbuser1@'%' identified by 'NSD2021@tedu.cn';
Query OK, 0 rows affected, 1 warning (0.48 sec)

mysql> show grants for dbuser1;
+--------------------------------------------------+
| Grants for dbuser1@%                             |
+--------------------------------------------------+
| GRANT USAGE ON *.* TO 'dbuser1'@'%'              |
| GRANT ALL PRIVILEGES ON `db1`.* TO 'dbuser1'@'%' |
+--------------------------------------------------+
2 rows in set (0.00 sec)
[root@node10 ~]# mysql -h192.168.1.11 -udbuser1 -pNSD2021@tedu.cn
mysql> create database db1 default charset utf8mb4;
Query OK, 1 row affected (0.57 sec)

mysql> create table db1.students(id int primary key auto_increment, name varchar(20));
Query OK, 0 rows affected (0.92 sec)

mysql> insert into db1.students(name) values ('tom');
Query OK, 1 row affected (0.15 sec)
[root@node10 ~]# mysql -h192.168.1.12 -udbuser1 -pNSD2021@tedu.cn
mysql> select * from db1.students;
+----+------+
| id | name |
+----+------+
|  1 | tom  |
+----+------+
1 row in set (0.00 sec)

[root@node10 ~]# mysql -h192.168.1.13 -udbuser1 -pNSD2021@tedu.cn
mysql> select * from db1.students;
+----+------+
| id | name |
+----+------+
|  1 | tom  |
+----+------+
1 row in set (0.00 sec)

测试故障自动恢复

[root@mysql1 ~]# systemctl stop mysql@bootstrap.service
[root@mysql2 ~]# mysql -uroot -pNSD2021@tedu.cn
mysql> insert into db1.students(name) values('jerry');
Query OK, 1 row affected (0.20 sec)

mysql> select * from db1.students;
+----+-------+
| id | name  |
+----+-------+
|  1 | tom   |
|  5 | jerry |
+----+-------+
2 rows in set (0.00 sec)
[root@mysql1 ~]# mysql -uroot -pNSD2021@tedu.cn
mysql> select * from db1.students;
+----+-------+
| id | name  |
+----+-------+
|  1 | tom   |
|  5 | jerry |
+----+-------+
2 rows in set (0.00 sec)

重新启动全部关闭后的mysql

# 查看所有的mysql服务器,找到具有最高seqno的节点,把safe_to_boostrap的值改为1
[root@mysql3 ~]# cat /var/lib/mysql/grastate.dat 
# GALERA saved state
version: 2.1
uuid:    a3b378ea-ce50-11eb-b624-0780367f3ddd
seqno:   7
safe_to_bootstrap: 1
[root@mysql3 ~]# systemctl start mysql@bootstrap.service

# 启动其他主机的mysql服务
[root@mysql1 ~]# systemctl start mysql
[root@mysql2 ~]# systemctl start mysql

存储引擎

概述

mysql> show engines;  # DEFAULT表示默认使用的引擎,
mysql> show create table nsd2021.departments\G
*************************** 1. row ***************************
       Table: departments
Create Table: CREATE TABLE `departments` (
  `dept_id` int(4) NOT NULL AUTO_INCREMENT,
  `dept_name` varchar(10) DEFAULT NULL,
  PRIMARY KEY (`dept_id`)
) ENGINE=InnoDB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8mb4
1 row in set (0.00 sec)

# 或

mysql> use nsd2021;
mysql> show table status\G
*************************** 1. row ***************************
           Name: departments
         Engine: InnoDB
        Version: 10
     Row_format: Dynamic
           Rows: 8
 Avg_row_length: 2048
    Data_length: 16384
Max_data_length: 0
   Index_length: 0
      Data_free: 0
 Auto_increment: 9
    Create_time: 2021-04-19 20:41:46
    Update_time: 2021-04-19 20:41:46
     Check_time: NULL
      Collation: utf8mb4_general_ci
       Checksum: NULL
 Create_options:
        Comment:
*************************** 2. row ***************************
           Name: employees
         Engine: InnoDB
        Version: 10
     Row_format: Dynamic
           Rows: 133
 Avg_row_length: 123
    Data_length: 16384
Max_data_length: 0
   Index_length: 16384
      Data_free: 0
 Auto_increment: 134
    Create_time: 2021-04-19 20:41:46
    Update_time: 2021-04-19 20:41:47
     Check_time: NULL
      Collation: utf8mb4_general_ci
       Checksum: NULL
 Create_options:
        Comment:
*************************** 3. row ***************************
           Name: salary
         Engine: InnoDB
        Version: 10
     Row_format: Dynamic
           Rows: 8066
 Avg_row_length: 44
    Data_length: 360448
Max_data_length: 0
   Index_length: 163840
      Data_free: 0
 Auto_increment: 9577
    Create_time: 2021-04-19 20:41:47
    Update_time: 2021-04-19 20:41:49
     Check_time: NULL
      Collation: utf8mb4_general_ci
       Checksum: NULL
 Create_options:
        Comment:
3 rows in set (0.01 sec)
mysql> create table nsd2021.students(id int primary key auto_increment, name varchar(20)) engine=myisam;
Query OK, 0 rows affected (0.03 sec)

mysql> show create table nsd2021.students \G                                    *************************** 1. row ***************************
       Table: students
Create Table: CREATE TABLE `students` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4
1 row in set (0.00 sec)

读锁和写锁

行锁和表锁

MyISAM

InnoDB

MEMORY

上一篇 下一篇

猜你喜欢

热点阅读