mysql主从维护_mysql主从日常管理维护

mysql主从日常管理维护

1)查看从服务器状态

为了防止复制过程中出现故障从而导致复制进程停止,我们需要经常检查从服务器的复制状态。

一般使用show slave status命令来检查。

例如:

mysql> show slave status \G;

*************************** 1. row ***************************

Slave_IO_State: Waiting for master to send event

Master_Host: 192.168.1.109

Master_User: mysql

Master_Port: 3306

Connect_Retry: 60

Master_Log_File: mysql3306-bin.000024

Read_Master_Log_Pos: 438065348

Relay_Log_File: mysql-relay.000751

Relay_Log_Pos: 438065489

Relay_Master_Log_File: mysql3306-bin.000024

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

Replicate_Do_DB:

Replicate_Ignore_DB: mysql,test

Replicate_Do_Table:

Replicate_Ignore_Table:

Replicate_Wild_Do_Table:

Replicate_Wild_Ignore_Table:

Last_Errno: 0

Last_Error:

Skip_Counter: 0

Exec_Master_Log_Pos: 438065348

Relay_Log_Space: 438065489

Until_Condition: None

Until_Log_File:

Until_Log_Pos: 0

Master_SSL_Allowed: No

Master_SSL_CA_File:

Master_SSL_CA_Path:

Master_SSL_Cert:

Master_SSL_Cipher:

Master_SSL_Key:

Seconds_Behind_Master: 0

1 row in set (0.00 sec)

ERROR:

No query specified

在显示 的这些信息中,我们主要关心 Slave_IO_Running 和Slave_SQL_Running 这两个进程状态是否是“yes”,这两个进程的含义分表如下:

Slave_IO_Running:此进程负责从服务器(slave)从主服务器(master)上读取BINLOG日志,并写入从服务器上的中继日志中。

Slave_SQL_Running:此进程负责读取并且执行中继日志中的BINLOG日志。

只要其中有一个进程是no,则表示复制进程停止,错误原因可以从“Last_Errno”字段的值中看到。

除了查看上面的信息,用户还可以通过这个命令了解从服务器的配置情况以及当前和主服务器的同步情况,包括指向那个主服务器,主服务器的端口,复制使用的用户,当前日志恢复到位置等。这些信息都是记录在从服务器这一端的,主服务器上并没有相应的信息。

2) 主从服务器同步维护

在某些繁忙的OLTP(在线事务处理)系统上,由于主服务器更新频繁,而从服务器由于各种原因(比如硬件性能较差)导致更新速度较慢,从而使得主从服务器之间的数据差距越来越大最终对某些应用产生影响。在这种情况下,我们需要定期的进行主从服务器的数据同步,使得主

从数据差距能减到最小。常用的方法是:在负责较低的时候暂时阻塞主数据库的更新,强制主从数据库更新同步。

具体步骤如下:

1.在主服务器上,执行以下语句(注意,会阻塞主数据库的所有更新操作)

Mysql>flush tables with read lock;

Mysql>show master status \G;

记录show语句的输出的日志名和偏移量,这些都是从服务器复制的目的坐标。

2.在从服务器上,执行下面语句,其中master_pos_wait()函数的参数是前面步骤中得到的复制坐标值。

Mysql> select master_pso_wait('mysql-bin.0001','974');

这个select语句会阻塞直到从服务器达到指定的日志文件和偏移量后,返回0,如果返回-1,则表示超时退出。查询返回0时,则从服务器与主服务器同步。

3.在主服务器上,执行下面的语句允许主服务器重新开始处理更新

Mysql> unlock tables;

1、在主上 flush tables with read lock;

2、在从上slave stop

3、在主上show master status

4、在从上CHANGE MASTER TO  MASTER_HOST='192.168.1.109', Master_User='mysql', MASTER_PASSWORD='123456', MASTER_LOG_FILE='mysql3306-bin.000002', MASTER_LOG_POS=98;

5、从上slave start

6、主上 unlock tables;

3)从服务器复制出错的处理

