HAProxy 入门及基础负载应用

A、首介 。。。

        HAProxy——开放源代码软件,是一款代理服务器和伪4层的负载均衡软件解决方案。基于TCP(第四层)和HTTP(第七层)应用的代理软件,支持高并发链接,它的工作模式可以将其简单而安全地整合到当前的服务架构中,同时可以保护你的WEB服务器不暴露到网络上(设置成代理来实现的 通过VIP将后端的web服务器隐藏到内网中)。haproxy进入了商业版本以后,就进入了快速迭代周期,目前正在维护的版本有 1.4  1.5  1.6  1.7;

B、特点。。。

        b1、免费开源,稳定性非常好

        b2、支持链接拒绝,可以用于防止DDoS攻击

        b3、支持虚拟主机

        b4、能够补充Nginx的一些缺点,路由HTTP请求到后端服务器,基于cookie作会话绑定;同时支持通过获取指定的url来检测后端服务器的状态

        b5、能够将多个请求反代至后端主机完成负载均衡的效果

        b6、通过一个URI接口web应用程序为通过身份验证的用户提供报告详细状态.

        b7、自带监控服务器状态的页面,实时监控状态、强大的后端主机健康检测功能.

        b8、支持 单一进程模型,事件驱动,弹性二叉树;

        b9、负载均衡策略算法较多、具体有如下8种:

    ① roundrobin,表示简单的轮询,这个是负载均衡基本都具备的;

    ② static-rr,表示根据权重,选择 server 的逻辑最为简单

    ③ leastconn,表示最少连接者先处理
    ④ source,表示根据请求源IP,这个跟Nginx的IP_hash机制类似,用其作为解决session问题的一种方法
    ⑤ ri,表示根据请求的URI;
    ⑥ rl_param,表示根据请求的URl参数’balance url_param’ requires an URL parameter name;
    ⑦ hdr(name),表示根据HTTP请求头来锁定每一次HTTP请求;

    ⑧ rdp-cookie(name),表示根据据cookie(name)来锁定并哈希每一次TCP请求。

C、安装。。。

        安装较为简单,在Centos6.4版本后,haproxy就被收录进ISO光盘的base仓库,可见其较高的市场占有率和大众接受度,

         c1、查看安装信息 yum info haproxy    HAProxy 入门及基础负载应用    

         c2、安装  yum install haproxy  -y              


D、程序环境 。。。 

        d1、程序配置文件路径

                配置文件: /etc/haproxy/haproxy.cfg
                Unit File: /usr/lib/systemd/system/haproxy.service (CentOS7)
                主程序: /usr/sbin/haproxy
                日志管理辅助: /usr/bin/halog
                网段计算辅助文件: /usr/bin/iprange

                内建的错误页文件:

            /usr/share/haproxy/400.http
            /usr/share/haproxy/403.http
            /usr/share/haproxy/408.http
            /usr/share/haproxy/500.http
            /usr/share/haproxy/502.http
            /usr/share/haproxy/503.http
            /usr/share/haproxy/504.http             

         d2、Haproxy配置文件分析

                首先备份下

                    cp /etc/haproxy/haproxy.cfg{,.bak}

                打开haproxy.cfg

                    vim /etc/haproxy/haproxy.cfg

                global: 全局配置段,参数是进程级的,通常是和操作系统相关,如果配置无误,就不需要再次进行修改
                proxles 代理配置段如下:
                    — defaults <name>:  为frontend, backend以及listen提供默认配置;
                    — frontend <name>:  相当于nginx的server段,接收请求的前端虚拟节点
                    — backend <name>: 后端服务集群的配置,是真实服务器,一个Backend对应一个或者多个实体服务器,相当于nginx的upstream段,
                                       

E、基础负载测试。。。

        测试准备

            e1、3台主机,第1台(7.3)安装haproxy做调试器,第2,3台(6.8)安装httpd做web应用,配置/var/www/html/index.html测试页面,(3台IP之间需互通)

            e2、启动服务: service httpd start,并监测80端口是否开启,ss -tnlp |grep 80 , 浏览器访问时确认关闭防火墙:iptables -F 及selinux : getenforce,

            e3、确认可正常浏览

        HAProxy 入门及基础负载应用

e4、接下来配置haproxy负载,仅更改几个配置点即可,主要更改frontend和backend段

  1.  可自定义frontend的main名称,加端口即可,如web的80 , ohoh *:80
  2.  default_backend 也可自定,不要和main名称一样即好, web_ser
  3. 此段的中间几行,默认即可,也可删除
  4. 配置backend段,修改backend名称同上web_ser
  5. balance默认调度算法 roundrobin简单轮询,默认
  6. 复制一行server, 将后端的两台http服务器IP和端口写入。保存退出
  7. 启动haproxy服务, systemctl  start  haproxy.service

        HAProxy 入门及基础负载应用


    END:浏览器访问,刷新查看两台切换

             HAProxy 入门及基础负载应用

            HAProxy 入门及基础负载应用


待续。。。




                

原创文章,作者:zzzzzzzzzzzzzzzz.x,如若转载,请注明出处:http://www.178linux.com/76030

(0)
zzzzzzzzzzzzzzzz.xzzzzzzzzzzzzzzzz.x
上一篇 2017-05-17
下一篇 2017-05-17

相关推荐

  • 计划任务和周期性任务

    linux计划任务     功能:指定未来的某以特定的时间点执行一次任务     命令:at、bathc     at命令:         选项: &nbsp…

    Linux干货 2016-09-12
  • keepalived+nginx 实现 sharepoint 负载均衡

    keepalived 实现虚拟路由
    nginx 做反向代理和负载均衡

    Linux干货 2017-12-20
  • 实现基于MYSQL验证的vsftpd虚拟用户

    马哥教育面授21期 运维 vsftpd MySQL 说明:本实验在两台CentOS主机上实现,一台做为FTP服务器,一台做数据库服务器 一、安装所需要包和包组: 在数据库服务器上安装包: yum –y install mariadb-server mariadb-devel systemctl start mariad…

    Linux干货 2016-12-21
  • 网络管理

    网络概念 网络应用程序 Web 浏览器(Chrome、IE、Firefox等) 即时消息(QQ、微信、钉钉等) 电子邮件(Outlook、foxmail 等) 协作(视频会议、VNC、Netmeeting、WebEx 等) web网络服务(apache,nginx,IIS) 文件网络服务(ftp,nfs,samba) 数据库服务( MySQL,MariaDB…

    Linux干货 2017-05-06
  • Linux发行版及哲学思想

    Linux各发行版以及哲学思想 什么是Linux 为什么会有不同的Linux发行版 现有主流发行版,及其他们之间相互关系 Linux所遵循的哲学思想 什么是Linux Linux是一种自由和开放源代码的Unix-like操作系统,由当时就读于芬兰赫尔辛基大学的Linus Torvalds于1991年10月5日首次发布于互联网。Linux遵循第二版GNU通用公…

    Linux干货 2016-10-29