负载均衡之Haproxy配置详解(及httpd配置)
| 
 三大主流软件负载均衡器对比(LVS VS Nginx VS Haproxy) 
  | 
总结HAProxy主要优点:
一、免费开源,稳定性也是非常好,这个可通过我做的一些小项目可以看出来,单Haproxy也跑得不错,稳定性可以与LVS相媲美;
二、根据官方文档,HAProxy可以跑满10Gbps-New benchmark of HAProxy at 10 Gbps using Myricom's 10GbE NICs (Myri-10G PCI-Express),这个作为软件级负载均衡,也是比较惊人的;
三、HAProxy可以作为MySQL、邮件或其它的非web的负载均衡,我们常用于它作为MySQL(读)负载均衡;
四、自带强大的监控服务器状态的页面,实际环境中我们结合Nagios进行邮件或短信报警,这个也是我非常喜欢它的原因之一;
五、HAProxy支持虚拟主机。
| 
 global                                                       # 全局参数的设置 
    log         127.0.0.1 local2                      # log语法:log <address_1>[max_level_1] # 全局的日志配置,使用log关键字, 
                                                                     指定使用127.0.0.1 
                                                                     上的syslog服务中的local0日志设备,记录日志等级为info的日志 
    chroot      /var/lib/haproxy                 #改变当前工作目录 
    pidfile     /var/run/haproxy.pid          #当前进程id文件 
    maxconn     4000                                #最大连接数 
    user        haproxy                                #所属用户 
    group     haproxy                                #所属组 
    daemon                                               #以守护进程方式运行haproxy 
    stats socket /var/lib/haproxy/stats 
defaults 
    mode                    http                        #默认的模式mode { tcp|http|health },tcp是4层,http是7层,health只会返回OK 
    log                        global                    #应用全局的日志配置 
    option                  httplog                  # 启用日志记录HTTP请求,默认haproxy日志记录是不记录HTTP请求日志 
    option                  dontlognull          # 启用该项,日志中将不会记录空连接。所谓空连接就是在上游的负载均衡器 
                                                                   或者监控系统为了探测该 服务是否存活可用时,需要定期的连接或者获取某 
                                                                  一固定的组件或页面,或者探测扫描端口是否在监听或开放等动作被称为空连接; 
                                                                  官方文档中标注,如果该服务上游没有其他的负载均衡器的话,建议不要使用 
                                                                   该参数,因为互联网上的恶意扫描或其他动作就不会被记录下来 
    option http-server-close                   #每次请求完毕后主动关闭http通道 
    option forwardfor       except 127.0.0.0/8   #如果服务器上的应用程序想记录发起请求的客户端的IP地址,需要在HAProxy 
                                                                            上 配置此选项, 这样 HAProxy会把客户端的IP信息发送给服务器,在HTTP 
                                                                            请求中添加"X-Forwarded-For"字段。 启用  X-Forwarded-For,在requests 
                                                                            头部插入客户端IP发送给后端的server,使后端server获取到客户端的真实IP。  
    option                  redispatch                      # 当使用了cookie时,haproxy将会将其请求的后端服务器的serverID插入到 
                                                                            cookie中,以保证会话的SESSION持久性;而此时,如果后端的服务器宕掉 
                                                                            了, 但是客户端的cookie是不会刷新的,如果设置此参数,将会将客户的请 
                                                                            求强制定向到另外一个后端server上,以保证服务的正常。 
    retries                 3                             # 定义连接后端服务器的失败重连次数,连接失败次数超过此值后将会将对应后端 
                                                                  服务器标记为不可用 
    timeout http-request    10s             #http请求超时时间 
    timeout queue           1m                 #一个请求在队列里的超时时间 
    timeout connect         10s                #连接超时 
    timeout client          1m                   #客户端超时 
    timeout server          1m                   #服务器端超时 
    timeout http-keep-alive 10s           #设置http-keep-alive的超时时间 
    timeout check           10s                 #检测超时 
    maxconn                 3000                 #每个进程可用的最大连接数 
frontend  main *:80                             #监听地址为80 
    acl url_static       path_beg       -i /static /images /javascript /stylesheets 
    acl url_static       path_end       -i .jpg .gif .png .css .js 
    use_backend static          if url_static 
    default_backend             my_webserver     #定义一个名为my_app前端部分。此处将对于的请求转发给后端 
backend static                                                 #使用了静态动态分离(如果url_path匹配 .jpg .gif .png .css .js静态文件则 
                                                                            访问此后端) 
    balance     roundrobin                               #负载均衡算法(#banlance roundrobin 轮询,balance source 保存session值, 
                                                                           支持static-rr,leastconn,first,uri等参数) 
    server      static 127.0.0.1:80 check             #静态文件部署在本机(也可以部署在其他机器或者squid缓存服务器) 
backend my_webserver                                  #定义一个名为my_webserver后端部分。PS:此处my_webserver只是一个 
                                                                            自定义名字而已,但是需要与frontend里面配置项default_backend 值相一致 
    balance     roundrobin                               #负载均衡算法 
    server  web01 172.31.2.33:80  check inter 2000 fall 3 weight 30              #定义的多个后端 
    server  web02 172.31.2.34:80  check inter 2000 fall 3 weight 30              #定义的多个后端 
    server  web03 172.31.2.35:80  check inter 2000 fall 3 weight 30              #定义的多个后端 
 | 
