分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 教程案例

使用 haproxy 搭建 web 群集

发布时间:2023-09-06 02:01责任编辑:胡小海关键词:haproxy
使用 haproxy 搭建 web 群集

案例概述:

haproxy是目前比较流行的一种群集调度工具 。相比较而言 ,LVS 性能最好 ,但是搭建复杂 ,Nginx 的 upstream 模块支持群集功能 , 但是对群集节点的健康检查功能不强 ,性能没有 haproxy好。


实验环境:

主机操作系统IP地址主要软件
haproxy 服务机CentOS 7.3 x86_64192.168.217.128haproxy-1.5.19.tar.gz
Nginx 服务器 1CentOS 7.3 x86_64192.168.217.129nginx-1.12.0.tar.gz
Nginx 服务器 2CentOS 7.3 x86_64192.168.217.130nginx-1.12.0.tar.gz
客户机Windows 7192.168.217.131IE浏览器

配置 Nginx 服务器:

  1. 安装服务所需的环境 :

    yum install -y pcre-devel zlib-devel gcc gcc-c++ ????#pcre 支持正则表达式 ??zlib 网页压缩
  2. 安装 Nginx 服务 :

    useradd -M -s /sbin/nologin nginx ?????#创建一个管理Nginx的程序用户tar zxvf nginx-1.12.0.tar.gz -C /opt/ ???#解压cd /opt/nginx-1.12.0/./configure \ ????????????????????--prefix=/usr/local/nginx \ ?????????????????#指定Nginx安装路径--user=nginx \ ??????????????????????????????????#管理用户--group=nginx ??????????????????????????????????#管理组
    make ?&& make install ????????????????????#编译安装
  3. 添加测试首页 ?,关闭防火墙:

    cd /usr/local/nginx/html ???????????????????????????????????????????echo "this is accp web" > test.html ?????????????????????????#新建的网页 ,也可以直接修改 indexln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/ ??????#建立软连接 ,方便系统管理nginx ??????????????????????????????????????????????????????????????????????#启动systemctl stop firewalld.service 

配置 Haproxy 服务器

  1. 安装服务所需的环境 :

    yum install -y pcre-devel gcc gcc-c++ ??
  2. 安装 Haproxy 服务 :

    tar zxvf haproxy-1.5.19.tar.gz -C /opt/cd /opt/haproxy-1.5.19/make TARGET=linux26 ???#使用uname -r查看内核,如:2.6.18-371.el5,此时该参数就为linux26make install
  3. 编辑 haproxy 配置文件 :

    mkdir /etc/haproxy ???????????????????????????????????cp examples/haproxy.cfg /etc/haproxy/ ????#复制配置文件到 etc下cd /etc/haproxy/vim haproxy.cfg
    chroot /usr/share/haproxy ??????#删除 ???改变根目录redispatch ??????????????????????????????#删除 ????强制将请求发送给已经 down 掉的服务器
    listen ?webcluster 0.0.0.0:80 ??????????????#监听所有地址的80端口 ???option httpchk GET /test.html ???????#检查服务器的 test.html 文件 ???balance roundrobin ??????????????????????#负载均衡使用轮询算法 ???server inst1 192.168.217.129:80 check inter 2000 fall 3 ??#指向服务器 ???server inst2 192.168.217.130:80 check inter 2000 fall 3
  4. 启动 haproxy 服务 :

    cp /opt/haproxy-1.5.19/examples/haproxy.init /etc/init.d/haproxy ?#复制启动脚本chmod +x haproxychkconfig --add /etc/init.d/haproxy ???# 添加服务、也可以设置开机自启ln -s /usr/local/sbin/haproxy /usr/sbin/haproxy ??#建立软连接 ,方便系统管理service haproxy start ????????????????????????#开启服务
  5. Haproxy 日志管理 :(日志默认输出到syslog中 ,查看不是很方便)

    vim /etc/haproxy/haproxy.cfg ?#修改log /dev/log ???local0 info ??????log /dev/log ???local0 notice ??//将这两行配置放到haproxy的global配置项目中,主要是将haproxy的info及notice日志分别记录到不同的日志文件中
    service haproxy restart ??????????????????#重启服务touch /etc/rsyslog.d/haproxy.conf ??#将haproxy相关的配置独立定义到haproxy.conf 
    vim /etc/rsyslog.d/haproxy.confif ($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

    测试

    打开客户机访问192.168.217.128/test.html ,刷新页面 ,查看两个网页是否轮流出现 。

使用 haproxy 搭建 web 群集

原文地址:http://blog.51cto.com/13640803/2132351

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved