设为首页 收藏本站
查看: 1657|回复: 0

[经验分享] haproxy实现mysql的读负载均衡

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-7-15 10:03:43 | 显示全部楼层 |阅读模式
上一篇博文里面,我们只用了一个slave节点。
实际生产环境中,我们肯定有多个slave节点负责读数据库。

假设我们还有一个配置好的slave,IP为192.168.2.15。那么现在的情况是:

Master1:192.168.2.13
Master2:192.168.2.14
VIP:192.168.2.100
Slave1:192.168.2.11
Slave2:192.168.2.15
Web服务器:192.168.2.11

haproxy的安装配置
演示用法而已,我们就将haproxy安装到192.168.2.11上,能验证效果即可。

参考文档:
    官方:http://cbonte.github.io/haproxy-dconv/configuration-1.6.html
    http://blog.iyunv.com/uid-30212356-id-5698536.html
    http://blog.c1gstudio.com/archiv ... utm_medium=referral

软件版本:
haproxy-1.5.4-2 【haproxy1.6配置文件和以往的有点不一样,这里没有用最新的】
yum install haproxy -y
cd /etc/haproxy

vim haproxy.cfg 修改配置文件,修改好的配置文件如下:
global
   log         127.0.0.1 local2
    chroot     /var/lib/haproxy
    pidfile    /var/run/haproxy.pid
    maxconn    4000
    user       haproxy
    group      haproxy
    daemon

    stats socket /var/lib/haproxy/stats

defaults
    mode                    tcp
    log                     global
    option                  dontlognull
    retries                 3
    timeout http-request    10s
    timeout queue           1m
    timeout connect         10s
    timeout client          1m
    timeout server          1m
    timeout http-keep-alive 10s
    timeout check           10s
    maxconn                 3000

## 定义一个监控页面,监听在1080端口,并启用了验证机制
listenstats
    mode http
    bind 0.0.0.0:1080
    stats enable
    stats hide-version
    stats uri     /haproxy
    stats realm   Haproxy\ Statistics
    stats auth    admin:123456
    stats admin if TRUE

listenmysql
    bind 0.0.0.0:3336
    mode tcp
    option mysql-check userhaproxy_check   # 定义了一个用于后端的mysql健康检查的用户[主要:这个用户要在后端的slave上存在才行]
    balance roundrobin
    server slave1 192.168.2.11:3306 weight 1check  inter 1s rise 2 fall 2
    server slave2 192.168.2.15:3306 weight 1check  inter 1s rise 2 fall 2

在各个mysqlslave节点上创建账号
创建允许haproxy连接到数据库的账号获取其运行状态
> GRANT PROCESS ON *.* TO'haproxy_check'@'192.168.2.%';
> flush privileges;

再创建一个访问的账号,一会要通过它连接haproxy的3336节点尝试访问slave,以便验证是否能负载均衡
> GRANT ALL ON *.* TO'lirl'@'192.168.2.%' identified by '123456';
> flush privileges;

启动haproxy
/etc/init.d/haproxy start

浏览器访问http://192.168.2.11:1080/haproxy
输入用户名admin 密码123456 进到下面的界面:
wKioL1eHMhCi_eBfAAGQGI_6wcQ645.jpg
从dashboard界面,可看到slave1 已经是up状态了。slave2是down状态。因为我们实际上192.168.2.15这台主机都没开机(slave2的配置和slave1一样的方法)。

我们在其他节点,用haproxy访问后端的数据库,如下图,已经能连接到了:
wKiom1eHMjbgNu6EAABBJGL7dBw305.jpg

在slave上,用root账号登录查看,如下图,能看到lirl账号登录上来了。
wKioL1eHMjbBv22VAAAqpN1A3gs535.jpg

slave2的我就不详细演示如何配了。

最后,附上一张最终完成后机器拓扑图:
wKiom1eHMjbQNzj-AACKnLlAZqs372.jpg


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-244376-1-1.html 上篇帖子: haproxy高可用以及双主模式(二) 下篇帖子: HaProxy实现动态修改Haproty配置文件 mysql
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表