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

相关推荐

  • 第七周 N21 总有刁民想害朕

    1、创建一个10G分区,并格式为ext4文件系统;    (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;        mke2fs -t ext4 /dev/sdb5 -b 2048 -m 2 -L "MYDATA&quot…

    Linux干货 2016-08-08
  • 马哥教育网络20期+第五周课程练习

    1、显示/boot/grub/grub.conf中以至少一个空白字符开头的行; [root@localhost ~]# grep "^[[:space:]]\+" /boot/grub/grub.conf 2、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又…

    Linux干货 2016-07-07
  • sed简介及常见用法

    sed是一个文本流处理器,配合正则表达式用可以实现很多文本处理操作。 和grep一样,sed是一行一行的处理的。sed处理文本时,首先会将源文件复制一份到内存中,然后将文本一行一行拿到模式空间内进行操作,最后输出到标准输出,即屏幕上。 在模式空间中,每一行都会根据用户给的条件进行匹配,匹配到了进行编辑后输出,没有匹配到,直接输出到标准输出。sed除了模式空间…

    2018-01-04
  • N25-第四周博客

      复制/etc/ske1目录为/home/tuser1,要求/home/tuser1及其内部文件的属组合其他用户均没有任何访问权限。            2,编辑/etc/group文件,添加组hadoop.。    &nbs…

    Linux干货 2016-12-22
  • ​mysql备份之lvm

    mysql备份之lvm 新建一个lvm磁盘,这里我建的lv为mydatalv,挂载到了/data下 [root@localhost ~]# lvs   LV       VG     Attr&nbs…

    Linux干货 2016-07-19
  • 如何使用正则表达式

    正则表达式(Regular Expression)就是使用简单的字符按照预先设定的规则来完成复杂的功能,说白了,正则表达式是一种字符串的匹配方式,就是用预先设定好的规则来描述我们想要表达的内容,它是由普通字符以及元字符组成的字符串,其中元字符不表示本身的意义,而是用于表达控制或通配等功能。 为什么要用这个东西那,我想,每一个学习计算机的人都应该明白,计算机就…

    Linux干货 2015-10-27