MySql读写分离,及数据库高可用负载均衡的实现

什么是读写分离,说白了就是mysql服务器读的操作和写的操作是分开的,当然这个需要两台服务器,master负责写,slave负责读,当然我们可以使用多个slave,这样我们也实现了简单意义上的高可用和负载均衡,只不过这种调度算法只是简单的轮循。我们如何让master和slave这样进行工作呢,其实我们需要一个代理,简单来说就是一个客户端和mysql服务器之间的一个管家,当我们客户端需要操作查询数据库的时候,我们先把操作发给这个管家,然后管家通过识别,哦~原来你要进行select操作,那么我就把你这个请求发给slave,又来一个原来你需要进行的是插入insert的操作,那么我就把你这个请求发给master,当如果有多个slave的时候,我就通过slave的权重,轮循的发给每一个slave,这样我们就实现了读写分离操作,以及简单的负载均衡。

实现读写分离的工具有很多,我介绍几个,阿里巴巴的cobar,360的atlas,以及用golang写的kingshard,在很早之前,mysql官方提供了一个mysql-proxy,也是360的atlas的"爸爸",但是这个一直没有正式发布,在oracle收购sun公司之后,这个工具也彻底的消失了。最后一个就是mysql-router,它是mysql官方提供的,但是需要注意的是,这个工具不支持读写分离,它实现了失败转移和失败切换,而且这个工具有自己的ip和端口,实现了高可用。

  • 学习和安装使用kingshard实现读写分离

前面学习了golang,那我肯定是要讲kingshard了,首先说明几点,kingshard只支持一个master多个slave,不能同时存在两个master(当然你学习了后面的mysql-router,可以结合kingshard使用),这里我默认选择一个master和一个slave,kingshard的原理很简单,我们作为客户端要连接到kingshard,然后kingshard也要连接到master,这就要求有两组不同的用户密码,下面是初始要求:

1.master和slave实现主从双向复制。

2.golang环境配置好。

现在开始安装kingshard,github上有详细的安装方式,网址:https://github.com/flike/kingshard

《第28天》MySql读写分离,及数据库高可用负载均衡的实现

1.下载好了,然后开始编译
《第28天》MySql读写分离,及数据库高可用负载均衡的实现

2.编译make,然后修改配置文件vim etc/unshard.yaml,注意路径,是在当前目录中的。

主要修改的内容有一下几个:

   <1>设置ip和监听的端口,我们的kingshard和客户端可以安装在一个机子上,也可以安装在不同的机子上,端口尽量不使用3306,防止被占用。ip是监听所有的ip,端口我设置为3307,用户密码我设置默认。

《第28天》MySql读写分离,及数据库高可用负载均衡的实现

  <2>开启日志

《第28天》MySql读写分离,及数据库高可用负载均衡的实现

   <3>配置节点,我们可以认为master和slave组成一个节点,节点名称为node1,在master上添加一个用户,这个用户密码是kingshard连接mysql用的。设置master和slave的ip端口,我这里用的是master为主机,slave为虚拟机,所以要注意同一网段。

《第28天》MySql读写分离,及数据库高可用负载均衡的实现

3.在master上创建一个用户kingshard,密码为123456,记住下面这个ip地址,是你在哪个机子上安装了kingshard就写哪个机子的ip。

《第28天》MySql读写分离,及数据库高可用负载均衡的实现

4.启动kingshard, ./bin/kingshard --config etc/unshard.yaml,--config指定了配置文件,这样就算启动成功了。

《第28天》MySql读写分离,及数据库高可用负载均衡的实现

5.客户端连接到kingshard,然后进行读写测试。

《第28天》MySql读写分离,及数据库高可用负载均衡的实现

读的测试(select),理论上说是slave(172.16.65.129)返回数据:成功,数据返回的ip是129,使用的命令是select * from toutiao;

《第28天》MySql读写分离,及数据库高可用负载均衡的实现

写的操作(insert),理论上说是master(172.16.65.1)返回数据:成功,数据返回的ip是1,使用的命令是insert into toutiao values(5,"toutiao5");

《第28天》MySql读写分离,及数据库高可用负载均衡的实现

  • mysql的高可用负载均衡机制

其实我们的kingshard已经实现了基本的负载均衡了,但是我们现在的场景变化了,假设我们现在有两台服务器,互为主从,我们如何实现这两台服务器的高可用功能呢,意思就是其中一台服务器宕机,另一台还是能够继续提供服务。这里我们就应该使用mysql-router来实现了,它的作用跟kingshard有点类似,不过它有自己的ip地址,同时呢,官方建议客户端和mysql-router安装在一台服务器上,客户端通过连接mysql-router,然后mysql-router管理两台服务器,默认是从其中一台进行读写操作,但是如果默认的宕机了,另一台会继续提供服务。mysql-router有两种模式,read-write和read-only.

准备:

1.两台服务器,配置mysql主从双向复制

2.安装好mysql-router。使用模式为read-only。

mysql主从双向复制,前面的课程已经讲过了,我就不再演示,不懂的朋友可以去看看我之前的教程,然后就开始安装mysql-router,过程很简单,装包,改配置文件,启服务,监控,ok了。

1.安装mysql-router,官方有,直接下载,rpm的,安装方法我就不用说了吧。最基础了。

2.修改配置文件,vim /etc/mysqlrouter/mysqlrouter.ini,在末尾添加上这样几行,由于我mysql-router和master是一台机子,所以我监控mysql-router的端口设置成3307,防止冲突。另外为了使得后面测试过程中显示的日志多一点,我们可以把日志类型改成debug类型的。

《第28天》MySql读写分离,及数据库高可用负载均衡的实现4.重启mysqlrouter服务,service mysqlrouter restart。

5.在其中一个master上创建一个用户可以连接mysql-router,这里我创建的用户是mysqlrouter,密码是mysqlrouter。

《第28天》MySql读写分离,及数据库高可用负载均衡的实现6.使用mysqlrouter这个用户通过本地连接到mysql-router,然后进行测试。

《第28天》MySql读写分离,及数据库高可用负载均衡的实现

日志显示登录的信息:可以很明显的看出来现在是ip地址为172.16.65.1的master正在提供服务

《第28天》MySql读写分离,及数据库高可用负载均衡的实现现在模拟172.16.65.1这台服务器宕机,然后重新连接mysql-router,看看是那一台服务器提供服务。

《第28天》MySql读写分离,及数据库高可用负载均衡的实现

宕机之后,现在提供服务的master变成了172.16.65.129了。《第28天》MySql读写分离,及数据库高可用负载均衡的实现

所有的都测试成功了,大家动手试一试吧!

  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hu_wenjie

您的鼓励将是我创作最大的动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值