mysql读写分离配置

随着网站访问和请求量的增加,单台数据库服务器的连接已耗尽,会出现连接请求还在等待,或是数据库服务器崩溃等现象,这时候我们考虑如何减少数据库的连接,可以通过优化代码、使用缓存、数据库读写分离等方式解决此问题。
什么是读写分离:将数据库的读、写操作分别作用到不同的数据库(不同物理机)上。
适用场景:读操作远大于写操作,包含大量复杂统计、离线计算等任务(比如定时按各维度对数据进行统计分析,或者结算佣金等)
研究了一阵,在配置的过程中出现各种问题。。今天刚配置好
windows系统环境:本机+VM虚拟机:MySql5.6,先安装好MySql
找到MySql5.6的 my.ini配置文件,在 C:\ProgramData\MySQL\MySQL Server 5.6目录中,ProgramData文件夹默认是隐藏的
Mysql主从同步的现实:
   1、Master库将变更记录到binlog中
   2、Slave将master的binlog拷贝到它的relay log(中继日志)中
   3、slave重做中继日志中的事件
可以通过中间价实现读写分离,如Ameba,Corba,mysql-Proxy(官方)

实践

A:主库操作
1、在my.ini文件的[mysqld]节中添加如下配置项:
server-id=1
log-bin=master-bin.log
sync_binlog=1
binlog-do-db=d #对数据库d记录日志,可以不配置此参数,我的未配置

2、使用root用户登录主库mysql,为同步操作创建一个用户,从库通过该用户同步主库数据
3、对待同步用户授权:GRANT REPLICATION SLAVE ON . to ‘test’@’%’ identified by ‘test’;
4、重启主库mysql服务,并再次登录后查看主库状态:show master status;
这里写图片描述
记住下面的 master-bin.000001 和 422 这是从库要同步的文件和同步的位置

B:从库操作
1、登录虚拟机,在my.ini文件的[mysqld]节中添加如下配置项:
server-id=2
log-bin=myslave-bin.log
sync_binlog=1

2、使用root用户登录从库mysql,修改从库的master信息
change master to master_host=’192.168.1.109’,master_user=’test’,master_password=’test’,master_log_file=’mysql-bin.,000001’,master_log_pos=422;–注意日志编号

3、启动从库:start slave;
4、查看从库状态:show slave status;下面红色框框里面的两个参数都是Yes,则说明主从配置成功!,之前很悲剧,Slave_IO_Running一直是No或者Connecting.
这里写图片描述

至此配置完成。。。下面测试是否主库的修改会同步到从库。。。
用上面创建的test用户登录主库,打开cmd命令,定位到mysql的安装目录的bin目录,cd C:\ProgramData\MySQL\MySQL Server 5.6
这里写图片描述

登录从库,查看从库的test库是否新增了表t和数据
这里写图片描述

再执行update命令试试
这里写图片描述

ok,测试完成,顺利通过。还有很多不足之处。慢慢改进
配置好读写分离后,可以通过中间件去实现数据库读写的自动分配

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值