systemctl restart haproxy
1、实验环境
centos 7.1 X64 mini版
2、配置web服务器(node33/34/35):
测试方便,关闭selinux、关闭iptables
一下都采用默认,不做配置即可。
yum install httpd -y
# vim /etc/httpd/conf/httpd.conf
httpd监听端口:
DocumentRoot:网页存放的路径,文档的根目录
重启httpd
# systemctl restart httpd
页面访问httpd:
修改显示内容:
# vim /var/www/html/index.html
I'm node33!!! My IP is 172.31.2.33...
再次访问:
这样三个web服务33/34/35搭建成功!!!!
接下来配置负载均衡(本次实验只用一个Haproxy:172.31.2.31):
负载均衡之Haproxy配置详解(及httpd配置)的更多相关文章
- 千万级高并发负载均衡软件haproxy配置文件详解
		
balance roundrobin #轮询方式 balance source #将用户IP经过hash计算后,使同一IP地址的所有请求都发送到同一固定的后 ...
 - Nginx/LVS/HAProxy 负载均衡软件的优缺点详解
		
Nginx/LVS/HAProxy 负载均衡软件的优缺点详解 Nginx/LVS/HAProxy是目前使用最广泛的三种负载均衡软件,本人都在多个项目中实施过,参考了一些资料,结合自己的一些使用经验 ...
 - 总结)Nginx/LVS/HAProxy负载均衡软件的优缺点详解
		
总结)Nginx/LVS/HAProxy负载均衡软件的优缺点详解 PS:Nginx/LVS/HAProxy是目前使用最广泛的三种负载均衡软件,本人都在多个项目中实施过,参考了一些资料,结合自己的一些使 ...
 - Nginx/LVS/HAProxy负载均衡软件的优缺点详解【转】
		
转自 (总结)Nginx/LVS/HAProxy负载均衡软件的优缺点详解http://www.ha97.com/5646.html PS:Nginx/LVS/HAProxy是目前使用最广泛的三种负载均 ...
 - (总结)Nginx/LVS/HAProxy负载均衡软件的优缺点详解
		
Nginx/LVS/HAProxy负载均衡软件的优缺点详解 PS:Nginx/LVS/HAProxy是目前使用最广泛的三种负载均衡软件,参考了一些资料,结合自己的一些使用经验,总结一下. 一般对负载均 ...
 - IIS负载均衡-Application Request Route详解第二篇:创建与配置Server Farm(转载)
		
IIS负载均衡-Application Request Route详解第二篇:创建与配置Server Farm 自从本系列发布之后,收到了很多的朋友的回复!非常感谢,同时很多朋友问到了一些问题,有些问 ...
 - IIS负载均衡-Application Request Route详解第四篇:使用ARR实现三层部署架构(转载)
		
IIS负载均衡-Application Request Route详解第四篇:使用ARR实现三层部署架构 系列文章链接: IIS负载均衡-Application Request Route详解第一篇: ...
 - IIS负载均衡-Application Request Route详解第一篇: ARR介绍(转载)
		
IIS负载均衡-Application Request Route详解第一篇: ARR介绍 说到负载均衡,相信大家已经不再陌生了,本系列主要介绍在IIS中可以采用的负载均衡的软件:微软的Applica ...
 - IIS负载均衡-Application Request Route详解第一篇: ARR介绍
		
IIS负载均衡-Application Request Route详解第一篇: ARR介绍 说到负载均衡,相信大家已经不再陌生了,本系列主要介绍在IIS中可以采用的负载均衡的软件:微软的Applica ...
 - mybatis 代码生成器(IDEA, Maven)及配置详解(部分配置你应该不知道)
		
目录 1 创建代码生成器 1.1 创建Maven项目 1.2 配置 generator.xml 1.3 配置 pom.xml 1.4 使用及测试 2 XML 配置详解 2.1 优先 2.2 官网没有的 ...
 
随机推荐
- mif_maker2010.exe下载和使用说明
			
mif_malker2010.exe下载地址:http://pan.baidu.com/s/1bCqAp4 使用说明:http://www.cnblogs.com/BitArt/archive/201 ...
 - Team Homework #2 Decide the roles of each team member ——IloveSE
			
大家好,我们是IloveSEers! 徐姗,我是一个性格开朗,但却认为计算机比较枯燥的女生.经过两年的学习,自己的编程能力,并不是很强,在这方便还需多多练习.对于软件工程这门课,我充满期待,因为我不仅 ...
 - 玩耍Hibernate系列(一)--基础知识
			
Hibernate框架介绍: Hibernate ORM 主要用于持久化对象(最常用的框架) Hibernate Search 用于对对象进行搜索,底层基于Apache Lucene做的 Hib ...
 - 【Unique Binary Search Trees】cpp
			
题目: Given n, how many structurally unique BST's (binary search trees) that store values 1...n? For e ...
 - hdu 2255 奔小康赚大钱 最大权匹配KM
			
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2255 传说在遥远的地方有一个非常富裕的村落,有一天,村长决定进行制度改革:重新分配房子.这可是一件大事 ...
 - max_flow(Ford-Fulkerson)                                                    分类:            ACM TYPE             2014-09-02 01:50    110人阅读    评论(0)    收藏
			
#include <cstdio> #include <iostream> #include <cstring> #include<queue> usi ...
 - shiro添加注解@RequiresPermissions不起作用
			
这是因为没有开启spring拦截器,在spring-mvc.xml中加入以下代码就可以了(一定要写在最先加载的xml中,写在后面加载的xml中也不起作用) <bean class="o ...
 - IE 选择文字后 显示小箭头 加速按钮
			
IE - 工具 - Internet选项 - 高级 - 不选择<在选择是显示加速按钮>选项就可以了.
 - Reactor构架模式
			
http://www.cnblogs.com/hzbook/archive/2012/07/19/2599698.html Reactor框架是ACE各个框架中最基础的一个框架,其他框架都或多或少地用 ...
 - POJ 1742
			
Coins Time Limit: 3000MS Memory Limit: 30000K Total Submissions: 27580 Accepted: 9335 Descriptio ...