haproxy是一款提供负载均衡的代理服务器,它可基于modetcp 实现伪四层调度,还可以基于modehttp实现七层调度,类似于nginx,因为他没有web服务所以不像nginx那样进行控制。

通过ACL访问控制列表,匹配客户端的请求,和服务器的转发进行控制

官方网站:https://cbonte.github.io/haproxy-dconv/

实验

HAproxy服务器ip:192.168.1.102(这里若隐藏后端服务器的ip,这需要设定两个ip,一个公网,一个私网)(haproxy是一个纯粹的反代,他没有web服务),后端服务器:192.168.1.104    192.168.1.105

1      同步时间 #systemctl start  chronyd.service

2  后端服务器安装http服务或使用nginx

  yum   install   http  -y

  给一个测试网页:

  # vim /var/www/html/index.html

  <h1>server 1 </h1>

  #systemctl start httpd.service     启动服务

3安装haproxy

配置文件:/etc/haproxy/haproxy.cfg

配置文件中配置分为几段:

1  全局配置段 global  (设置自己的进程特性)通用的默认配置

进程及安全配置

性能参数配置

debug参数

用户列表

2 代理配置段  proxy   用于将用户请求代理后端的

代理配置段分四类字段:

    default: 是为backend和listen 这两段 提供默认配置

fronted: 对前端服务器的配置

backend: 对后端服务器的配置

listen:设定frented与backend两者是一 一对应的,这段同时拥有前端和后端的配置,是一对一的,这样其他人就不能调度该后端里

日志:haproxy它本身没有日志功能,日志需要rsyslog或syslog 日志服务来配合

vim /etc/haproxy/haproxy.cfg

日志设定:  log         127.0.0.1   local2      指定本地日志服务器local2

log          127.0.0.1  local2

这需要在rsyslog配置文件中做配置 可能日志服务器中的local2 没有启动

vim   /etc/rsyslog.conf

$ModLoad imudp                  取消注释  基于udp 记录日志

$UDPServerRun 514                 基于udp 描述端口

local2.*                   /var/log/haproxy.log

重启日志服务器:systemctl restart rsyslog.service  (514端口处于监听)

反代配置  

srv1 只是内部使用的id (这里不是主机名)

启动服务:systemctl start haproxy.service

curl http://192.168.1.102     访问测试

负载均衡:

backend  websrvs

balance roundrobin                                   轮询

server srv1 192.168.1.104:80 check

server srv2 192.168.1.105:80 check

重启服务: # systemctl restart haproxy.service

访问:curl http://192.168.1.102

for  i    in  {1.. 10} ; do  curl  http://192.168.1.102/ ;  done

参数:

在global 设置参数  这些参数多数不需要改

1 chroot: 与安全相关(假的根环境)以chroot运行

2  ca-base  若基于ssh回话的ca认证相关

3 cpu-map  cpu绑定类似于nginx的worker进程与cpu的绑定

4 log  指定日志

5 maxconn  最大单进程并发连接数

6 maxconnrate  速率

7 noepoll   不使用epoll机制

