Haproxy提供高可用性、负载均衡以及基于TCP(第四层)和HTTP(第七层)应用的代理,支持虚拟主机,它是免费、快速而且可靠的一种解决方案。php
haproxy特别适用于那些负载特别大的web站点,这些站点一般又须要会话保持或七层处理。haproxy运行在时下的硬件上,彻底能够支持数以万计的并发链接,而且它的运行模式使得它能够很简单安全的整合进您当前的架构中,同时能够保护你的web服务器不被暴露到网络上。css
haproxy实现了一种事件驱动、单一进程模型,此模型支持很是大的并发链接数。多进程或多线程模型受内存限制、系统调度器限制以及无处不在的锁限制,不多能处理数千并发链接。事件驱动模型由于在有更好的资源和时间管理的用户端(User-Space)实现全部这些任务,因此没有这些问题。此模型的弊端是,在多核系统上,这些程序一般扩展性较差。这就是为何他们必须进行优化以使每一个CPU时间片(Cycle)作更多的工做。html
haproxy的优势前端
(1)免费开源,稳定性也是很是好。单haproxy也跑得不错,稳定性能够与硬件级的F5相媲美。python
(2)根据官方文档,haproxy能够跑满10Gbps,这个数值做为软件级负载均衡器是至关惊人的。mysql
(3)haproxy支持链接拒绝:由于维护一个链接的打开的开销是很低的,有时咱们很须要限制攻击蠕虫(attack bots),也就是说限制它们的链接打开从而限制它们的危害。这个已经为一个陷于小型DDoS攻击的网站开发了并且已经拯救了不少站点,这个优势也是其它负载均衡器没有的。ios
(4)haproxy支持全透明代理(已具有硬件防火墙的典型特色):能够用客户端IP地址或者任何其余地址来链接后端服务器。这个特性仅在Linux 2.4/2.6内核打了tcp proxy补丁后才可使用。这个特性也使得为某特殊服务器处理部分流量同时又不修改服务器的地址成为可能。git
(5)haproxy现多于线上的Mysql集群环境,咱们经常使用于它做为MySQL(读)负载均衡。web
(6)自带强大的监控服务器状态的页面,实际环境中咱们结合Nagios进行邮件或短信报警。正则表达式
(7)HAProxy支持虚拟主机,许多朋友说它不支持虚拟主机是错误的,经过测试咱们知道,HAProxy是支持虚拟主机的。
以在ubantu-16.04操做系统为例
apt-get -y install haproxy
经常使用命令以下:
ps -ef |grep haproxy haproxy -v cat /etc/haproxy/haproxy.cfg
listen stats mode http bind 0.0.0.0:1080 stats enable stats hide-version stats uri /stats stats realm Haproxy\ Statistics stats auth admin:admin123 stats admin if TRUE #启用管理功能
balance
balance用于定义负载均衡的算法,可用于defaults、listen和backend中。
balance使用方法以下:
balance <algorithm>
[ <arguments> ]
balance url_param [check_post [<max_wait>]
]
用于在负载均衡场景中挑选一个server,其仅应用于持久信息不可用的条件下或须要将一个链接从新派发至另外一个服务器时。
balance支持的算法有:
roundrobin:基于权重进行轮询,在服务器的处理时间保持均匀分布时,这是最平衡、最公平的算法。此算法是动态的,这表示其权重能够在运行时进行调整。不过在设计上,每一个后端服务器仅能最多接受4128个链接。
source:将请求的源地址进行hash运算,并由后端服务器的权重总数相除后派发至某匹配的服务器。这可使得同一个客户端IP的请求始终被派发至某特定的服务器;不过,当服务器权重总数发生变化时,如某服务器宕机或添加了新的服务器,许多客户端的请求可能会被派发至与此前请求不一样的服务器;经常使用于负载均衡无cookie功能的基于TCP的协议;其默认为静态,不过也可使用hash-type修改此特性。
static-rr:基于权重进行轮询,与roundrobin相似,可是为静态方法,在运行时调整其服务器权重不会生效;不过,其在后端服务器链接数上没有限制。
leastconn:新的链接请求被派发至具备最少链接数目的后端服务器;在有着较长时间会话的场景中推荐使用此算法,如LDAP、SQL等,其并不太适用于较短会话的应用层协议,如HTTP;此算法是动态的,能够在运行时调整其权重。
uri:对URI的左半部分(“问题”标记以前的部分)或整个URI进行hash运算,并由服务器的总权重相除后派发至某匹配的服务器;这可使得对同一个URI的请求老是被派发至某特定的服务器,除非服务器的权重总数发生了变化;此算法经常使用于代理缓存或反病毒代理以提升缓存的命中率;须要注意的是,此算法仅应用于HTTP后端服务器场景;其默认为静态算法,不过也可使用hash-type修改此特性。
url_param:经过为URL指定的参数在每一个HTTP GET请求中将会被检索;若是找到了指定的参数且其经过等于号“=”被赋予了一个值,那么此值将被执行hash运算并被服务器的总权重相除后派发至某匹配的服务器;此算法能够经过追踪请求中的用户标识进而确保同一个用户ID的请求将被送往同一个特定的服务器,除非服务器的总权重发生了变化;若是某请求中没有出现指定的参数或其没有有效值,则使用轮叫算法对相应请求进行调度;此算法默认为静态的,不过其也可使用hash-type修改此特性。
hdr():对于每一个HTTP请求,经过指定的HTTP首部将会被检索;若是相应的首部没有出现或其没有有效值,则使用轮叫算法对相应请求进行调度;其有一个可选选项“use_domain_only”,可在指定检索相似Host类的首部时仅计算域名部分以下降hash算法的运算量;此算法默认为静态的,不过其也可使用hash-type修改此特性;
bind
bind仅能用于frontend和listen区段,用于定义一个或几个监听的套接词。
bind使用方法以下:
bind [
]:<port_range> [, …]
bind [
]:<port_range> [, …] interface
:可选选项,其能够为主机名、IPv4地址、IPv6地址或
*
。省略此选项、将其指定为*
或0.0.0.0时,将监听当前系统的全部IPv4地址。
<port_range>:能够是一个特定的TCP端口,也但是一个端口范围(如 5005-5010),代理服务器将经过指定的端口来接收客户端请求。
须要注意的是,每组监听的套接词在同一个实例上只能使用一次,并且小于1024的端口须要有特定权限的用户才能使用,这可能须要经过uid参数来定义。
:指定物理接口的名称,仅能在Linux系统上使用。其不能使用接口别名,而仅能使用物理接口名称,并且只有管理有权限指定绑定的物理接口。
mode
mode用于设定实例的运行模式或协议。当实现内容交换时,前端和后端必须工做于同一种模式(通常说来都是HTTP模式),不然将没法启动实例。
mode可被用与listen、defaults、frontend、backend区段。
mode使用方法以下:
mode { tcp|http|health }
tcp:实例运行于纯TCP模式(即4层),在客户端和服务器端之间将创建一个全双工的链接,且不会对7层报文作任何类型的检查;此为默认模式,一般用于SSL、SSH、SMTP等应用。
http:实例运行于HTTP模式(即7层),客户端请求在转发至后端服务器以前将被深度分析,全部不与RFC格式兼容的请求都会被拒绝。
health:实例工做于health模式,其对入站请求仅响应“OK”信息并关闭链接,且不会记录任何日志信息;此模式将用于响应外部组件的健康状态检查请求;目前此模式已经废弃,由于tcp或http模式中的monitor关键词可完成相似功能;
hash-type
hash-type定义用于将hash码映射至后端服务器的方法;其不能用于frontend区段;可用方法有map-based和consistent,在大多数场景下推荐使用默认的map-based方法。
hash-type使用方法以下:
hash-type
map-based:hash表是一个包含了全部在线服务器的静态数组。其hash值将会很是平滑,会将权重考虑在列,但其为静态方法,对在线服务器的权重进行调整将不会生效,这意味着其不支持慢速启动。此外,挑选服务器是根据其在数组中的位置进行的,所以,当一台服务器宕机或添加了一台新的服务器时,大多数链接将会被从新派发至一个与此前不一样的服务器上,对于缓存服务器的工做场景来讲,此方法不甚适用。
consistent:hash表是一个由各服务器填充而成的树状结构;基于hash键在hash树中查找相应的服务器时,最近的服务器将被选中。此方法是动态的,支持在运行时修改服务器权重,所以兼容慢速启动的特性。添加一个新的服务器时,仅会对一小部分请求产生影响,所以,尤为适用于后端服务器为cache的场景。不过,此算法不甚平滑,派发至各服务器的请求未必能达到理想的均衡效果,所以,可能须要不时的调整服务器的权重以得到更好的均衡性。
log
log为每一个实例启用事件和流量日志,所以可用于全部区段。每一个实例最多能够指定两个log参数,不过,若是使用了“log global”且”global”段已经定了两个log参数时,多余了log参数将被忽略。
log global
log
[ []]
global:当前实例的日志系统参数同”global”段中的定义时,将使用此格式;每一个实例仅能定义一次“log global”语句,且其没有任何额外参数。
:定义日志发往的位置,其格式之一能够为<ipv4_address:port>,其中的port为UDP协议端口,默认为514;格式之二为Unix套接词文件路径,但须要留心chroot应用及用户的读写权限。
:能够为syslog系统的标准facility之一。
:定义日志级别,即输出信息过滤器,默认为全部信息;指定级别时,全部等于或高于此级别的日志信息将会被发送。
maxconn
maxconn设定一个前端的最大并发链接数,所以,其不能用于backend区段。
maxconn使用方法以下:
maxconn
对于大型站点来讲,能够尽量提升此值以便让haproxy管理链接队列,从而避免没法应答用户请求。固然,此最大值不能超出“global”段中的定义。此外,须要留心的是,haproxy会为每一个链接维持两个缓冲,每一个缓冲的大小为8KB,再加上其它的数据,每一个链接将大约占用17KB的RAM空间。这意味着通过适当优化后,有着1GB的可用RAM空间时将能维护40000-50000并发链接。
若是为指定了一个过大值,极端场景下,其最终占据的空间可能会超出当前主机的可用内存,这可能会带来意想不到的结果;所以,将其设定了一个可接受值方为明智决定。其默认为2000。
default_backend
default_backend定义在没有匹配的use_backend规则时为实例指定使用的默认后端服务器,所以,其不可应用于backend区段。在frontend和backend之间进行内容交换时,一般使用use-backend定义其匹配规则;而没有被规则匹配到的请求将由此参数指定的后端服务器接收。
default_backend使用方法以下:
default_backend
:指定使用的后端的名称。
server
server为后端声明一个server,所以,不能用于defaults和frontend区段。
server使用方法以下:
server <name> <address>[:port][param *]
<name>:
为此服务器指定的内部名称,其将出如今日志及警告信息中;若是设定了http-send-server-name,它还将被添加至发往此服务器的请求首部中。
<address>:
为此服务器的的IPv4地址,支持使用可解析的主机名,同时也支持域名,只不过在启动时须要解析主机名至相应的IPv4地址。
[:port]:
指定将链接请求所发往的此服务器时的目标端口,其为可选项;未设定时,将使用客户端请求时的同一相端口。
[param*]:
为此服务器设定的一系参数;其可用的参数很是多,具体请参考官方文档中的说明,下面仅说明几个经常使用的参数;
服务器或默认服务器参数:
backup:设定为备用服务器,仅在负载均衡场景中的其它server均不可用于启用此server。
check:启动对此server执行健康状态检查,其能够借助于额外的其它参数完成更精细的设定,如:
inter :设定健康状态检查的时间间隔,单位为毫秒,默认为2000;也可使用fastinter和downinter来根据服务器端状态优化此时间延迟;
rise :设定健康状态检查中,某离线的server从离线状态转换至正常状态须要成功检查的次数;
fall :确认server从正常状态转换为不可用状态须要检查的次数;
cookie :为指定server设定cookie值,此处指定的值将在请求入站时被检查,第一次为此值挑选的server将在后续的请求中被选中,其目的在于实现持久链接的功能;
maxconn :指定此服务器接受的最大并发链接数;若是发往此服务器的链接数目高于此处指定的值,其将被放置于请求队列,以等待其它链接被释放;
maxqueue :设定请求队列的最大长度;
observe :经过观察服务器的通讯情况来断定其健康状态,默认为禁用,其支持的类型有“layer4”和“layer7”,“layer7”仅能用于http代理场景;
redir :启用重定向功能,将发往此服务器的GET和HEAD请求均以302状态码响应;须要注意的是,在prefix后面不能使用/,且不能使用相对地址,以避免形成循环;例如:
server srv1 192.168.5.174:80 redir http://www.baidu.com check
weight :权重,默认为1,最大值为256,0表示不参与负载均衡。
stats enable
stats enable启用基于程序编译时默认设置的统计报告,stats enable不能用于frontend区段。只要没有另外的其它设定,它们就会使用以下的配置:
stats uri : /stats
stats realm : “HAProxy Statistics”
stats auth : no authentication
stats scope : no restriction
尽管stats enable一条就可以启用统计报告,但仍是建议设定其它全部的参数,以避免其依赖于默认设定而带来非指望的后果。
stats hide-version
stats hide-version隐藏统计报告中haproxy版本号,不能用于frontend区段。默认状况下,统计页面会显示一些有用信息,包括haproxy的版本号。然而,向全部人公开haproxy的精确版本号是很是有风险的,由于它能帮助恶意用户快速定位版本的缺陷和漏洞。
stats realm
stats realm启用统计报告并高精认证领域,不能用于“frontend”区段。
stats realm
haproxy在读取realm时会将其视做一个单词,所以,中间的任何空白词符都必须使用反斜线进行转义。此参数仅在与“stats auth”配置使用时有意义。
:实现HTTP基本认证时显示在浏览器中的领域名称,用于提示用户输入一个用户名和密码。
stats scope
stats scope启用统计报告并限定报告的区段,不能用于frontend区段。
当指定此语句时,统计报告将仅显示其列举出区段的报告信息,全部其它区段的信息将被隐藏。若是须要显示多个区段的统计报告,此语句能够定义屡次。须要注意的是,区段名称检测仅仅是以词符串比较的方式进行,它不会真检测指定的区段是否真正存在。
stats scope { | “.” }
:能够是一个listen、frontend或backend区段的名称,而“.”则表示stats scope语句所定义的当前区段。
stats auth
stats auth启用带认证的统计报告功能并受权一个用户账号,其不能用于frontend区段。
stats auth :
:受权进行访问的用户名;
:此用户的访问密码,明文格式;
此语句将基于默认设定启用统计报告功能,并仅容许其定义的用户访问,其也能够定义屡次以受权多个用户账号。能够结合“stats realm”参数在提示用户认证时给出一个领域说明信息。在使用非法用户访问统计功能时,其将会响应一个“401 Forbidden”页面。其认证方式为HTTP Basic认证,密码传输会以明文方式进行,所以,配置文件中也使用明文方式存储以说明其非保密信息故此不能相同于其它关键性账号的密码。
stats admin
stats admin在指定的条件知足时启用统计报告页面的管理级别功能,它容许经过web接口启用或禁用服务器,不过,基于安全的角度考虑,统计报告页面应该尽量为只读的。此外,若是启用了HAProxy的多进程模式,启用此管理级别将有可能致使异常行为。
stats admin { if | unless }
目前来讲,POST请求方法被限制于仅能使用缓冲区减去保留部分以外的空间,所以,服务器列表不能过长,不然,此请求将没法正常工做。所以,建议一次仅调整少数几个服务器。下面是两个案例,第一个限制了仅能在本机打开报告页面时启用管理级别功能,第二个定义了仅容许经过认证的用户使用管理级别功能。
backend stats_localhost
stats enable
stats admin if LOCALHOST
backend stats_auth
stats enable
stats auth admin:password
stats admin if TRUE
option httplog
option httplog启用记录HTTP请求、会话状态和计时器的功能。
option httplog [ clf ]
clf:使用CLF格式来代替HAProxy默认的HTTP格式,一般在使用仅支持CLF格式的特定日志分析器时才须要使用此格式。
默认状况下,日志输入格式很是简陋,由于其仅包括源地址、目标地址和实例名称,而“option httplog”参数将会使得日志格式变得丰富许多,其一般包括但不限于HTTP请求、链接计时器、会话状态、链接数、捕获的首部及cookie、“frontend”、“backend”及服务器名称,固然也包括源地址和端口号等。
option logasap
option logasap
启用提早将HTTP请求记入日志,不能用于backend区段。
默认状况下,HTTP请求是在请求结束时进行记录以便能将其总体传输时长和词节数记入日志,由此,传较大的对象时,其记入日志的时长可能会略有延迟。option logasap参数可以在服务器发送complete首部时即时记录日志,只不过,此时将不记录总体传输时长和词节数。此情形下,捕获Content-Length响应首部来记录传输的词节数是一个较好选择。
option forwardfor
option forwardfor容许在发往服务器的请求首部中插入“X-Forwarded-For”首部。即启用获取客户端真实IP功能。
option forwardfor [ except ][ header ] [ if-none ]
:可选参数,当指定时,源地址为匹配至此网络中的请求都禁用此功能。
:可选参数,可以使用一个自定义的首部,如“X-Client”来替代“X-Forwarded-For”。有些独特的web服务器的确须要用于一个独特的首部。
if-none:仅在此首部不存在时才将其添加至请求报文问道中。
haproxy工做于反向代理模式,其发往服务器的请求中的客户端IP均为haproxy主机的地址而非真正客户端的地址,这会使得服务器端的日志信息记录不了真正的请求来源,“X-Forwarded-For”首部则可用于解决此问题。haproxy能够向每一个发往服务器的请求上添加此首部,并以客户端IP为其value。
须要注意的是,haproxy工做于隧道模式,其仅检查每个链接的第一个请求,所以,仅第一个请求报文被附加此首部。若是想为每个请求都附加此首部,请确保同时使用了“option httpclose”、“option forceclose”和“option http-server-close”几个option。
errorfile
errorfile在用户请求不存在的页面时,返回一个页面文件给客户端而非由haproxy生成的错误代码;可用于全部段中。
errorfile
:指定对HTTP的哪些状态码返回指定的页面;这里可用的状态码有200、400、40三、40八、500、50二、503和504。
:指定用于响应的页面文件。
例如:
errorfile 400 /etc/haproxy/errorpages/400badreq.http
errorfile 403 /etc/haproxy/errorpages/403forbid.http
errorfile 503 /etc/haproxy/errorpages/503sorry.http
rrorloc和errorloc302
errorloc
errorloc302
请求错误时,返回一个HTTP重定向至某URL的信息;可用于全部配置段中。
:指定对HTTP的哪些状态码返回指定的页面;这里可用的状态码有200、400、40三、40八、500、50二、503和504;
:Location首部中指定的页面位置的具体路径,能够是在当前服务器上的页面的相对路径,也可使用绝对路径;须要注意的是,若是URI自身错误时产生某特定状态码信息的话,有可能会致使循环定向;
须要留意的是,这两个关键词都会返回302状态吗,这将使得客户端使用一样的HTTP方法获取指定的URL,对于非GET法的场景(如POST)来讲会产生问题,由于返回客户的URL是不容许使用GET之外的其它方法的。若是的确有这种问题,可使用errorloc303来返回303状态码给客户端。
errorloc303
errorloc303
请求错误时,返回一个HTTP重定向至某URL的信息给客户端,可用于全部配置段中。
:指定对HTTP的哪些状态码返回指定的页面;这里可用的状态码有400、40三、40八、500、50二、503和504;
:Location首部中指定的页面位置的具体路径,能够是在当前服务器上的页面的相对路径,也可使用绝对路径;须要注意的是,若是URI自身错误时产生某特定状态码信息的话,有可能会致使循环定向;
例如:
backend webserver
server 172.16.100.6 172.16.100.6:80 check maxconn 3000 cookie srv01
server 172.16.100.7 172.16.100.7:80 check maxconn 3000 cookie srv02
errorloc 403 /etc/haproxy/errorpages/sorry.htm
errorloc 503 /etc/haproxy/errorpages/sorry.htm
haproxy的配置文件主要包含如下几个部分:
global全局配置、defaults默认配置、监控页面配置、frontend配置、backend配置。
global:全局配置参数,进程级的,用来控制Haproxy启动前的一些进程及系统设置。
defaults:配置一些默认的参数,能够被frontend,backend,listen段继承使用。
frontend:用来匹配接收客户所请求的域名,uri等,并针对不一样的匹配,作不一样的请求处理。
backend:定义后端服务器集群,以及对后端服务器的一些权重、队列、链接数等选项的设置。
listen:我将其理解为frontend和backend的组合体。
全局配置的标志参数为global,全局配置主要用于设定义全局参数,属于进程级的配置,一般和操做系统配置有关。
进程管理及安全相关的参数:
chroot :修改haproxy的工做目录至指定的目录并在放弃权限以前执行chroot()操做,能够提高haproxy的安全级别,不过须要注意的是要确保指定的目录为空目录且任何用户均不能有写权限。
使用方法为:
chroot /var/lib/haproxy
daemon:让haproxy以守护进程的方式工做于后台,其等同于“-D”选项的功能。固然,也能够在命令行中以“-db”选项将其禁用。
uid:以指定的uid身份运行haproxy进程。
user:同uid参数,但使用的是用户名。
gid :以指定的gid运行haproxy,建议使用专用于运行haproxy的gid,以避免因权限问题带来风险。
group :同gid参数,不过指定的组名。
log
[max level [min level]]:定义全局的syslog服务器,最多能够定义两个。
log-send-hostname []:在syslog信息的首部添加当前主机名,能够为“string”指定的名称,也能够缺省使用当前主机名。
nbproc :指定启动的haproxy进程个数,只能用于守护进程模式的haproxy。默认只启动一个进程,鉴于调试困难等多方面的缘由,通常只在单进程仅能打开少数文件描述符的场景中才使用多进程模式。
pidfile:将haproxy的进程写入pid文件。
ulimit-n:设定每进程所可以打开的最大文件描述符数目,默认状况下其会自动进行计算,所以不推荐修改此选项。
stats socket :定义统计信息保存位置。
性能调整相关的参数:
maxconn :设定每一个haproxy进程所接受的最大并发链接数,其等同于命令行选项“-n”;“ulimit -n”自动计算的结果正是参照此参数设定的。
maxpipes :haproxy使用pipe完成基于内核的tcp报文重组,此选项则用于设定每进程所容许使用的最大pipe个数。每一个pipe会打开两个文件描述符,所以,“ulimit -n”自动计算时会根据须要调大此值;默认为maxconn/4,其一般会显得过大。
noepoll:在Linux系统上禁用epoll机制。
nokqueue:在BSE系统上禁用kqueue机制。
nopoll:禁用poll机制。
nosepoll:在Linux禁用启发式epoll机制。
nosplice:禁止在Linux套接字上使用内核tcp重组,这会致使更多的recv/send系统调用;不过,在Linux 2.6.25-28系列的内核上,tcp重组功能有bug存在。
spread-checks <0..50, in="" percent="">:在haproxy后端有着众多服务器的场景中,在精确的时间间隔后统一对众服务器进行健康情况检查可能会带来意外问题;此选项用于将其检查的时间间隔长度上增长或减少必定的随机时长。
tune.bufsize :设定buffer的大小,一样的内存条件下,较小的值可让haproxy有能力接受更多的并发链接,较大的值可让某些应用程序使用较大的cookie信息;默认为16384,其能够在编译时修改,不过强烈建议使用默认值。
tune.chksize :设定检查缓冲区的大小,单位为字节;更大的值有助于在较大的页面中完成基于字符串或模式的文本查找,但也会占用更多的系统资源;不建议修改。
tune.maxaccept :设定haproxy进程内核调度运行时一次性能够接受的链接的个数,较大的值能够带来较大的吞吐率,默认在单进程模式下为100,多进程模式下为8,设定为-1能够禁止此限制;通常不建议修改。
tune.maxpollevents :设定一次系统调用能够处理的事件最大数,默认值取决于OS。其值小于200时可节约带宽,但会略微增大网络延迟,而大于200时会下降延迟,但会稍稍增长网络带宽的占用量。
tune.maxrewrite :设定为首部重写或追加而预留的缓冲空间,建议使用1024左右的大小。在须要使用更大的空间时,haproxy会自动增长其值。
tune.rcvbuf.client :定义在客户端内核套接字接收缓冲区的大小,单位为字节,建议不要调整此值。
tune.rcvbuf.server :设定内核套接字中服务端或客户端接收缓冲的大小,单位为字节;强烈推荐使用默认值。
tune.sndbuf.client:定义在客户端内核套接字发送缓冲区的大小,单位为字节,建议不要调整此值。
tune.sndbuf.server:定义在服务端内核套接字发送缓冲区的大小,单位为字节,建议不要调整此值。
上边的这些指令大多也是做为了解便可,在实际中并不常会调整这些参数。
debug相关的参数:
debug:在调度haproxy时能够启用此参数,但在生产环境不该该启用。
quiet:haproxy启动后不会显示任何相关信息,这与在命令行启动haproxy时加上参数“-q”相同。
defaults段用于为全部其它配置段提供默认参数,这配置默认配置参数可由下一个defaults所从新设定。
下面提供一个defaults模版配置,以下:
defaults
mode http
设置haproxy的运行模式,有三种{http|tcp|health}。注意:若是haproxy中还要使用4层的应用(mode tcp)的话,不建议在此定义haproxy的运行模式。
log global
设置日志继承全局配置段的设置。
option httplog
表示开始打开记录http请求的日志功能。
option dontlognull
若是产生了一个空链接,那这个空链接的日志将不会记录。
option http-server-close
打开http协议中服务器端关闭功能,使得支持长链接,使得会话能够被重用,使得每个日志记录都会被记录。
option forwardfor except 127.0.0.0/8
若是上游服务器上的应用程序想记录客户端的真实IP地址,haproxy会把客户端的IP信息发送给上游服务器,在HTTP请求中添加”X-Forwarded-For”字段,但当是haproxy自身的健康检测机制去访问上游服务器时是不该该把这样的访问日志记录到日志中的,因此用except来排除127.0.0.0,即haproxy身。
option redispatch
当与上游服务器的会话失败(服务器故障或其余缘由)时,把会话从新分发到其余健康的服务器上,当原来故障的服务器恢复时,会话又被定向到已恢复的服务器上。还能够用”retries”关键字来设定在断定会话失败时的尝试链接的次数。
retries 3
向上游服务器尝试链接的最大次数,超过此值就认为后端服务器不可用。
option abortonclose
当haproxy负载很高时,自动结束掉当前队列处理比较久的连接。
timeout http-request 10s
客户端发送http请求的超时时间。
timeout queue 1m
当上游服务器在高负载响应haproxy时,会把haproxy发送来的请求放进一个队列中,timeout queue定义放入这个队列的超时时间。
timeout connect 5s
haproxy与后端服务器链接超时时间,若是在同一个局域网可设置较小的时间。
timeout client 1m
定义客户端与haproxy链接后,数据传输完毕,再也不有数据传输,即非活动链接的超时时间。
timeout server 1m
定义haproxy与上游服务器非活动链接的超时时间。
timeout http-keep-alive 10s
设置新的http请求链接创建的最大超时时间,时间较短时能够尽快释放出资源,节约资源。
timeout check 10s
健康检测的时间的最大超时时间。
maxconn 3000
最大并发链接数。
contimeout 5000
设置成功链接到一台服务器的最长等待时间,默认单位是毫秒,新版本的haproxy使用timeout connect替代,该参数向后兼容。
clitimeout 3000
设置链接客户端发送数据时的成功链接最长等待时间,默认单位是毫秒,新版本haproxy使用timeout client替代。该参数向后兼容。
srvtimeout 3000
设置服务器端回应客户度数据发送的最长等待时间,默认单位是毫秒,新版本haproxy使用timeout server替代。该参数向后兼容。
listen admin_status
frontend和backend的组合体,监控组的名称,按需自定义名称。
bind 0.0.0.0:1080
配置监听端口。
mode http
配置监控运行的模式,在这为http模式。
log 127.0.0.1 local3 err
配置错误日志记录。
stats refresh 5s
配置每隔5秒自动刷新监控页面。
stats uri /stats
配置监控页面的url。
stats realm Haproxy\ Statistics
配置监控页面的提示信息。
stats auth admin:admin
配置监控页面的用户和密码admin,能够设置多个用户名。以下:
stats auth admin1:admin1
配置监控页面的用户和密码admin1。
stats hide-version
配置隐藏统计页面上的HAproxy版本信息。
stats admin if TRUE
配置手工启用/禁用,后端服务器(haproxy-1.4.9之后版本)。
frontend web_demo
定义一个名为 web_demo的frontend。
bind 0.0.0.0:80
定义haproxy前端部分监听的端口。
mode http
定义为http模式。
log global
继承global中log的定义。
option forwardfor
使后端server获取到客户端的真实IP。
acl php_web path_end .php
定义一个名叫php_web的acl,当请求的url末尾是以.php结尾的,将会被匹配到。
use_backend php_server if php_web
若是知足策略php_web时,就将请求交予backend php_server处理。
default_backend backend_default
若是以上策略都不知足时,就将请求交予default_backend处理。
acl使用以下: acl 自定义acl名称 acl方法 -i [匹配的路径或者方法] hdr_reg(host),hdr_dom(host),hdr_beg(host),url_sub,url_dir,path_beg,path_end -i 表示不区分大小写,后边跟上匹配的路径或文件或正则表达式 与ACL一块儿使用的参数还有use_backend,usebackend后面须要跟上一个backend实例名,表示在知足ACL规则后去请求哪一个backend实例,与use_backend对应的还有default_backend参数,表示在没有知足ACL条件的时候默认使用哪一个backend后端 例如: acl static_down nbsrv(static_server) lt 1 定义一个名叫static_down的acl,当backend static_sever中存活机器数小于1时会被匹配到。 #acl php_web url_reg /*.php acl php_web path_end .php 定义一个名叫php_web的acl,当请求的url末尾是以.php结尾的,将会被匹配到,上面两种写法任选其一。 #acl static_web url_reg /*.(css|jpg|png|jpeg|js|gif)$ acl static_web path_end .gif .png .jpg .css .js .jpeg 定义一个名叫static_web的acl,当请求的url末尾是以.css、.jpg、.png、.jpeg、.js、.gif结尾的,将会被匹配到,上面两种写法任选其一。 acl is_ilanni hdr_beg(host) -i ilanni.test.com 定义一个名叫is_ilanni的acl,当请求的是以ilanni.test.com开头的主机的话,将会被匹配到。其中-i表示忽略大小写。 acl is_dg hdr_beg(host) dg.test.com 定义一个名叫is_dg的acl,当请求的是以dg.test.com开头的主机的话,将会被匹配到。 acl is_171 hdr_beg(host) 192.168.5.171 定义一个名叫is_171的acl,当请求的是以192.168.5.171开头的主机的话,将会被匹配到。 acl is_ip src 192.168.5.140 定义一个名叫is_ip的acl,当客户端的IP是192.168.5.140的话,将会被匹配到。 use_backend php_server if static_down 若是知足策略static_down时,就将请求交予backend php_server处理。 use_backend php_server if php_web 若是知足策略php_web时,就将请求交予backend php_server处理。 use_backend static_server if static_web 若是知足策略static_web时,就将请求交予backend static_server处理。 use_backend acl if is_171 is_ip 若是同时知足is_171和is_ip这两条策略时,就将请求交予backend acl处理。 use_backend mui_acl if is_171 is_ip is_port 若是同时知足is_17一、is_ip和is_port这三条策略时,就将请求交予backend mui_acl处理。 use_backend dgserver if is_dg 若是知足策略is_dg时,就将请求交予backend dgserver处理。 use_backend ilanni if is_ilanni 若是知足策略is_ilanni时,就将请求交予backend ilanni处理。 use_backend 171server if is_171 若是知足策略is_171时,就将请求交予backend 171server处理。 default_backend backend_default 若是以上策略都不知足时,就将请求交予default_backend处理。
backend dgserver
定义dgserver服务器组
balance source
定义负载均衡方式,roundrobin平均方式
mode http
option httpchk GET /index.html
心跳检测的文件
server web1 192.168.5.171:8080 maxconn 1024 weight 3 check inter 2000 rise 2 fall 3
服务器定义,maxconn 1024 表示该服务器的最大链接数,check inter 2000是检测心跳频率,rise 2是2次正确认为服务器可用,fall 3是3次失败认为服务器不可用,weight表明权重
配置示例以下:
frontend https_frontend bind *:443 ssl crt /etc/ssl/certs/servername.pem ####关键##### mode http option httpclose option forwardfor reqadd X-Forwarded-Proto:\ https default_backend web_server backend web_server mode http balance roundrobin cookie SERVERID insert indirect nocache server s1 192.168.250.47:80 check cookie s1 server s2 192.168.250.49:80 check cookie s2 注意:这里的pem 文件是下面两个文件合并而成: cat servername.crt servername.key |tee servername.pem
附录:简单地演示生成自签名证书的方式
$ sudo mkdir /etc/ssl/xip.io $ sudo openssl genrsa -out /etc/ssl/xip.io/xip.io.key 1024 $ sudo openssl req -new -key /etc/ssl/xip.io/xip.io.key -out /etc/ssl/xip.io/xip.io.csr > Country Name (2 letter code) [AU]:US > State or Province Name (full name) [Some-State]:Connecticut > Locality Name (eg, city) []:New Haven > Organization Name (eg, company) [Internet Widgits Pty Ltd]:SFH > Organizational Unit Name (eg, section) []: > Common Name (e.g. server FQDN or YOUR name) []:*.xip.io > Email Address []: > Please enter the following 'extra' attributes to be sent with your certificate request > A challenge password []: > An optional company name []: $ sudo openssl x509 -req -days 365 -in /etc/ssl/xip.io/xip.io.csr -signkey /etc/ssl/xip.io/xip.io.key -out /etc/ssl/xip.io/xip.io.crt $ sudo cat /etc/ssl/xip.io/xip.io.crt /etc/ssl/xip.io/xip.io.key | sudo tee /etc/ssl/xip.io/xip.io.pem
当购买真正的证书 时,你不必定会获取拼接后的文件。你能够要本身拼接它们。然而,不少机构也会提供一份拼接好的文件给你。若是你没有获取到拼接后的文件,则它可能不是一个 pem 文件,而是 bundle、cert、cert、key文件或一些相同概念但名称相似的文件。
又称SSL穿透,不须要从新编译支持ssl,简单方便。须要后面的web服务器配置好ssl 便可。
配置示例以下:
frontend https_frontend bind *:443 mode tcp default_backend web_server backend web_server mode tcp balance roundrobin stick-table type ip size 200k expire 30m stick on src server s1 192.168.250.47:443 server s2 192.168.250.49:443 #注意,这种模式下mode 必须是tcp 模式
为了安全起见,要求全部业务服务器都关闭公网的链接,只开放haproxy所在的服务器,而且其余业务服务器的ssh链接经过haproxy来实现。
实际业务,访问192.168.5.171的8098端口就是访问192.168.5.174的ssh端口。
为了安全起见,要求mysql数据库的链接只能经过内网IP,可是由于使用的是云数据库,因此若是公司内部要链接数据库的话要经过haproxy来实现。实际业务,访问192.168.5.171的8099端口就是访问192.168.7.7的3306端口。
以上两个需求的配置以下:
由于是haproxy的7层和4层混合使用,因此在defaults中,咱们不定义haproxy的运行模式。
注意:有关http模式的相关配置参数不要出如今default中。
..... listen 8099 bind 0.0.0.0:8099 mode tcp server 174_22 192.168.5.174:22 maxconn 1024 weight 5 check inter 2000 rise 2 fall 3 listen 8098 bind 0.0.0.0:8098 mode tcp server 77_3306 192.168.7.7:3306 maxconn 1024 weight 5 check inter 2000 rise 2 fall 3