mysql主从复制安装与配置一例

发布时间:2019-10-22编辑:脚本学堂
本文介绍下,在centos中配置mysql主从复制的一个例子,有需要的朋友,参考下吧。

环境:
 

主从服务器上的mysql/ target=_blank class=infotextkey>mysql数据库版本同为5.1.34
主机IP:192.168.0.1
从机IP:192.168.0.2

一. MySQL主服务器配置
1.编辑配置文件/etc/my.cnf
 

复制代码 代码示例:
# 确保有如下行
server-id = 1
log-bin=mysql-bin
binlog-do-db=mysql  #需要备份的数据库名,如果备份多个数据库,重复设置这个选项即可
binlog-ignore-db=mysql  #不需要备份的数据库名,如果备份多个数据库,重复设置这个选项即可
log-slave-updates #这个参数一定要加上,否则不会给更新的记录些到二进制文件里
slave-skip-errors #是跳过错误,继续执行复制操作

2.建立用户
 

复制代码 代码示例:
mysql> grant replication slave on *.* to slave@192.168.0.2 identified by ‘111111′;
# grant replication slave on *.* to ‘用户名’@'主机’ identified by ‘密码’;
# 可在Slave上做连接测试: mysql -h 192.168.0.1 -u test -p

3.锁主库表
 

复制代码 代码示例:
mysql> FLUSH TABLES WITH READ LOCK;

4.显示主库信息
记录File和Position,从库设置将会用到
 

复制代码 代码示例:
mysql> SHOW MASTER STATUS;
+------------------+----------+--------------+------------------+
| File             | Position | Binlog_do_db | Binlog_ignore_db |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 106      |              |                  |
+------------------+----------+--------------+------------------+

5.另开一个终端,打包主库
 

复制代码 代码示例:
cd /usr/local/mysql  #mysql库目录
tar zcvf var.tar.gz var

二.MySQL从服务器配置
1、传输拿到主库数据包、解包
 

复制代码 代码示例:
# cd /usr/local/mysql
# scp 192.168.0.1:/usr/local/mysql/var.tar.gz .
# tar zxvf var.tar.gz

2、查看修改var文件夹权限
 

复制代码 代码示例:
# chown -R mysql:mysql var

3.编辑 /etc/my.cnf
 

复制代码 代码示例:
server-id=2
log-bin=mysql-bin
master-host=192.168.0.1
master-user=slave
master-password=111111
master-port=3306
replicate-do-db=test  #需要备份的数据库名
replicate-ignore-db=mysql #忽略的数据库
master-connect-retry=60 #如果从服务器发现主服务器断掉,重新连接的时间差(秒)
log-slave-updates #这个参数一定要加上,否则不会给更新的记录些到二进制文件里
slave-skip-errors #是跳过错误,继续执行复制操作

4、验证连接MASTER
 

复制代码 代码示例:
# mysql -h192.168.0.1 -uslave -ppassword
mysql> show grants for slave@192.168.0.2;

5、在SLAVE上设置同步
设置连接MASTER MASTER_LOG_FILE为主库的File,MASTER_LOG_POS为主库的Position
 

复制代码 代码示例:
mysql> slave stop;
mysql> CHANGE MASTER TO MASTER_HOST='192.168.0.1',MASTER_USER='slave',MASTER_PASSWORD='111111',MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=106;

6、启动SLAVE服务
 

复制代码 代码示例:
mysql> slave start;

7、查看SLAVE状态
 

复制代码 代码示例:
mysql> SHOW SLAVE STATUSG;
 

其中 Slave_IO_Running 和 Slave_SQL_Running 两列的值都为 "Yes",表明 Slave 的 I/O 和 SQL 线程都在正常运行。

8、解锁主库表
 

复制代码 代码示例:
mysql> UNLOCK TABLES;
 

到此主从库搭建成功。可以在主库上插入数据测试同步是否正常。

常见错误及解决方法:
1:在从库上面show slave statusG;出现下列情况,
         

Slave_IO_Running: Yes
          Slave_SQL_Running: No
          Seconds_Behind_Master: NULL
 

原因:
a.程序可能在slave上进行了写操作
b.也可能是slave机器重起后,事务回滚造成的.

解决方法:
进入master
 

复制代码 代码示例:
mysql> show master status;
+----------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+----------------------+----------+--------------+------------------+
| mysql-bin.000040 | 324 | | |
+----------------------+----------+--------------+------------------+

然后到slave服务器上执行手动同步
 

复制代码 代码示例:
slave stop;
change master to
master_host='10.14.0.140',
master_user='repl',
master_password='111111',
master_port=3306,
master_log_file='mysql-bin.000040',
master_log_pos=324;
slave start;
show slave statusG;

2、现象:从数据库无法同步,show slave status显示Slave_IO_Running为No,Seconds_Behind_Master为null
解决:重启主数据库
 

复制代码 代码示例:
service mysql restart
mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 98 | | |
+------------------+----------+--------------+------------------+
slave stop;
change master to Master_Log_File='mysql-bin.000001',Master_Log_Pos=98
slave start;

或是这样:
 

复制代码 代码示例:
stop slave;
set global sql_slave_skip_counter =1;
start slave;

这个现象主要是master数据库存在问题,我在实际的操作中先重启master后重启slave即可解决这问题,出现此问题,必须要要重启master数据库。
1.主辅库同步主要是通过二进制日志来实现同步的。