haproxy快速安装的更多相关文章

  1. Centos7快速安装haproxy

    HAProxy是一个使用C语言编写的自由及开放源代码软件[1],其提供高可用性.负载均衡,以及基于TCP和HTTP的应用程序代理. HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要 ...

  2. 烂泥:高负载均衡学习haproxy之安装与配置

    本文由秀依林枫提供友情赞助,首发于烂泥行天下 有关高负载均衡的软件,目前使用比较多的是haproxy.nginx和lvs.下面我们就开始学习haprxoy这款软件. 一.haproxy介绍 以下开始介 ...

  3. CocoaPods 的简单快速安装方法

    CocoaPods 的简单快速安装方法(Setting up CocoaPods master repo 卡着不动,是因为淘宝镜像已经不能用了. 一.git clone方法安装cocoapods 镜像 ...

  4. HAProxy的安装与使用

    在互联网时代中,后台系统架构,经常可以听到高可用集群.负载均衡集群之类的系统架构解决方案,其中,负载均衡有基于硬件的F5.Big-IP等,也有基于软件的LVS(基于Linux操作系统实现,性能可以和基 ...

  5. CentOS RDO方式快速安装OpenStack

    一.了解RDO RDO是什么? RDO是红帽Red Hat Enterprise Linux OpenStack Platform的社区版,类似RHEL和Fedora,RHEV和oVirt这样的关系. ...

  6. Linux超快速安装Ruby on Rails

    Linux超快速安装Ruby on Rails 时间 2014-11-25 11:45:11 Flincllck Talk 原文  http://www.flincllck.com/quick-ins ...

  7. Python,Jupyter Notebook,IPython快速安装教程

    0.安装环境 Windows10,Python3.5.1,IPython,jupyter notebook,and other functionality 官方安装文档Linux版3.x 官方安装文档 ...

  8. 转载 - Vultr VPS注册开通且一键快速安装PPTP VPN和电脑连接使用

    本文转载来自:https://www.vultrclub.com/139.html 从2014年Vultr VPS进入市场之后,作为有背景.实力的搅局者,是的最近两年VPS.服务器的用户成本降低.配置 ...

  9. Vmware快速安装linux虚拟机(SUSE)

    安装环境:Vmware 11.SUSE11 64位 vmware快速安装linux虚拟机的过程还是比较简单的,步骤如下: 1.点击文件,新建虚拟机. 2.选择典型安装. 3.在红框中选择想要安装的虚拟 ...

随机推荐

  1. JSP中EL很常用,怎样使用大于号、小于号、等于号等

    JSP中EL很常用,怎样使用大于号.小于号.等于号等   符号 在EL中使用 常规 1 等于 eq == 2 不等于 ne != 3 大于 gt > 4 小于 lt < 5 大于等于 ge ...

  2. 20175209 《Arrays和String单元测试》

    20175209 <Arrays和String单元测试> 题目 在IDEA中以TDD的方式对String类和Arrays类进行学习,测试相关方法的正常,错误和边界情况 String类 ch ...

  3. 使用vcastr22.swf做flash版网页视频播放器

    flash的安装设置参考  Flash设置(各种版本浏览器包括低版本IE) 百度搜索下载vcastr22.swf文件 然后使用方式很简单,浏览器安装flash相关插件就能看了 视频路径主要在这里,视频 ...

  4. Java IO系列之二:NIO基本操作

    核心部分  NIO( New Input/ Output) , 引入了一种基于通道和缓冲区的 I/O 方式,NIO 是一种同步非阻塞的 IO 模型.同步是指线程不断轮询 IO 事件是否就绪,非阻塞是指 ...

  5. 【Unity编辑器】UnityEditor多重弹出窗体与编辑器窗口层级管理

    一.简介 最近马三为公司开发了一款触发器编辑器,对于这个编辑器策划所要求的质量很高,是模仿暴雪的那个触发器编辑器来做的,而且之后这款编辑器要作为公司内部的一个通用工具链使用.其实,在这款触发器编辑器之 ...

  6. python 高级部分

    伴随视频可以观看 因为Python的线程虽然是真正的线程,但解释器执行代码时,有一个GIL锁:Global Interpreter Lock,任何Python线程执行前,必须先获得GIL锁,然后,每执 ...

  7. 【7】学习C++之类的构造函数

    (说实话,我一开始真没觉得构造函数这块有多重要,但是看的视频中老师却花了不少的时间去讲这块内容,本着整理了不亏的心态还是整理了一下) 1.常见的构造函数 C++的类在创建对象的时候,都会去调用构造函数 ...

  8. eclipse添加jar包进jar源码debug调试

    1.点击调试配置 2.选中源码 3.点击添加 4.点击java路径变量 5.点击环境变量配置 6.输入名称及jar包复制限定名

  9. jsonp和CORS跨域实现

    一.jsonp,使用jquery封装的$.ajax,返回数据类型要设置为jsonp 示例: $.ajax({ type: 'get', contentType: "application/j ...

  10. STL--hashtable

    hashtable使用开链的方式,解决元素个数大于array容量的问题. 当两个不同元素hash得到相同的hash值时,此时我们使用bucket list来链接连个元素. hashtable迭代器必须 ...