Haproxy的应用
如上图所示,在 192.168.1.0/24
这个网段的客户端想要访问在 172.20.0.0/20
网段内的服务器,所有的通信又不想暴露在互联网上,因此可以在这两个网段内分别都放一台 Haproxy 服务器,并将两台 Haproxy 直连,10.94.0.73
到 10.94.0.72
互通,然后做两次代理即可。
Haproxy1 应该监听在 192.168.1.105
上以供 192.168.1.0/24
网段内的主机访问,然后指定源地址 10.94.0.73
将请求指向后端服务器 Haproxy2 的 10.94.0.72
。
Haproxy1 的配置
1 |
global |
Haproxy2 应该监听在 10.94.0.72
以供 Haproxy1 的 10.94.0.73
来请求,然后指定源地址 172.20.0.254
将 Web 请求指向后端服务器 172.20.15.15:80
,将 MySQL 请求指向后端服务器 172.20.11.154:3306
。
Haproxy2 的配置
1 |
global |
Web 负载均衡
如图所示,客户端访问 192.168.127.130
时,要把请求分发到 192.168.127.131:80
、192.168.127.132:80
这两台服务器上。这是一个最简单的负载均衡结构图,实现起来比较简单。
1 |
global |
配置说明
- Global settings :这是第一部分的配置,全局配置;对Haproxy进程自身属性的设定
- proxys:对代理的设定,通常有4部分组成
- defaults:提供默认配置
- frontend:前端配置
- backend:后端配置
- listen:从某种意义上讲可以认为是将 frontend 和 backend 整合到一块的
ACL 匹配
如图所示,要求
1、如果客户端的 IP 是 192.168.127.110
,访问 192.168.127.130
时,要把请求分发到 Web Server3 上,即 192.168.127.133
。
2、客户端访问 192.168.127.130
时,要把请求分发到 192.168.127.131
,192.168.127.132
,192.168.127. 大专栏 Haproxy的应用133
这三台服务器上。同时还要求客户端每一次访问,都跳转到不同的服务器上。
3、如果客户端访问的不是 192.168.127.130
而是 192.168.127.129
时,要把请求全部分发到 Web Server1 上,即 192.168.127.131
。
1 |
global |
状态监控
在其他的配置完成后,做一个全局配置区段,用来监控 Haproxy 服务器的状态。
1 |
listen Haproxy_Status # 关联前端和后端定义一个完整的代理 |
配置好之后,重启服务访问 http://192.168.127.130:1080/status
即可看到状态信息。
记录日志
自己记录日志
1 |
local2.* /var/log/haproxy.log |
交给日志服务器记录日志
配置 /etc/haproxy/haproxy.cfg
1 |
log 127.0.0.1 local2 |
开启 rsyslog 记录 haproxy 日志功能,编辑 /etc/rsyslog.conf
找到如下配置项并去掉配开头的的注释
1 |
# Provides UDP syslog reception |
添加如下内容
1 |
# Save haproxy log |
配置 /etc/sysconfig/rsyslog
1 |
# Options for rsyslogd |
相关解释说明:
- -r: 打开接受外来日志消息的功能,其监控514 UDP端口;
- -x: 关闭自动解析对方日志服务器的FQDN信息,这能避免DNS不完整所带来的麻烦;
- -m: 修改syslog的内部mark消息写入间隔时间(0为关闭),例如240为每隔240分钟写入一次”–MARK–”信息;
- -h: 默认情况下,syslog不会发送从远端接受过来的消息到其他主机,而使用该选项,则把该开关打开,所有接受到的信息都可根据syslog.conf中定义的@主机转发过去.
重启服务查看日志
1 |
systemctl restart rsyslog haproxy |
Haproxy的应用的更多相关文章
- [笔记]HAproxy reload config file with uninterrupt session
HAProxy is a high performance load balancer. It is very light-weight, and free, making it a great op ...
- [原]HAproxy 代理技术原理探究
HAproxy 技术分享 简介 HAProxy是一款提供高可用性.负载均衡以及基于TCP(第四层)和HTTP(第七层)应用的代理软件 Features 1.免费 2.能够做到4层以上代理 3.高性能 ...
- 利用HAProxy代理SQL Server的AlwaysOn辅助副本
利用HAProxy代理SQL Server的AlwaysOn辅助副本 公司最近数据库升级到SQL Server2014 ,并部署了alwayson高可用集群 机房内有三套程序需要读取数据库 第一套:主 ...
- Mysql的Haproxy反向代理和负载均衡
HaProxy提供高可用性.负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费.快速并且可靠的一种解决方案.应用到Haproxy主要是因为他免费,并且基于TCP和HTTP的应用代理. ...
- HAProxy介绍
简单说明 HAProxy提供高可用性.负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费.快速并且可靠的一种解决方案.HAProxy特别适用于那些负载特大的web站点,这些站点通常又需 ...
- 对比Haproxy和Nginx负载均衡效果
为了对比Hproxy和Nginx负载均衡的效果,分别在测试机上(以下实验都是在单机上测试的,即负载机器和后端机器都在一台机器上)做了这两个负载均衡环境,并各自抓包分析.下面说下这两种负载均衡环境下抓包 ...
- haproxy windows环境使用
haproxy下载:http://pan.baidu.com/s/1miEvQUc 测试环境说明: ip地址 作用 开放端口 备注 nbproc 1 daemon defaults mode tcp ...
- haproxy利用ACL规则封禁自定义IP地址拒绝访问
现在有一个需求就是在发版的时候希望除公司IP外的外网访问服务的时候都是拒绝访问的 现在利用haproxy 的acl规则作出限制 errorfile 403 /etc/haproxy/err ...
- HAProxy的日志配置以及ACL规则实现负载均衡
HAProxy配置日志策略 默认情况下,HAProxy是没有配置日志的在centos6.3下默认管理日志的是rsyslog,可以实现UDP日志的接收,将日志写入文件,写入数据库先检测rsyslog是否 ...
- HAproxy的安装与配置讲解
1,安装 官网下载 http://www.haproxy.org/#down cd /usr/local/src/ wget http://www.haproxy.org/download/1.4/s ...
随机推荐
- 四十二、LAMP与LNMP web架构深度优化实战-第一部
1.nginx.conf配置文件基本参数优化 1.1 隐藏nginx header内版本号信息 一些特定的系统及服务漏洞一般都和特定的软件版本号有关,我们应尽量隐藏服务器的敏感信息(软件名称及版本等信 ...
- MTF的倾斜边缘计算方法
光学系统性能的衡量方法有很多,常见的有点扩散函数法.瑞利判断法.点 列图法.光学传递函数(MTF)法等,其中 MTF 法在光学系统和镜头加工制造中 使用 最为广泛.MTF 曲线真实的反映了成像系统将物 ...
- RDD(六)——分区器
RDD的分区器 Spark目前支持Hash分区和Range分区,用户也可以自定义分区,Hash分区为当前的默认分区,Spark中分区器直接决定了RDD中分区的个数.RDD中每条数据经过Shuffle过 ...
- Django框架篇
Django框架 1.HTTP超文本传输协议 8中请求方法 GET , POST ,HEAD ,PUT ,DELETE , TRACE ,OPTIONS ,CONNCT 状态码 1xx ;服务器收到请 ...
- Review For Exam
Review For Exam [2019 福建省赛] 一个很简单的状态压缩DP,结果集体走偏 如何解决连续几日的限制问题?这种东西普通的DP很难写 #include <bits/stdc++. ...
- Exchange Onine 公用文件夹
公用文件夹专为共享访问设计,为收集.组织信息及工作组织中的其他人共享信息提供提供了一种轻松.有效的方式.公用文件夹帮助以易于浏览的层次结构来组织内容. 一.公用文件夹的适用环境 公用文件夹在以下out ...
- AJAX数据传输
AJAX = Asynchronous JavaScript and XML(异步的Javascript和XML) AJAX最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页 ...
- java中BigDecimal的四舍五入小记
static class test{ public static void main(String[] args) { BigDecimal b=new BigDecimal(45); BigDeci ...
- Java源码之ArrayList
本文源码均来自Java 8 总体介绍 Collection接口是集合类的根接口,Java中没有提供这个接口的直接的实现类.Set和List两个类继承于它.Set中不能包含重复的元素,也没有顺序来存放. ...
- Nearby Bicycles
With fast developments of information and communication technology, many cities today have establish ...