Haproxy是目前比较流行的一种群集调度工具,同类群集调度工具有很多,如LVS和Nginx。相比较而言,LVS性能最好,但搭建相对复杂;Nginx的upstream模块支持群集功能,但是对群集节点健康检查功能不强,性能没有Haproxy好。
相关知识点:HTTP请求:HTTP是一个基于TCP/IP通信协议来传递数据(HTML 文件, 图片文件, 查询结果等),HTTP是一个属于应用层的面向对象的协议,由于其简捷、快速的方式,适用于分布式超媒体信息系统。HTTP协议工作于客户端-服务端架构为上。浏览器作为HTTP客户端通过URL向HTTP服务端即WEB服务器发送所有请求。Web服务器根据接收到的请求后,向客户端发送响应信息。
HTTP请求方法
根据HTTP标准,HTTP请求可以使用多种请求方法。
HTTP1.0定义了三种请求方法: GET, POST 和 HEAD方法。
HTTP1.1新增了五种请求方法:OPTIONS, PUT, DELETE, TRACE 和 CONNECT 方法。
HTTP工作原理
HTTP协议定义Web客户端如何从Web服务器请求Web页面,以及服务器如何把Web页面传送给客户端。HTTP协议采用了请求/响应模型。客户端向服务器发送一个请求报文,请求报文包含请求的方法、URL、协议版本、请求头部和请求数据。服务器以一个状态行作为响应,响应的内容包括协议的版本、成功或者错误代码、服务器信息、响应头部和响应数据。
以下是 HTTP 请求/响应的步骤:
1、客户端连接到Web服务器
一个HTTP客户端,通常是浏览器,与Web服务器的HTTP端口(默认为80)建立一个TCP套接字连接。例如,http://www.oakcms.cn。
2、发送HTTP请求
通过TCP套接字,客户端向Web服务器发送一个文本的请求报文,一个请求报文由请求行、请求头部、空行和请求数据4部分组成。
3、服务器接受请求并返回HTTP响应
Web服务器解析请求,定位请求资源。服务器将资源复本写到TCP套接字,由客户端读取。一个响应由状态行、响应头部、空行和响应数据4部分组成。
4、释放连接TCP连接
若connection 模式为close,则服务器主动关闭TCP连接,客户端被动关闭连接,释放TCP连接;若connection 模式为keepalive,则该连接会保持一段时间,在该时间内可以继续接收请求;
5、客户端浏览器解析HTML内容
客户端浏览器首先解析状态行,查看表明请求是否成功的状态代码。然后解析每一个响应头,响应头告知以下为若干字节的HTML文档和文档的字符集。客户端浏览器读取响应数据HTML,根据HTML的语法对其进行格式化,并在浏览器窗口中显示。
例如:在浏览器地址栏键入URL,按下回车之后会经历以下流程:
1、浏览器向 DNS 服务器请求解析该 URL 中的域名所对应的 IP 地址;
2、解析出 IP 地址后,根据该 IP 地址和默认端口 80,和服务器建立TCP连接;
3、浏览器发出读取文件(URL 中域名后面部分对应的文件)的HTTP 请求,该请求报文作为 TCP 三次握手的第三个报文的数据发送给服务器;
4、服务器对浏览器请求作出响应,并把对应的 html 文本发送给浏览器;
5、释放 TCP连接;
6、浏览器将该 html 文本并显示内容;
使用nginx-1.12.0.tar.gz安装包进行编译安装
yum -y install pcre-devel zlib-devel #安装环境依赖
useradd -M -s /sbin/nologin nginx #创建nginx专门的用户账号,不建立宿主文件夹,禁止登录到Shell环境
tar zxvf nginx-1.12.0.tar.gz -C /usr/src #解压安装包到指定的目录下
cd /usr/src/nginx-1.12.0
./configure --prefix=/usr/local/nginx --user=nginx --group=nginx
make && make install
安装完后的默认信息如下:
默认安装目录:/usr/local/nginx
建立默认的访问页
cd /usr/local/nginx/html
echo "AAA" > index.html #在默认的Web目录下创建一个简单的测试页面
/usr/local/nginx/sbin/nginx #启动Nginx
netstat -anpt | grep nginx #检测Nginx是否已启动
然后在浏览器中访问测试页
需要注意的是:关闭防火墙和SELinux,避免无法访问测试页面
在使用同样的方法搭建Nginx2
echo "BBBBBBB" > /usr/local/nginx/html/index.html #创建测试页
Nginx2的测试页面
1、使用haproxy-1.5.19.tar.gz安装包进行编译安装
yum -y install pcre-devel bzip2-devel #安装依赖
tar zxvf haproxy-1.5.19.tar.gz -C /usr/src #将haproxy安装包解药到指定位置
cd /usr/src/haproxy-1.5.19
make TARGET=linux26 #64位系统
make install
2、配置Haproxy
建立Haproxy的配置文件
mkdir /etc/haptoxy
cp /usr/src/haproxy-1.5.19/examples/haproxy.cfg /etc/haptoxy #将haproxy.cfg文件复制到配置文件目录
根据目前的群集设计,haproxy.cfg配置文件如下:
# this config needs haproxy-1.1.28 or haproxy-1.2.1
global
log 127.0.0.1 local0 #配置日志记录,local0为日志设备,默认存放到系统日志
log 127.0.0.1 local1 notice #notice为日志级别,通常有24个级别
#log loghost local0 info
maxconn 4096 #最大连接数
uid 99 #用户UID
gid 99 #用户GID
daemon
#debug
#quiet
defaults
log global #定义日志为global配置中的日志定义
mode http #模式为http
option httplog #采用http日志格式记录日志
option dontlognull
retries 3 #检测节点服务器失败次数,连接达到三次失败,则认为节点不可用
maxconn 2000 #最大连接数
contimeout 5000 #连接超时时间
clitimeout 50000 #客户端超时时间
srvtimeout 50000 #服务器超时时间
listen webcluster 0.0.0.0:80 #定义一个webcluster的应用
option httpchk GET /index.html #检查服务器的index.html文件
balance roundrobin #强制将请求发送到已经down掉的服务器
server inst1 192.168.248.10:80 check inter 2000 fall 3 #定义在线节点
server inst2 192.168.248.20:80 check inter 2000 fall 3 #定义备份节点
Haproxy配置文件通常分为三个部分,及“global”、“defaults”和“listen”。“global”为全局配置,“defaults”为默认配置,“listen”为应用组件配置
“defaults”配置项配置默认参数,一般会被应用组件继承,如果在应用组件中没有特别声明,将安装默认配置参数设置
3、创建自启动脚本
cp /usr/src/haproxy-1.5.19/examples/haproxy.cfg /etc/haproxy/
ln -s /usr/local/sbin/haproxy /usr/sbin/haproxy
chmod +x /etc/init.d/haproxy
chkconfig --add /etc/init.d/haproxy #添加到系统服务
/etc/init.d/haproxy start #启动haproxy
4、测试
在客户端浏览器打开http://192.168.248.30,显示的结果如下:
再次打开新的浏览器页面访问http://192.168.248.30,显示的结果如下:
1、修改Haproxy配置文件中的关于日志配置的选项,将原有的日志配置更改为如下配置:
global
log /dev/log local0 info
log /dev/log local0 notice
这两行配置主要是将Haproxy的“info”及“notice”日志分别记录到不同的日志文件中
重新启动Haproxy,完成Haproxy配置
2、修改rsyslog配置
为了便于管理,将Haproxy相关的配置独立到/etc/rsyslog.d/haproxy.conf,rsyslog启动时会自动加载此目录下的所有配置文件
vim /etc/rsyslog.d/haproxy.conf
内容如下:
if ($programname == 'haproxy' and $syslogseverity-text == 'info') then -/var/log/haproxy/haproxy-info.log
& ~
if ($programname == 'haproxy' and $syslogseverity-text == 'notice') then -/var/log/haproxy/haproxy-notice.log
& ~
这里配置的语法是使用了rainerscript"脚本语言。
这部分配置是将Haproxy的“info”日志记录到/var/log/haproxy/haproxy-info.log下,将“notice”日志记录到/var/log/haproxy/haproxy-notice.log下,其中“&~”表示日志写入日志文件后,rsyslog停止处理这个信息。
保存配置文件并重启rsyslog服务,完成rsyslog配置
3、测试日志信息
在客户端浏览器访问http://192.168.248.30/index.html后可以使用以下命令即时查看日志信息
tail -f /var/log/haproxy/haproxy-info.log
得到的结果
参数 | 参数说明 | 优化建议 |
maxconn | 最大连接数 | 此参数根据应用的实际使用情况进行调整,推荐使用10240,同时“defaults”中的最大连接数的值不能超过“global”段中的定义 |
daemon | 守护进程模式 | Haproxy可以使用非守护进程模式启动,生产环境建议使用守护进程模式启动 |
nbproc | 负载均衡的并发进程数 | 建议与当前服务器CPU核数相等或为其2倍 |
retries | 重试次数 | 此参数主要用于对群集节点的检查,如果节点多,且并发量大,设置为2次或3次;在服务器节点不多的情况下,可以设置5次或6次 |
option http-server-close | 主动关闭http请求选项 | 建议在生产环境中使用此选项,避免由于timeout时间设置过长导致http连接堆积 |
timeout http-keep-alive | 长连接超时时间 | 此选项设置长连接超时时间,具体参考应用自身特点设置,可以设置为10s |
timeout http-request | http请求超时时间 | 建议将此时间设置为5~10s,增加http连接释放速度 |
timeout client | 客户端超时时间 | 如果访问量过大,节点响应慢,可以将此时间设置短一些,建议设置为1min左右就可以了 |