从服务器更新失败时,首先需要确定是否是从服务器的表与主服务器的不同造成的。如果是表结构不同导致的,则修改从服务器的表与主服务器的相同,然后重新运行start slave语句。

如果不是表结构不同导致的更新失败,则需要确认手动更新是否安全,然后护士来之主服务器的更新失败的语句。跳过来自主服务器的命令:SET GLOBAL SQL_SLAVE_SKIP_COUNTER =  n ,其中n的取值为1或者2。如果来自主服务器的更新语句不使用AUTO_INCREMENT或LAST_INSERT_ID(),n值应为1,否则,值为2.原因是使用AUTO_INCREMENT或LAST_INSERT_ID()的语句需要从二进制日志中取两个事件。以下例子就是在从服务器端牟尼跳过主服务器的两个更新语句的效果。

1.首先在从服务器上停止slave线程

Mysql> stop slave;

Mysql > SET GLOBAL SQL_SLAVE_SKIP_COUNTER = 2

2.然后在主服务器上插入数据

3.从服务器端启动复制进程,检查测试的表,首先发现插入的两条记录呗跳过了,只执行了第3条插入语句。

4) log event entry exceeded max_allowed_packet的处理

如果应用中使用大的BLOG列或者长字符串,那么在从服务器上恢复的时候,可能出现“log event entry exceeded max_allowed_packet”错误,这个因为含有大文本的记录无法通过网络进行传输导致。解决的办法就是在主从服务器上增加max_allowed_packet参数的大小,这个参数的默认值是1MB,可以按照实际需要进行修改,比如下列中将其增大为512MB。

mysql> show variabl

es like 'max_allowed_packet';

+--------------------+-----------+

| Variable_name      | Value     |

+--------------------+-----------+

| max_allowed_packet | 536870912 |

+--------------------+-----------+

1 row in set (0.00 sec)

可以在配置文件中写入

[mysqldump]

quick

max_allowed_packet = 512M

5)多主复制时的自增长 变量冲突问题

在大多数情况下,一般只使用单主复制(一台主服务器对一台或者多台从服务器)。但是在某些情况下,可能会需要使用多主复制(多台主服务器对一台从服务器)。这个时候,如果主服务器的表采用自动增长变量,那么复制到从服务器的同一张表后很可能会引起主键冲突,因为系统参数auto_increment_increment和auto_increment_offset默认值为1,这样多台主服务器的自增变量列迟早会发生冲突。在单数复制时,可以采用默认设置,不会有主键冲突发生。但是使用多主复制时,就需要定制auto_increment_increment和auto_increment_offset的设置,保证多主之间复制到从数据库不会有重复冲突,比如两个master的情况可以按照以下设置:

Master1:auto_increment_increment = 2 ,auto_increment_offset =1:(1,3,5,7………)

Master2:auto_increment_increment = 2 , auto_increment_offset =0 (0,2,4,6……..)

查看:

show variables like 'auto_inc%';

6)查看从服务器的复制进度

很多情况下,我们都想知道从服务器复制的进如何。知道了这个差距,可以帮助我们判断是否需要手工来做主从的同步工作,也可以帮助我们判断从服务器上做统计的数据精度如果。这个值可以通过show processlist中的slave_SQL_running线程的time值得到,它记录了从服务器当期执行sql时间戳与系统时间之间的差距,单位是秒。

mysql> show processlist \G;

*************************** 1. row ***************************

Id: 1

User: system user

Host:

db: NULL

Command: Connect

Time: 4636437

State: Waiting for master to send event

Info: NULL

*************************** 2. row ***************************

Id: 2

User: system user

Host:

db: NULL

Command: Connect

Time: 2    这个time值就是最后执行的复制操作大概是在主服务器上2秒钟前得更新

State: Has read all relay log; waiting for the slave I/O thread to update it

Info: NULL

*************************** 3. row ***************************

Id: 625916

User: root

Host: localhost

db: NULL

Command: Query

Time: 0

State: NULL

Info: show processlist

3 rows in set (0.00 sec)

ERROR:

No query specified

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值