HAProxy初探及简单案例_Net21_第二周

前言

随着互联网业务的迅猛发展,大型电商平台和门户网站对系统的可用性和可靠性的要求越来越高,高可用集群、负载均衡集群成为一种热门的系统架构解决方案。在众多的负载均衡解决方案中,有基于硬件的负载均衡设备,例如F5、Big-IP等,也有基于软件的负载均衡产品,如LVS、Nginx以及本文介绍的HAProxy等。在软件的负载均衡产品中,又分为两种实现方式,分别是基于操作系统的实现和基于第三方应用的实现。LVS就是基于Linux操作系统的一种软负载实现,而HAProxy就是基于基于第三方应用实现的软负载均衡。

HAProxy简介

HAProxy是一个开源、高性能、基于TCP(四层)和HTTP(七层)应用的负载均衡软件,它的显著优点如下:
  • 可靠性与稳定性都非常出色,可与硬件级设备媲美。

  • 支持多种负载均衡调度算法,并且也支持session保持。

  • 理论上1G可用RAM空间可维持4W-5W个并发连接,性能强大可见一斑。

  • 拥有功能强大的后端服务器的状态监控web页面,可以实时了解设备的运行状态,还可实现设备上下线等简单操作。

  • HAProxy还拥有功能强大的ACL支持,在架构设计与实现上带来很大方便。

HAProxy配置概述

在讲配置之前,顺带提一下安装HAProxy,以Centos7为例的话可以直接yum安装一下就ok了。安装完成之后默认的主配置文件路径为/etc/haproxy/haproxy.cfg.这个主配置文件主要由5个部分组成:
  • global段:
    用来设定全局配置参数,配置的为进程级别的参数,且通常与其运行的OS相关。

  • defaults段:
    默认参数的配置,在此处配置的各种参数默认会被frontend、backend、listen段引用,而如果frontend、backend、listen段如果设置新的相对应的参数,会覆盖defaults段的设定。

  • frontend段:
    用于定义一系列监听的套接字,这些套接字可接受客户端请求并与之建立连接。

  • backend段:
    用于定义一系列“后端”服务器,代理将会将对应客户端的请求转发至这些服务器。

  • listen段:
    是frontend和backend的结合体,通过关联“前端”和“后端”定义了一个完整的代理,通常只对TCP流量有用。

HAProxy简单配置实例

拓扑环境很简单,3台虚拟机作为3个节点,其中一台运行HAProxy,另外2台作为后端Web Server。其中192.168.1.67为HAProxy节点的地址,.68和.69是后端Web Server地址。
  • HAProxy的日志配置策略
       默认情况下,HAProxy没有配置日志输出功能,但是为了管理和维护方便,日志的输出很有必要,这里简单介绍下HAProxy如何启用日志功能:
      

       ①首先在global段开启,一般默认是开启的;

    vim /etc/haproxy/haproxy.conf
    global
        log         127.0.0.1 local2

       ②以rsyslog管理系统日志为例:
        

    vim /etc/rsyslog.conf
    $ModLoad imudp
    $UDPServerRun 514                                   #启用相关协议与监听接口
    local2.*          /var/log/haproxy.log            #设置日志输出路径
    systemctl restart rsyslog.service

         

  • frontend与backend简单示例
    实现将来自用户的80端口的http请求转发至后端8000上的server服务:

        ①编辑Web Server主配置文件(/etc/httpd/conf/httpd.conf),找到约在42行的Listen 80,并在下面追加:

Listen 8000

        并且在两台web服务器的首页添加内容以示区别。

        ②编辑haproxy主配置文件如下:

frontend  main :80         #:80代表匹配任意源地址且源端口为80的请求
    
        default_backend websrvs
backend websrvs
    
        balance     roundrobin      #轮询调度
    
        server web1 192.168.1.68:8000 check
    
        server web2 192.168.1.69:8000 check     #check用于做健康状态检测

        ③启动haproxy

  • 实例效果

    web1.jpgweb2.jpg

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

(1)
Net21_charlesNet21_charles
上一篇 2016-07-22
下一篇 2016-07-22

相关推荐

  • puppet代码分析

    这篇博客的目的是通过分析Forge上的Puppet模块来加深一些概念的理解,同时了解一些常用用法。 今天的例子是jfryman-nginx模块,它是原puppetlabs-nginx模块的升级版本,依赖3个Puppet公共模块:puppetlabs-apt,puppetlabs-stdlib和puppetlabs-concat。安装非常方便,puppet m…

    2017-03-18
  • test

    test

    Linux干货 2018-02-23
  • 第八周作业

    1、写一个脚本,使用ping命令探测172.16.250.1-172.16.250.254之间的所有主机的在线状态;     在线的主机使用绿色显示;     不在线的主使用红色显示; 2、如何给网络接口配置多个地址,有哪些方式? 方法3:在/etc/sysconfig/netw…

    2017-04-20
  • lvm的基本使用

    lvm的创建、扩展、迁移以及逻辑卷快照的使用

    2017-12-08
  • bash功能特性四 文件名通配符

    文件名通配(globbing)     通配符在bash中是一个非常有用的功能,它可以使我们更加方便的查找符合特定条件的文件。     文件通配符的包括以下几种:          *:任意长度的任意…

    Linux干货 2015-04-21
  • grep基本正则表达式以及扩展正则表达式

    基本正则表达式: grep:Globel serach REgular expression and print out the line 作用:文本搜索工具,根据用户指定的“模式(过滤条件)”对目标文本逐行进行匹配检查,打印匹配到的行 模式:由正则表达式的元字符及文本字符所编写出的过滤条件 grep选项:       &nbs…

    Linux干货 2016-08-08

评论列表(1条)

  • 马哥教育
    马哥教育 2016-07-22 10:46

    写的很好,排版还可以在漂亮一点,用5w1h的思想写,加油