mysql主从同步故障解决

来源:互联网 发布:阿里云费用提现 编辑:程序博客网 时间:2024/06/11 08:55
A、故障现象 : 无法连接 mysql 
错误信息 :ERROR 1130: Host xx.xx.xx.xx is not allowed to connect to this MySQL server 
原因 : mysql服务器没有赋予此客户端远程连接的权限。 
检查 :在mysql服务器本地查询mysql库里user表对应的host是否包含客户端机器的IP(%为不限制IP允许远程连接)。 

处理 :修改mysql库下的user表:update user set host = '%'  where user ='XXX';flush privileges

B:MySQL的1236错误即:Could not find first log file name in binary log index file
   原因:网络通信的问题也有可能是日志读取错误的问题
   解决方案:1检查网络通信是否正常2 刷新日志,重启slave

C、故障现象 : 无法连接 mysql 
  错误信息 :ERROR 1130: Host xx.xx.xx.xx is not allowed to connect to this MySQL server 
  原因 : mysql服务器没有赋予此客户端远程连接的权限。 
  检查 :在mysql服务器本地查询mysql库里user表对应的host是否包含客户端机器的IP(%为不限制IP允许远程连接)。 
  处理 :修改mysql库下的user表:update user set host = '%'  where user ='XXX';flush privileges;                                  


D、还有就是应该是常遇到的mysql故障(启动MySql提示:The server quit without updating PID file(…)失败 ),下面附上网上常用的解决方案:

1.可能是/usr/local/MySQL/data/rekfan.pid文件没有写的权限
解决方法 :给予权限,执行 “chown -R mysql:mysql /var/data” “chmod -R 755 /usr/local/mysql/data”  然后重新启动mysqld!
2.可能进程里已经存在mysql进程
解决方法:用命令“ps -ef|grep mysqld”查看是否有mysqld进程,如果有使用“kill -9  进程号”杀死,然后重新启动mysqld!
3.可能是第二次在机器上安装mysql,有残余数据影响了服务的启动。
解决方法:去mysql的数据目录/data看看,如果存在mysql-bin.index,就赶快把它删除掉吧,它就是罪魁祸首了。本人就是使用第三条方法解决的 !http://blog.rekfan.com/?p=186
4.mysql在启动时没有指定配置文件时会使用/etc/my.cnf配置文件,请打开这个文件查看在[mysqld]节下有没有指定数据目录(datadir)。
解决方法:请在[mysqld]下设置这一行:datadir = /usr/local/mysql/data
5.skip-federated字段问题
解决方法:检查一下/etc/my.cnf文件中有没有没被注释掉的skip-federated字段,如果有就立即注释掉吧。
6.错误日志目录不存在
解决方法:使用“chown” “chmod”命令赋予mysql所有者及权限
7.selinux惹的祸,如果是centos系统,默认会开启selinux
解决方法:关闭它,打开/etc/selinux/config,把SELINUX=enforcing改为SELINUX=disabled后存盘退出重启机器试试。

此外。最最重要的是看日志,具体问题具体分析,以上整理仅供参考。


原创粉丝点击