Haproxy+Nginx搭建web群集

Haproxy介绍

是一种常见的Web集群调度器
目前常见的Web集群调度器分为软件和硬件,软件通常使用开源的LVS、 Haproxy、 Nginx,硬件一般使用比较多的是F5,也有很多人使用国内的一些产品,如梭子鱼、绿盟等

LVS和Haproxy区别

LVS虽然在企业应用中抗负载能力很强,但存在不足
LVS不支持正则处理,不能实现动静分离
对于大型网站,LVS的实施配置复杂,维护成本相对较高
Haproxy是一款可提供高可用性、负载均衡、及基于TCP和HTTP应用的代理的软件
特别适用于负载特别大的Web站点
运行在当前的硬件上可支持数以万计的并发连接连接请求

Haproxy调度算法

RR 轮询调度算法
Round Robin
这种算法是最简单的,就是按依次循环的方式将请求调度到不同的服务器上,该算 法最大的特点就是简单。轮询算法假设所有的服务器处理请求的能力都是一样的,调度器会将所有的请求平均分配给每个真实服务器,不管后端 RS 配置和处理能力,非常均衡地分发下去。

LC 最少连接数算法
Least Connections
这个算法会根据后端 RS 的连接数来决定把请求分发给谁,比如 RS1 连接数比 RS2 连接数少,那么请求就优先发给 RS1

SH 源地址散列调度算法
Source Hashing
上一个连接谁,第二次就连接谁
与目标地址散列调度算法类似,但它是根据源地址散列算法进行静态分配固定的服务器资源。

Haproxy配置文件

Haproxy配置文件通常分为三个部分

  • global:为全局配置
  • defaults:为默认配置
  • listen:为应用组件配置

global配置参数

  • log127.0.0.1 lcal0:配置日志记录,local0为日志设备,默认存放到系统日志
  • log127.0.0.1 loca1 notice:notice为日志级别,通常有24个级别,下面会说
  • maxconn4096:最大连接数
  • uid 99:用户uid
  • gid 99:用户gid
  • defaults配置项配置默认参数,一般会被应用组件继承,如果在应用组件中没有特别声明,将安装默认配置参数设置
  • log global:定义日志为global配置中的日志定义
  • mode http:模式为http
  • option httplog:采用http日志格式记录日志
  • retries :检查节点服务器失败连续达到三次则认为节点不可用
  • maxconn2000:最大连接数
  • contimeout :连接超时时间
  • clitimeout :客户端超时时间
  • srvtimeout :服务器超时时间

listen配置项目一般为配置应用模块参数

  • listen appli4- backup 0.0.0.0:10004:定义一个appli4- backup的应用
  • option httpchk /index.html检查服务器的index.html文件
  • option persist:强制将请求发送到已经down掉的服务器
  • balance roundrobin:负载均衡调度算法使用轮询算法
  • server inst1 192.168.114.56:80 check inter 2000 fall 3:定义在线节点
  • server inst2 192.168 114.56:81 check inter 2000 fall 3 backup:定义备份节点

Haproxy日志管理

Haproxy的日志默认是输出到系统的 syslog中,在生产环境中一般单独定义出来
定义的方法步骤

  1. 修改 Haproxy配置文件中关于日志配置的选项,加入配置
    log /dev/log local0 info
    log /dev/log local0 notice
  2. 修改 rsyslog配置,将 Haproxy相关的配置独立定义到
    haproxy.conf,并放到/etc/rsyslog.d/下
  3. 保存配置文件并重启 rsyslog服务,完成 rsyslog配置

日志文件解释

  • 日志的level: local0~local7 16~23保留为本地使用
  • emerg 0 系统不可用
  • alert 1 必须马上采取行动的事件
  • crit 2 关键的事件
  • err 3 错误事件
  • warning 4 警告事件
  • notice 5 普通但重要的事件
  • info 6 有用的信息
  • debug 7 调试信息

Haproxy可优化参数

在现网环境当中,服务器的负载越来越大, 所以haproxy参数优化相当重要

  • maxconn:最大连接数,根据应用实际情况进行调整,推荐使用10 240
  • daemon:守护进程模式, Haproxy可以使用非守护进程模式启动,建议使用守护进程模式启动
  • nbproc:负载均衡的并发进程数,建议与当前服务器CPU核数相等或为其2倍
  • retries:重试次数,主要用于对集群节点的检查,如果节点多,且并发量大,设置为2次或3次
  • option http-server-close:主动关闭http请求选项,建议在生产环境中使用此选项
  • timeout http-keep-alive:长连接超时时间,设置长连接超时时间,可以设置为10s
  • timeout http-request:http请求超时时间,建议将此时间设置为5~10s,增加http连接释放速度
  • timeout client:客户端超时时间,如果访问量过大,节点响应慢,可以将此时间设置短一些,建议设置为1min左右就可以了

来吧!展示!!

实验描述

实验拓扑图
在这里插入图片描述两台web服务器安装nginx
一台调度器安装Haproxy
客户端使用win10,有浏览器就行

调度器IP:192.168.10.20
ngin01 IP:192.168.10.30
ngin02 IP:192.168.10.31
客户端 IP:192.168.10.100

实验 START!!

配置NGINX服务器
两台Web服务器编译安装 Nginx

