Linux---MySQL主从配置相关报错合集

mysql 数据同步 出现Slave_IO_Running:No或者Slave_Sql_Running:No问题的解决方法小结

mysql主从复制经常会遇到错误而导致slave端复制中断这个时候一般就需要人工干预跳过错误才能继续。

如果是slave_io_running no了那么就我个人看有三种情况一个是网络有问题连接不上第二个是有可能my.cnf有问题配置文件怎么写就不说了网上太多了最后一个是授权的问题slave上没有权限读master上的数据replication slave和file权限是必须的。

一旦io为no了先看err日志看看报什么错很可能是网络也有可能是包太大收不了这个时候主备上改max_allowed_packet这个参数。 max_allowed_packet=1024M 可在 vi /etc/my.cnf中的[mysqld]中添加

如果是slave_sql_running no了那么也有两种可能一种是slave机器上这个表中出现了其他的写操作就是程序写了这个是会有问题的还有一种占绝大多数可能的是slave进程重启事务回滚造成的这也是mysql的一种自我保护的措施像关键时候只读一样。

跳过错误有两种方式

1.跳过指定数量的事务

mysql>slave
stop;mysql>SET
GLOBAL SQL_SLAVE_SKIP_COUNTER = 1        #跳过一个事务mysql>slave
start

其中SQL_SLAVE_SKIP_COUNTER=N;再开一下slave就可以了这个全局变量赋值为N的意思是

This statement skips the next N events from the
master. This is useful for recovering from replication stops caused by a
statement.

This statement is valid only when the slave thread
is not running. Otherwise, it produces an error.

2.修改mysql的配置文件通过slave_skip_errors参数来跳所有错误或指定类型的错误

vi /etc/my.cnf
[mysqld]
slave-skip-errors=1062,1053,1146 #跳过指定error no类型的错误
slave-skip-errors=all #跳过所有错误

相关错误实例

1、出现错误提示、

Slave I/O: error connecting to master ‘[email protected]:3306‘ - retry-time: 60  retries: 86400, Error_code: 1045

解决方法

检查网络密码以及权限相关的设置是否有误

2、出现错误提示

Error reading packet from server: File ‘/home/mysql/mysqlLog/log.000001‘ not found (Errcode: 2) ( server_errno=29)

解决方案

由于主服务器运行了一段时间产生了二进制文件而slave是从log.000001开始读取的删除主机二进制文件包括log.index文件。

3、错误提示如下

Slave SQL: Error ‘Table ‘xxxx‘ doesn‘t exist‘ on query. Default database: ‘t591‘. Query: ‘INSERT INTO `xxxx`(type,post_id,browsenum) SELECT type,post_id,browsenum FROM xxxx WHERE hitdate=‘20090209‘‘, Error_code: 1146

解决方法

由于slave没有此table表添加这个表使用slave start 就可以继续同步。

4、错误提示如下

Error ‘Duplicate entry ‘1‘ for key 1‘ on query. Default database: ‘movivi1‘. Query: ‘INSERT INTO `v1vid0_user_samename` VALUES(null,1,‘123‘,‘11‘,‘4545‘,‘123‘)‘

