负载均衡器之 Haproxy
1. 编译安装haproxy
官网: http://www.haproxy.org
1.1 下载haproxy
# wget http://www.haproxy.org/download/1.6/src/haproxy-1.6.14.tar.gz
1.2 解压haproxy
# .tar.gz
1.3 查看编译方法
# less README
下面选自README
To build haproxy, you have to choose your target OS amongst the following ones
and assign it to the TARGET variable :
- linux22 for Linux 2.2
- linux24 for Linux 2.4 and above (default)
- linux24e for Linux 2.4 with support for a working epoll (> 0.21)
- linux26 for Linux 2.6 and above
- linux2628 , .x, and above (enables splice and tproxy)
- solaris or (others untested)
- freebsd to (others untested)
- netbsd for NetBSD
- osx for Mac OS/X
- openbsd for OpenBSD 3.1 and above
- aix51 for AIX 5.1
- aix52 for AIX 5.2
- cygwin for Cygwin
- generic for any other OS or version.
- custom to manually adjust every setting
By default, the DEBUG variable is set to '-g' to enable debug symbols. It is
not wise to disable it on uncommon systems, because it's often the only way to
get a complete core when you need one. Otherwise, you can set DEBUG to '-s' to
strip the binary.
For example, I use this to build :
$
And I build it this way on OpenBSD or FreeBSD :
$ gmake TARGET=freebsd USE_PCRE= USE_OPENSSL= USE_ZLIB=
And on a classic Linux with SSL and ZLIB support (eg: Red Hat .x) :
$ USE_OPENSSL= USE_ZLIB=
And on a recent Linux >= with SSL and ZLIB support :
$ USE_OPENSSL= USE_ZLIB=
In order to build a -bit binary on an x86_64 Linux system with SSL support
without support for compression but when OpenSSL requires ZLIB anyway :
$ ADDLIB=-lz
1.4 安装:
# USE_OPENSSL= USE_ZLIB= 安装方法是根据自己内核版本来了,具体查看内核的方法: # uname -a # make install PREFIX=/usr/local/haproxy
2. haproxy最简单的配置
2.1 拷贝配置文件
# mkdir -p /usr/local/haproxy/conf/ # cp -a examples/content-sw-sample.cfg /usr/local/haproxy/conf/ # mv /usr/local/haproxy/conf/content-sw-sample.cfg /usr/local/haproxy/conf/http_haproxy.conf
配置配置文件如下
# cat http_haproxy.conf | grep -v "#"
global
maxconn
log 127.0.0.1 local0
uid
gid
chroot /usr/local/haproxy/var
daemon
frontend public
bind name clear
mode http
default_backend dynamic
timeout client 30s
backend dynamic
mode http
timeout connect 5s
timeout server 30s
timeout queue 30s
balance roundrobin
server server_01 minconn maxconn check inter
server server_02 minconn maxconn check inter
#
2.2 检查语法
# ./haproxy -f /usr/local/haproxy/conf/http_haproxy.conf -c Configuration file is valid #
2.3 测试访问
# netstat -tulnp | grep haproxy tcp /./haproxy # # curl -I http://192.168.31.243:81/ HTTP/ OK Server: nginx/ Date: Mon, Jan :: GMT Content-Type: text/html Content-Length: Last-Modified: Tue, Dec :: GMT ETag: "5c1898d6-27c" Accept-Ranges: bytes # curl -I http://192.168.31.243:80 HTTP/ OK Server: nginx/ Date: Mon, Jan :: GMT Content-Type: text/html Content-Length: Last-Modified: Tue, Dec :: GMT Connection: keep-alive ETag: "5c1898d6-27c" Accept-Ranges: bytes #
3. 出现的问题和解决的办法
3.1 haproxy 默认log不输出的问题
在haproxy配置文件中,指定了 log 输出为 local0 之后,同时也在 /etc/rsyslog.conf 配置了
local0.* /var/log/haproxy.log
发现还是不行,最后发现UDPServer未开启导致的,
# cat /etc/rsyslog.conf | grep "UDPServerRun" $UDPServerRun # UDPServerRun 514 需要打开
验证是否打开 # netstat -tulnp | grep 514 udp 0 0 0.0.0.0:514 0.0.0.0:* 2772/rsyslogd udp 0 0 :::514 :::* 2772/rsyslogd #
负载均衡器之 Haproxy的更多相关文章
- 软件级负载均衡器(LVS/HAProxy/Nginx)的特点简介和对比
本文出自 “抚琴煮酒” 博客,出处http://andrewyu.blog.51cto.com/1604432/697466 现在网站发展的趋势对网络负载均衡的使用是随着网站规模的提升根据不同的阶 ...
- Haproxy原理(1)
一.四层和七层负载均衡的区别 所谓的四层就是ISO参考模型中的第四层.四层负载均衡也称为四层交换机,它主要是通过分析IP层及TCP/UDP层的流量实现的基于IP加端口的负载均衡.常见的基于四层的负载均 ...
- 关于haproxy
高性能负载均衡软件 haproxy 一.四层和七层负载均衡的区别: 所谓的四层就是OSI参考模型中的第四层,四层负载均衡也称为四层交换机,他主要是通过分析IP层及TCP/UDP层的流量实现的基于IP加 ...
- PXC5.7(Percona XtraDB Cluster)+HAproxy+Keepalived 集群部署
Percona-XtraDB-Cluster+Haproxy 搭建集群环境 环境准备及服务器信息: 配置防火墙 firewall-cmd --add-port=3306/tcp --permanent ...
- HAProxy详解(一):HAProxy介绍【转】
一.高性能负载均衡软件HAProxy介绍: 随着互联网业务的迅猛发展,大型电商平台和门户网站对系统的可用性和可靠性要求越来越高,高可用集群.负载均衡集群成为一种热门的系统架构解决方案.在众多的负载均衡 ...
- HAProxy从零开始到掌握
转自:https://www.jianshu.com/p/c9f6d55288c0 目录: HAProxy是什么 HAProxy的核心能力和关键特性 HAProxy的安装和运行 使用HAProxy搭建 ...
- 1、代理服务器及haproxy基础
1.web站点架构 前端一台主机提供app server,当用户请求到达时,如果要存储结构化数据,就需要找一台主机做database server.当业务达到一定程度时,要把web server.存储 ...
- [转]Haproxy原理(1)
本文出处:https://www.cnblogs.com/skyflask/p/6970151.html 目录 一.四层和七层负载均衡的区别二.HAProxy与LVS的异同三.快速安装HAProxy集 ...
- Haproxy基础知识 -运维小结
开源软件负载均衡器 现在常用的三大开源软件负载均衡器分别是Nginx.LVS.Haproxy. 在之前的文章中已经对比了这三个负载均衡软件, 下面根据自己的理解和使用经验, 再简单说下这三个负载均衡软 ...
随机推荐
- CSS 图像高级 Css Sprites
上节课中我们学习了背景图像,这节课我们学习背景图像的高级知识,如Css Sprites,CSS 背景渐变等. Css Sprites Css Sprites,国内也叫CSS精灵.它的原理是将许多的小图 ...
- leetcode268缺失数字
int missingNumber(int* nums, int numsSize) { ) /; ;i<numsSize;i++){ sum = sum - nums[i]; } return ...
- js 金额用逗号隔开
function money(s, n) { n = n > 0 && n <= 20 ? n : 2; s = parseFloat((s + "") ...
- chrome开发者工具实现整站截屏
我们经常要遇到将整个网站作为图片保存下来的情况,而windows系统自带的PrintScreen键只能保存当前屏幕的截图 在chrome浏览器中可以安装第三方的截图插件实现整站截图 今天我们要介绍的方 ...
- Java 中的日志
参考:https://www.cnblogs.com/gavanwanggw/p/7305218.html 日志框架: 提供日志调用的接口,实际的日志输出托付给日志系统实现 JCL:比较流行的日志框架 ...
- python 多进程/多线程/协程 同步异步
这篇主要是对概念的理解: 1.异步和多线程区别:二者不是一个同等关系,异步是最终目的,多线程只是我们实现异步的一种手段.异步是当一个调用请求发送给被调用者,而调用者不用等待其结果的返回而可以做其它的事 ...
- HDU 1522 Marriage is Stable 稳定婚姻匹配
http://acm.hdu.edu.cn/showproblem.php?pid=1522 #include<bits/stdc++.h> #define INF 0x3f3f3f3f ...
- JAVA多线程之线程间的通信方式
(转发) 收藏 记 周日,北京的天阳光明媚,9月,北京的秋格外肃穆透彻,望望窗外的湛蓝的天,心似透过栏杆,沐浴在这透亮清澈的蓝天里,那朵朵白云如同一朵棉絮,心意畅想....思绪外扬, 鱼和熊掌不可兼得 ...
- 设计模式学习心得<组合模式 Composite>
组合模式(Composite Pattern),又叫部分整体模式,是用于把一组相似的对象当作一个单一的对象.组合模式依据树形结构来组合对象,用来表示部分以及整体层次.这种类型的设计模式属于结构型模式, ...
- linux RCU机制
参考资料: https://www.cnblogs.com/qcloud1001/p/7755331.html https://www.cnblogs.com/chaozhu/p/6265740.ht ...