欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

002.MySQL高可用主从复制部署

程序员文章站 2022-04-13 15:57:08
一 基础环境 主机名 系统版本 MySQL版本 主机IP master CentOS 6.8 MySQL 5.6 172.24.8.10 slave01 CentOS 6.8 MySQL 5.6 172.24.8.11 主机名 系统版本 MySQL版本 主机IP master CentOS 6.8 ......

一 基础环境

主机名
系统版本
mysql版本
主机ip
master
centos 6.8
mysql 5.6
172.24.8.10
slave01
centos 6.8
mysql 5.6
172.24.8.11

二 实际部署

2.1 安装mysql

  1 [root@master ~]# yum list installed | grep mysql	#查看是否存在其他mysql组件
  2 [root@master ~]# yum -y remove mysql-libs.x86_64	#为避免冲突引发报错,卸载已存在的组件
  3 [root@master ~]# wget http://repo.mysql.com/mysql-community-release-el6-7.noarch.rpm
  4 [root@master ~]# rpm -ivh mysql-community-release-el6-7.noarch.rpm
  5 [root@master ~]# yum install mysql-community-server -y
  6 [root@master ~]# chkconfig --list | grep mysqld		#查看mysql是否加入启动项
  7 [root@master ~]# chkconfig mysqld on
 

2.2 初始化mysql

  1 [root@master ~]# service mysqld start
  2 [root@master ~]# mysql_secure_installation
  3 [root@master ~]# service iptables stop
  4 [root@master ~]# chkconfig iptables off
  5 [root@master ~]# vi /etc/sysconfig/selinux
  6 selinux=disabled
 
注意:以上操作在slave主机上也需要执行。
安装参考:

2.3 master my.cf配置

  1 [root@master ~]# vi /etc/my.cnf
  2 [mysqld]
  3 ……
  4 server-id=1			#设置主服务器master的id
  5 log-bin=mysql-bin		#配置二进制变更日志命名格式
 
注意:
master开启二进制日志后默认记录所有库所有表的操作,可以通过配置来指定只记录指定的数据库甚至指定的表的操作,具体在mysql配置文件的[mysqld]可添加修改如下选项:
  1 # 不同步哪些数据库
  2 binlog-ignore-db = mysql
  3 binlog-ignore-db = test
  4 binlog-ignore-db = information_schema
  5 # 只同步哪些数据库,除此之外,其他不同步
  6 binlog-do-db = mysqltest
 

2.4 创建账号

  1 [root@master ~]# mysql -uroot -p
  2 enter password:
  3 mysql> grant replication slave on *.* to 'repl_user'@'172.24.8.11' identified by 'x12345678';
  4 mysql> flush privileges;
  5 [root@master ~]# service mysqld restart
  6 [root@master ~]# mysql -uroot -p
  7 enter password:
  8 mysql> show master status;
 
file:mysql-bin.000001
position:120

2.5 slave my.cf配置

  1 [root@master ~]# vi /etc/my.cnf
  2 [mysqld]
  3 server-id=2			#设置从服务器slave的id
  4 log-bin=mysql-bin		#如果此slave是其他slave的master,则此项也必须开启
  5 relay_log=mysql-relay-bin	#配置二进制relay日志命名格式
  6 log_slave_updates=1		#表示slave将复制事件写进自己的二进制日志
  7 read_only=1
 

2.6 启动slave

  1 [root@slave01 ~]# service mysqld restart
  2 [root@slave01 ~]# mysql -uroot -p
  3 enter password:
  4 mysql> change master to master_host='172.24.8.10',
  5     -> master_user='repl_user',
  6     -> master_password='x12345678',
  7     -> master_log_file='mysql-bin.000001',
  8     -> master_log_pos=120;
  9 mysql> show slave status\g			#查看slave状态
 10 ……
 11 slave_io_state:
 12 master_host: 172.24.8.10
 13 master_user: repl_user
 14 master_port: 3306
 15 connect_retry: 60
 16 master_log_file: mysql-bin.000001
 17 read_master_log_pos: 120
 18 relay_log_file: =mysql-relay-bin.000001
 19 relay_log_pos: 4
 20 relay_master_log_file: mysql-bin.000001
 21 slave_io_running: no
 22 slave_sql_running: no
 23 ……
 24 exec_master_log_pos: 120
 25 relay_log_space: 120
 26 ……
 27 seconds_behind_master: null
 28 master_ssl_verify_server_cert: no
 29 master_info_file: /var/lib/mysql/master.info
 30 sql_delay: 0
 31 sql_remaining_delay: null
 32 slave_sql_running_state:
 33 master_retry_count: 86400
 34 ……
 
提示:
slave_io_state, slave_io_running, 和slave_sql_running是no,表明slave还没有开始复制过程。

2.7 手动同步

如果master已经存在数据,则在开启主备复制之前,需要将master和slave手动同步一次(/var/lib/mysql整个目录打包tar.gz),具体方法参考《004.mysql主库手动复制至从库》。
注意:本实验都是重新安装的mysql,可直接启动同步。

三 启动主从

3.1 slave启动主从服务

  1 [root@slave01 ~]# service mysqld restart
  2 [root@slave01 ~]# mysql -uroot -p
  3 enter password:
  4 mysql> start slave;
  5 mysql> show slave status\g			#查看slave状态
  6 ……
  7 slave_io_state: waiting for master to send event
  8 master_host: 172.24.8.10
  9 master_user: repl_user
 10 master_port: 3306
 11 connect_retry: 60
 12 master_log_file: mysql-bin.000001
 13 read_master_log_pos: 120
 14 relay_log_file: =mysql-relay-bin.000001
 15 relay_log_pos: 283
 16 relay_master_log_file: mysql-bin.000002
 17 slave_io_running: yes
 18 slave_sql_running: yes
 19 ……
 20 exec_master_log_pos: 120
 21 relay_log_space: 120
 22 ……
 23 master_info_file: /var/lib/mysql/master.info
 
提示:
slave的i/o和sql线程都已经开始运行,而且seconds_behind_master不再是null。日志的位置增加了,意味着一些事件被获取并执行了。如果你在master上进行修改,你可以在slave上看到各种日志文件的位置的变化,同样,你也可以看到数据库中数据的变化。

3.2 验证主从

在master主服务器上创建库并插入相应数据:
  1 [root@master ~]# mysql -uroot -p
  2 enter password:
  3 mysql> create database mysqltest;
  4 mysql> use mysqltest;
  5 mysql> create table user(id int(5),name char(10));
  6 mysql> insert into user values (00001,'zhangsan');
  7 在slave从服务器上进行验证:
  8 [root@master ~]# mysql -uroot -p
  9 enter password:
 10 mysql> show databases;
 11 mysql> select * from mysqltest.user;
 
结论:
从上图中的结果,我们可以看到mysql主从复制已经在起作用了,我们在主数据库中写入的数据已经复制到我们的从数据库中了。
提示:
若出现以下报错:
可尝试重启slave:
  1 mysql> reset slave;