[root@ngin01 bao]# yum -y install \
> gcc \
> gcc-c++ \
> make pcre-devel \
> zlib-devel
[root@ngin01 bao]#  useradd -M -s /sbin/nologin nginx
[root@ngin01 bao]# tar zxvf nginx-1.12.2.tar.gz 
[root@ngin01 nginx-1.12.2]# cd nginx-1.12.2/
[root@ngin01 nginx-1.12.2]# ./configure \
> --prefix=/usr/local/nginx \
> --user=nginx \
> --group=nginx \
> --with-http_stub_status_module
[root@ngin01 nginx-1.12.2]# make && make install
[root@ngin01 man]#  ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
[root@ngin01 man]# nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
[root@ngin01 /]# cd /usr/local/nginx/html/
[root@ngin01 html]# ls
50x.html  index.html
[root@ngin01 /]# cd /usr/local/nginx/html/
[root@ngin01 html]# ls
50x.html  index.html
[root@ngin01 html]# echo "<h1>This is Nginx01</h1>" >index.html 
[root@ngin01 html]# vim /etc/sysconfig/network-scripts/ifcfg-ens33 
ONBOOT=yes
IPADDR=192.168.10.30  ##02改成 192.168.10.31
PREFIX=24
GATEWAY=192.168.10.1
[root@ngin01 html]# systemctl restart network

配置 Haproxy 服务器

[root@localhost ~]# mkdir /bao
[root@localhost ~]# cd /bao
[root@localhost bao]# rz -E
rz waiting to receive.
[root@localhost bao]# tar zxvf haproxy-1.5.19.tar.gz 
[root@localhost haproxy-1.5.19]# yum -y install pcre \
> pcre-devel \
> bzip2-devel \
> gcc \
> gcc-c++ \
> make
[root@localhost haproxy-1.5.19]# make TARGET=linux26
[root@localhost haproxy-1.5.19]# make && make install
[root@localhost haproxy-1.5.19]# mkdir /etc/haproxy
[root@localhost haproxy-1.5.19]# cp examples/haproxy.cfg /etc/haproxy/  ##examples里面有主配置文件模板
[root@localhost haproxy-1.5.19]# cd /etc/haproxy/
[root@localhost haproxy]# vim haproxy.cfg
# this config needs haproxy-1.1.28 or haproxy-1.2.1

global
        log 127.0.0.1   local0
        log 127.0.0.1   local1 notice
        #log loghost    local0 info
        maxconn 4096
        #chroot /usr/share/haproxy  ##注释掉
        uid 99
        gid 99
        daemon
        #debug
        #quiet

defaults
        log     global
        mode    http
        option  httplog
        option  dontlognull
        retries 3
        #redispatch  ##注释掉
        maxconn 2000
        contimeout      5000
        clitimeout      50000
        srvtimeout      50000

listen  webcluster 0.0.0.0:80   ##删除原本listen内容,添加一下内容
        option httpchk GET /index.html   ##监听检查服务器的index.html文件>(节点服务器的主页)
        balance roundrobin      ##负载均衡调度算法使用轮询算法
        server inst1 192.168.10.30:80 check inter 2000 fall 3   ##定义在>线节点
        server inst2 192.168.10.31:80 check inter 2000 fall 3
[root@localhost haproxy]# cd /bao/
[root@localhost bao]# cp haproxy-1.5.19/examples/haproxy.init /etc/init.d/haproxy  ##复制启动脚本,让service 可以控制他
[root@localhost sbin]# ln -s /usr/local/sbin/haproxy /usr/sbin/
[root@localhost sbin]# chmod +x /etc/init.d/haproxy 
[root@localhost sbin]# netstat -natp |grep 80
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      74115/haproxy 
[root@localhost sbin]# vim /etc/sysconfig/network-scripts/ifcfg-ens33 
DEVICE=ens33
ONBOOT=yes
IPADDR=192.168.10.20
PREFIX=24
GATEWAY=192.168.10.1
[root@localhost sbin]# systemctl restart network

将三台主机放进同一个 LAN区段
在这里插入图片描述

验证实验

第一次访问
在这里插入图片描述第二次访问
在这里插入图片描述实验成功

日志系统展示!!

[root@localhost ~]# vim /etc/haproxy/haproxy.cfg
global
        log /dev/log    local0 info
        log /dev/log    local0 notice
        #log loghost    local0 info
[root@localhost ~]# service haproxy stop
Stopping haproxy (via systemctl):                          [  确定  ]
[root@localhost ~]# service haproxy start
Starting haproxy (via systemctl):                          [  确定  ]
[root@localhost ~]# 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
&~
[root@localhost ~]# systemctl restart rsyslog.service 

查看日志
发现并没有 haproxy 的日志文件

[root@localhost ~]# cd /var/log
[root@localhost log]# ls
[root@localhost log]# ls |grep haproxy
[root@localhost log]# 

访问一次,再查看日志
在这里插入图片描述

[root@localhost log]# cd haproxy/
[root@localhost haproxy]# ls
haproxy-info.log  haproxy-notice.log
[root@localhost haproxy]# cat haproxy-info.log 
Sep  2 19:59:05 localhost haproxy[76408]: 192.168.10.20:36398 [02/Sep/2020:19:59:05.903] nginxserver nginxserver/inst1 0/0/0/0/0 200 261 - - ---- 1/1/0/1/0 0/0 "GET / HTTP/1.1"
Sep  2 19:59:05 localhost haproxy[76408]: 192.168.10.20:36398 [02/Sep/2020:19:59:05.904] nginxserver nginxserver/inst2 22/0/1/1/24 404 324 - - ---- 1/1/0/1/0 0/0 "GET /favicon.ico HTTP/1.1"
[root@localhost haproxy]# cat haproxy-notice.log   ##我停了两台nginx服务器
Sep  2 20:02:33 localhost haproxy[77020]: Proxy nginxserver started.
Sep  2 20:02:33 localhost haproxy[77020]: Proxy nginxserver started.

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值