Mysql主从配置及问题解决思路

本文档详细介绍了如何配置MySQL的主从复制,实现读写分离。首先在Windows和Ubuntu上安装MySQL,然后在主服务器上创建用于同步的用户,并启用二进制日志。接着在从服务器上配置相关参数,连接主服务器并启动从服务器。在遇到问题时,可通过检查错误日志和调整配置来解决。确保Slave_IO_Running和Slave_SQL_Running均为Yes以保持正常运行。
摘要由CSDN通过智能技术生成

Mysql主从配置,实现读写分离
概述:搭设一台Master服务器(win8.1系统,Ip:192.168.0.104),搭设两台Slave服务器(虚拟机——一台Ubuntu,一台 Windows Server 2003)
原理:主服务器(Master)负责网站NonQuery操作,从服务器负责Query操作,用户可以根据网站功能模特性块固定访问Slave服务器,或者自己写个池或队列,自由为请求分配从服务器连接。主从服务器利用MySQL的二进制日志文件,实现数据同步。二进制日志由主服务器产生,从服务器响应获取同步数据库。
具体实现:
1、在主从服务器上都装上MySQL数据库,windows系统鄙人安装的是mysql_5.5.25.msi版本,Ubuntu安装的是mysql-5.6.22-linux-glibc2.5-i686.tarMysql主从配置,实现读写分离
windows安装mysql就不谈了,一般地球人都应该会。鄙人稍微说一下Ubuntu的MySQL安装,我建议不要在线下载安装,还是离线安装的好。
参考  http://www.linuxidc.com/Linux/2013-01/78716.htm
(1)如果您不是使用root用户登录,建议 su - root 切换到Root用户安装,那就不用老是 sudo 了。
(2)存放解压的mysql 文件夹,文件夹名字最好改成mysql
(3)在./support-files/mysql.server start 启动MySQL的时候,可能会出现一个警告,中文意思是启动服务运行读文件时,忽略了my.cnf文件,那是因为my.cnf的文件权限有问题,mysql会认为该文件有危险不会执行。但是mysql还会启动成功,但如果下面配置从服务器参数修改my.cnf文件的时候,你会发现文件改过了,但是重启服务时,修改过后的配置没有执行,而且您 list一下mysql的文件夹下会发现很多.my.cnf.swp等中间文件。这都是因为MySQL启动时没有读取my.cnf的原因。这时只要将my.cnf的文件权限改成my_new.cnf的权限一样就Ok,命令:chmod 644 my.cnf就Ok

(4)Ubuntu中修改文档内容没有Vim,最好把Vim 装上,apt-get install vim,不然估计会抓狂。
这时候我相信MySQL应该安装上去了。
2、配置Master主服务器
(1)在Master MySQL上创建一个用户‘repl’,并允许其他Slave服务器可以通过远程访问Master,通过该用户读取二进制日志,实现数据同步。
创建用于读取日志的数据库用户
(2)找到MySQL安装文件夹修改my.Ini文件。mysql中有好几种日志方式,这不是今天的重点。我们只要启动二进制日志log-bin就ok。
在[mysqld]下面增加下面几行代码
View Code
(3)查看日志
mysql> SHOW MASTER STATUS;
±------------------±---------±-------------±-----------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
±------------------±---------±-------------±-----------------+
| master-bin.000001 | 1285 | | |
±------------------±---------±-------------±-----------------+
1 row in set (0.00 sec)
重启MySQL服务
3、配置Slave从服务器(windows)
(1)找到MySQL安装文件夹修改my.ini文件,在[mysqld]下面增加下面几行代码
my.cnf 配置
重启MySQL服务
(2)连接Master
change master to master_host=‘192.168.0.104’, //Master 服务器Ip
master_port=3306,
master_user=‘repl’,
master_password=‘mysql’,
master_log_file=‘master-bin.000001’,//Master服务器产生的日志
master_log_pos=0;
(3)启动Slave
start slave;
4、Slave从服务器(Ubuntu)
(1)找到MySQL安装文件夹修改my.cnf文件,vim my.cnf
s

(2) ./support-files/myql.server restart 重启MySQL服务 , ./bin/mysql 进入MySQL命令窗口
(3)连接Master
change master to master_host=‘192.168.0.104’, //Master 服务器Ip
master_port=3306,
master_user=‘repl’,
master_password=‘mysql’,
master_log_file=‘master-bin.000001’,//Master服务器产生的日志
master_log_pos=0;
(4)启动Slave
start slave;

问题及解决思路
Mysql主从读写分离问题
SHOW SLAVE STATUS\G; 查看从服务器状态

Slave_IO_Running: Yes
Slave_SQL_Running: Yes

上为正常状态;
Slave_IO_Running:no---------------------检查主从网络连接,my.cnf配置
Slave_SQL_running:no-------------------根据具体error排查,必要时可跳过并重启slave
方法一:mysql> stop slave;
mysql> set GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
mysql>start slave ;

方法二:重新配置slave
mysql> change master to
master_host=‘192.168.6.150’,
master_user=‘repl’,
master_password=‘123456’,
master_port=3306,
master_log_file=master-bin.000003’,
master_log_pos=10787219;--------------------------在master中运行show master status;

方法三:跳过错误
在my.cnf中增加配置
slave-skip-errors=1062,1053,1146,1032 #跳过指定error no类型的错误 重启mysql;

**

遇见错误请从LOG信息入手

**

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值