【TiDB 最佳实践系列】HAProxy
作者: 张鱼小丸子 -PingCAP 原文来源:https://tidb.net/blog/dfc0d91b
HAProxy 在 TiDB 中的最佳实践
本文介绍 HAProxy 在 TiDB 中的最佳配置和使用方法。HAProxy 提供 TCP 协议下的负载均衡能力,TiDB 客户端通过连接 HAProxy 提供的浮动 IP 即可对数据进行操作,实现 TiDB Server 层的负载均衡。
HAProxy 简介
HAProxy 是由 C 语言编写的自由开放源码的软件,为基于 TCP 和 HTTP 协议的应用程序提供高可用性、负载均衡和代理服务。因为 HAProxy 能够快速、高效使用 CPU 和内存,所以目前使用非常广泛,许多知名网站诸如 GitHub、Bitbucket、Stack Overflow、Reddit、Tumblr、Twitter 和 Tuenti 以及亚马逊网络服务系统都在使用 HAProxy。
HAProxy 由 Linux 内核的核心贡献者 Willy Tarreau 于 2000 年编写,他现在仍然负责该项目的维护,并在开源社区免费提供版本迭代。最新的稳定版本 2.0.0 于 2019 年 8 月 16 日发布,带来更多优秀的特性。
HAProxy 部分核心功能介绍
高可用性:HAProxy 提供优雅关闭服务和无缝切换的高可用功能;
负载均衡:L4 (TCP) 和 L7 (HTTP) 两种负载均衡模式,至少 9 类均衡算法,比如 roundrobin,leastconn,random 等;
健康检查:对 HAProxy 配置的 HTTP 或者 TCP 模式状态进行检查;
会话保持:在应用程序没有提供会话保持功能的情况下,HAProxy 可以提供该项功能;
SSL:支持 HTTPS 通信和解析;
监控与统计:通过 web 页面可以实时监控服务状态以及具体的流量信息。
准备环境
在部署 HAProxy 之前,需准备好以下环境。
硬件要求
根据官方文档,对 HAProxy 的服务器硬件配置有以下建议,也可以根据负载均衡环境进行推算,在此基础上提高服务器配置。
依赖软件
根据官方文档,对操作系统和依赖包有以下建议,如果通过 yum 源部署安装 HAProxy 软件,依赖包无需单独安装。
操作系统
依赖包
epel-release
gcc
systemd-devel
执行如下命令安装依赖包:
{{< copyable “shell-regular” >}}
部署 HAProxy
HAProxy 配置 Database 负载均衡场景操作简单,以下部署操作具有普遍性,不具有特殊性,建议根据实际场景,个性化配置相关的配置文件。
安装 HAProxy
使用 yum 安装 HAProxy:
{{< copyable “shell-regular” >}}
验证 HAProxy 安装是否成功:
{{< copyable “shell-regular” >}}
HAProxy 命令介绍
执行如下命令查看命令行参数及基本用法:
{{< copyable “shell-regular” >}}
更多有关 HAProxy 命令参数的信息,可参阅 Management Guide of HAProxy 和 General Commands Manual of HAProxy。
配置 HAProxy
yum 安装过程中会生成配置模版,你也可以根据实际场景自定义配置如下配置项。
启动 HAProxy
方法一:执行
haproxy
,默认读取/etc/haproxy/haproxy.cfg
(推荐)。
{{< copyable “shell-regular” >}}
方法二:使用
systemd
启动 HAProxy。
{{< copyable “shell-regular” >}}
停止 HAProxy
方法一:使用
kill -9
。执行如下命令:
{{< copyable “shell-regular” >}}
终止 HAProxy 相关的 PID 进程:
{{< copyable “shell-regular” >}}
方法二:使用
systemd
。
{{< copyable “shell-regular” >}}
版权声明: 本文为 InfoQ 作者【TiDB 社区干货传送门】的原创文章。
原文链接:【http://xie.infoq.cn/article/8b07edfbf240447c839d84d3d】。文章转载请联系作者。
评论