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)
上一篇 2016-07-22 10:08
下一篇 2016-07-22 10:09

相关推荐

  • 配置HTTPS

    环境为CentOS 7.3、httpd2.4.6 一 搭建证书 CA 主机为192.168.29.3 client主机为 192.168.29.100 1 生成私钥 [root@centos7 ~]# (umask 077 ; openssl genrsa -out /etc/pki/CA/private/cakey.pem 4096) Generating…

    2017-06-06
  • PHP进阶知识总结

    周末梳理了下这段时间看书的一些知识点,进步的过程不仅要实践,还要安排多看书、思考、总结。 只针对知识点进行了罗列和简单说明,很多细节还未整理好,待后面再专门详细写。   基础易忽略概念   PHP是一个支持面向对象开发的语言,而不是一个纯面向对象的语言 PHP5中保留了对var的支持,但会将var自动转换为public 类型检查函数: i…

    Linux干货 2015-03-10
  • mysql进阶至mysql备份基础及备份工具

    一、mysql备份、恢复基础 备份:存储的数据副本 还原:把副本应用到线上系统,仅能恢复至备份操作时刻的数据状态。 硬件上的冗余并不能有效恢复逻辑操作上的错误。 备份:数据备份、服务配置文件备份、系统环境备份。程序的运行依赖于一定的系统环境,仅提供数据本身并不能确保恢复数据之后系统可用,数据备份的目的在于确保系统出现不可预料的灾难事故之后能够快速恢复运行,降…

    2016-11-18
  • 马哥网络21-第5周作业

    1、显示/boot/grub/grub.conf中以至少一个空白字符开头的行; [root@localhost proc]# grep "^[[:space:]]\{1,\}" /boot/grub/grub.conf root (hd0,0) kernel /vmlinuz-2…

    Linux干货 2016-08-08
  • 缓存需知

    Edit Web缓存核心技术点需知 5.1 HTTP首部控制 5.2 基于新鲜度检测机制: 2.1 特征1:时间局部性 2.2 特征2:空间局部性 2.3 缓存的优点 2.4 哪类数据应该被缓存 2.5 哪类数据可缓存但不应该被缓存 2.6 缓存命中率决定缓存有效性 2.7 缓存数据生命周期 2.8 缓存处理步骤 2.9 缓存和普通数据读取的区别 1. 完整…

    Linux干货 2015-02-22
  • 如何使用openssl工具创建私有CA

    一、CA及证书 非对称加密是为了保证互联网中通讯信息安全使用的一种算法,密钥是成对出现(公钥和私钥),它的特点是发送方A使用接收方B的公钥加密数据,所有只有B拥有与之配对的私钥解密该数据,反之亦然。那么,A和B之间怎么交换得到对方的真实安全的公钥呢?此时就需要一个权威的机构来验证公钥的合法性,这个机构称之为CA(Certification Authority…

    2017-07-16

评论列表(1条)

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

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