群集架构----HaProxy & Nginx调度器
####群集架构----HaProxy & Nginx
#常见的Web集群调度器
目前常见的Web集群调度器分为软件和硬件,软件通常使用开源的LVS、 Haproxy、 Nginx,硬件一般使用比较多的是F5,也有很多人使用国内的一些产品,如梭子鱼、绿盟等
LVS虽然在企业应用中抗负载能力很强,但存在不足
LVS不支持正则处理,不能实现动静分离
对于大型网站,LVS的实施配置复杂,维护成本相对较高
Haproxy是一款可提供高可用性、负载均衡、及基于TCP和HTTP应用的代理的软件
特别适用于负载特别大的Web站点
运行在当前的硬件上可支持数以万计的并发连接连接请求
主机 操作系统 IP地址 主要软件
Haproxy服务器 CentoS 7.6 x86_64 192.168.100.140 haproxy-1.5.19.tar.gz
Nginx服务器1 CentOs 7.6 x86_64 192.168.100.150 nginx-1.12.0.tar.gz
Nginx服务器2 CentOs 7.6 x86_64 192.168.100.160 nginx-1.12.0.tar.gz
客户端 Windows 10 192.168.100.20 Chrome
--------------------------节点服务器---------------------
yum install -y \
pcre-devel \
zlib-devel \
gcc \
gcc-c++ \
make
useradd -M -s /sbin/nologin nginx
tar zxvf nginx-1.12.0.tar.gz -C /opt/
cd /opt/nginx-1.12.0/
./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx
make && make install
cd /usr/local/nginx/html
echo "this is nginx01 web" > test.html
ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
启动
nginx -t
nginx
netstat -ntap |grep nginx
systemctl stop firewalld
setenforce 0
自己浏览器测试
--------------------------------haproxy服务器-----------------------
yum install -y \
pcre-devel \
bzip2-devel \
gcc \
gcc-c++ \
make
tar zxvf haproxy-1.5.19.tar.gz -C /opt/
cd /opt/haproxy-1.5.19/
make TARGET=linux26
make install
mkdir /etc/haproxy
cp examples/haproxy.cfg /etc/haproxy/
cd /etc/haproxy/
vim haproxy.cfg
#删除所有listen项目,并添加-------------------------
##删除以下语句
chroot /usr/share/haproxy
redispatch
##添加
listen webcluster 0.0.0.0:80
option httpchk GET /test.html
balance roundrobin "轮询调度法"
server inst1 192.168.100.150:80 check inter 2000 fall 3 "定义均衡地址池"
server inst2 192.168.100.160:80 check inter 2000 fall 3
cp /opt/haproxy-1.5.19/examples/haproxy.init /etc/init.d/haproxy
cd /etc/init.d
chmod +x haproxy
chkconfig --add /etc/init.d/haproxy
ln -s /usr/local/sbin/haproxy /usr/sbin/haproxy
systemctl stop firewalld
setenforce 0
service haproxy start
netstat -ntap |grep haproxy '检查80端口'
测试: 访问代理服务器地址192.168.100.140 刷新,检查是否调度切换
---------------------------------------haproxy 日志定义与管理------------------------------
vim /etc/haproxy/haproxy.cfg
log /dev/log local0 info
log /dev/log local0 notice
service haproxy restart
touch /etc/rsyslog.d/haproxy.conf
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
&~
systemctl restart rsyslog.service
service haproxy restart //重启服务才能有日志文件