Error ‘You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘‘ at line 1‘ on query. Default database: ‘club‘. Query: ‘INSERT INTO club.point_process ( GIVEID, GETID, POINT, CREATETIME, DEMO ) VALUES ( 0, 4971112, 5, ‘2010-12-19 16:29:28‘,‘

1 row in set (0.00 sec)

Mysql > Slave status\G;

显示Slave_SQL_Running 为 NO

解决方法

Mysql > stop slave;
Mysql > set global sql_slave_skip_counter =1 ;
Mysql > start slave;

5、错误提示如下

# show slave status\G;

Master_Log_File: mysql-bin.000029

Read_Master_Log_Pos: 3154083

Relay_Log_File: c7-relay-bin.000178

Relay_Log_Pos: 633

Relay_Master_Log_File: mysql-bin.000025

Slave_IO_Running: Yes

Slave_SQL_Running: No

Replicate_Do_DB: club

Replicate_Ignore_DB:

Replicate_Do_Table:

Replicate_Ignore_Table:

Replicate_Wild_Do_Table:

Replicate_Wild_Ignore_Table:

Last_Errno: 1594

Last_Error: Relay log read failure: Could not parse relay log event entry. The possible reasons are: the master‘s binary log is corrupted (you can check this by running ‘mysqlbinlog‘ on the binary log), the slave‘s relay log is corrupted (you can check this by running ‘mysqlbinlog‘ on the relay log), a network problem, or a bug in the master‘s or slave‘s MySQL code. If you want to check the master‘s binary log or slave‘s relay log, you will be able to know their names by issuing ‘SHOW SLAVE STATUS‘ on this slave.

Skip_Counter: 0

Exec_Master_Log_Pos: 1010663436

这个问题原因是主数据库突然停止或问题终止更改了mysql-bin.xxx日志slave服务器找不到这个文件需要找到同步的点和日志文件然后chage master即可。

解决方法

change master to

master_host=‘211.103.156.198‘,

master_user=‘mysql,

master_password=‘password

master_port=3306,

master_log_file=‘mysql-bin.000025‘,

master_log_pos=1010663436;

6、错误提示如下

Error ‘Unknown column ‘qdir‘ in ‘field list‘‘ on query. Default database: ‘club‘. Query: ‘insert into club.question_del (id, pid, ques_name, givepoint, title, subject, subject_pid, createtime, approve, did, status, intime, order_d, endtime,banzhu_uid,banzhu_uname,del_cause,qdir) select id, pid, ques_name, givepoint, title, subject, subject_pid, createtime, approve, did, status, intime, order_d, endtime,‘1521859‘,‘admin0523‘,‘无意义回复‘,qdir from club.question where id=7330212‘

1 row in set (0.00 sec)

这个错误就说club.question_del 表里面没有qdir这个字段 造成的加上就可以了~

在主的mysql  里面查询 Desc club.question_del

在 错误的从服务器上执行  alter table question_del add qdir varchar(30) not null;

7、错误提示如下

Slave_IO_Running:
NO

这个错误就是IO 进程没连接上  想办法连接上把 把与主的POS 号和文件一定要对然后重新加载下数据。具体步骤

slave stop;
change master to master_host=‘IP地址‘,master_user=‘club‘,master_password=‘mima
‘,master_log_file=‘mysqld-bin.000048‘,MASTER_LOG_POS=396549485;

注master_log_file=‘mysqld-bin.000048‘,MASTER_LOG_POS=396549485;是从主的上面查出 来的

show master
status\G;

LOAD DATA FROM MASTER;

load data from master

slave
start;

8、错误提示如下

Error
reading packet from server:
 
Access denied; you need the REPLICATION SLAVE privilege for this operation (
server_errno=1227)

【解决办法】主服务器给的复制权限不够重新赋予权限。

 
>
grant replication slave on *.* to ‘mysql‘@‘master IP‘ identified by ‘password‘
>
flush privileges
时间: 2024-10-05 02:45:07

Linux---MySQL主从配置相关报错合集的相关文章

vc++6.0各种报错合集

背景: 由于APP对于现在的我来说,只是一个工具,对VC++6.0绝对的是浅尝辄止吧!(暂时没有太多的时间分配到这块)所以在此把错误积累下来,以备下次使用少走弯路. 正文 一.出现警告“warning c4273:inconsistent dll linkage” 在报错的XX.h头文件中可以看到如下定义 #ifdef XXX_DLL_EXPORTS #define XXX_API extern"C" __declspec(dllexport) #else #define XXX_AP

【Linux Mysql主从配置】整理主从配置遇到的坑!

说明:-u :用户名 -p :密码 --lock-all-tables :执行操作时锁住所有表,防止操作时有数据修改 1.设置mysql配置文件[ 我使用的宝塔,所以直接在软件商店的mysql里边直接进行配置设置 ] 主服务器:[mysqld]:log-bin=mysql-bin log_slave_updates=1 skip-grant-tables[跳过验证权限] server-id = 1 从服务器:[mysqld]:log-bin=relay-bin server-id = 2 ski

Linux Mysql主从同步常见问题合集

1.1       常见问题 1.Slave I/O: error connecting to master '[email protected]:3306'-retry-time: 60 retries: 86400,Error_code:1045 解决方法: 从服务器上删除掉所有的二进制日志文件,包括一个数据目录下的master.info文件和hostname-relay-bin开头的文件. master.info::记录了Mysql主服务器上的日志文件和记录位置.连接的密码. 2. Err

Linux下安装Nrpe软件相关报错

Linux下面安装nrpe软件时,如果进行配置时(./configure)  报错: 并且执行make all命令进行编译时候也报错: 解决办法:    在报错的服务器上执行yum -y install openssl-devel   命令安装ssl的库 之后再次执行./configure命令进行配置,如果配置成功应该显示如下信息: 再次使用make all 命令就不会报错了.make all完毕显示如下信息: Linux下安装Nrpe软件相关报错,布布扣,bubuko.com

Linux中mysql进入命令行报错:MYSQL ERROR 2003 (HY000): Can't connect to MySQL server on '192.168.99.192' (111)

场景:在Linux中安装mysql01和mysql02,通过VIP虚出一个VIP=192.168.99.192,mysql01为主ip为192.168.99.153,mysql02为备机ip为192.168.99.154 此时VIP在mysql01上通过 mysql01上连接VIP :mysql -h 192.168.99.192 -P 3306   结果是可以正常进入mysql命令行: 通过mysql02上远程连接VIP 会在界面上报错:mysql error 2003(HY000):Can'

Linux下mysql主从配置

mysql服务器的主从配置,这样可以实现读写分离,也可以在主库挂掉后从备用库中恢复需要两台机器,安装mysql,两台机器要在相通的局域网内主机A: 192.168.1.100从机B:192.168.1.101可以有多台从机1.先登录主机 Amysql>GRANT REPLICATION SLAVE ON *.* TO ‘backup’@’192.168.1.101‘ IDENTIFIED BY ‘123456’;赋予从机权限,有多台丛机,就执行多次2. 打开主机A的my.cnf,输入server

Mysql主从配置+读写分离

Mysql主从配置+读写分离     MySQL从5.5版本开始,通过./configure进行编译配置方式已经被取消,取而代之的是cmake工具.因此,我们首先要在系统中源码编译安装cmake工具. 注:安装前须查看是否已经安装了如下依赖包,如果没有请安装. apt-get -y install gcc g++ libncurses5-dev ncurses-devel openssl   一.主库安装及配置 1.源码安装cmake # tar xf cmake-3.0.0.tar.gz #

笔记13(FTP配置、tomcat配置、resin配置、MySQL主从配置)

FTP服务搭建与配置 FTP介绍 FTP是File Transfer Protocol(文件传输协议,简称文传协议)的英文简称,用于在Internet上控制文件的双向传输. FTP的主要作用就是让用户连接一个远程计算机(这些计算机上运行着FTP服务器程序),并查看远程计算机中的文件,然后把文件从远程计算机复制到本地计算机,或把本地计算机的文件传送到远程计算机. 小公司用的多,大企业不用FTP,因为不安全. 使用vsftpd搭建ftp服务 centos上自带vsftpd 安装:yum instal

mysql主从配置&&基于keepalived的主备切换

mysql互为主从设置 && 主备切换配置 需求说明: 1.公司架构一直是一台单独的mysql在线上跑,虽然一直没有出现什么宕机事件,但是出于一个高可用的考虑,提出主从备份.主备切换的需求: 2.实现这个需求的前一段时间只是在做数据库备份的时候实现了主从热备,为了实现主备切换功能,继续操作上述需求: 实验环境: master1:10.1.156.3:3306 master2:10.1.156.5:3306 my.cnf配置文件关于主从这块的修改: master1: server-id =