热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

HAProxy入门及基础负载应用

HAProxy入门及基础负载应用

A、首介。。。

HAProxy ——开放源代码软件,是一款代理服务器和伪4层的负载均衡软件解决方案。 基于TCP(第四层)和HTTP(第七层)应用的代理软件 ,支持高并发链接,它的工作模式可以将其简单而安全地整合到当前的服务架构中,同时可以保护你的WEB服务器不暴露到网络上(设置成代理来实现的 通过VIP将后端的web服务器隐藏到内网中)。haproxy进入了商业版本以后,就进入了快速迭代周期,目前正在维护的版本有 1.4  1.5  1.6  1.7;

B、特点。。。

b1、免费开源,稳定性非常好

b2、支持链接拒绝,可以用于防止DDoS攻击

b3、 支持虚拟主机

b4、 能够补充Nginx的一些缺点,路由HTTP请求到后端服务器,基于COOKIE作会话绑定;同时支持通过获取指定的url来检测后端服务器的状态

b5、能够将多个请求反代至后端主机完成负载均衡的效果

b6、通过一个URI接口web应用程序为通过身份验证的用户提供报告详细状态.

b7、 自带监控服务器状态的页面,实时监控状态、强大的后端主机健康检测功能.

b8、支持 单一进程模型,事件驱动,弹性二叉树;

b9、 负载均衡策略算法较多、具体有如下8种:

① roundrobin,表示简单的轮询,这个是负载均衡基本都具备的;

② static-rr,表示根据权重,选择 server 的逻辑最为简单

③ leastconn,表示最少连接者先处理

④ source,表示根据请求源IP,这个跟Nginx的IP_hash机制类似,用其作为解决session问题的一种方法

⑤ ri,表示根据请求的URI;

⑥ rl_param,表示根据请求的URl参数’balance url_param’ requires an URL parameter name;

⑦ hdr(name),表示根据HTTP请求头来锁定每一次HTTP请求;

⑧ rdp-COOKIE(name),表示根据据COOKIE(name)来锁定并哈希每一次TCP请求。

C、安装。。。

安装较为简单,在Centos6.4版本后,haproxy就被收录进ISO光盘的base仓库,可见其较高的市场占有率和大众接受度,

c1、查看安装信息 yum info haproxy   

c2、安装  yum install haproxy  -y              

D、程序环境。。。 

d1、程序配置文件路径

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

                Unit File:/usr/lib/systemd/system/haproxy.service (CentOS7)

                主程序:/usr/sbin/haproxy

                日志管理辅助:/usr/bin/halog

                网段计算辅助文件:/usr/bin/iprange

内建的错误页文件:

/usr/share/haproxy/400.http

/usr/share/haproxy/403.http

/usr/share/haproxy/408.http

/usr/share/haproxy/500.http

/usr/share/haproxy/502.http

/usr/share/haproxy/503.http

/usr/share/haproxy/504.http             

d2、Haproxy配置文件分析

首先备份下

cp /etc/haproxy/haproxy.cfg{,.bak}

打开haproxy.cfg

vim /etc/haproxy/haproxy.cfg

global: 全局配置段,参数是进程级的,通常是和操作系统相关,如果配置无误,就不需要再次进行修改

proxles 代理配置段如下:

— defaults :  为frontend, backend以及listen提供默认配置;

— frontend :  相当于nginx的server段,接收请求的前端虚拟节点

— backend : 后端服务集群的配置,是真实服务器,一个Backend对应一个或者多个实体服务器,相当于nginx的upstream段,

E、基础负载测试。。。

测试准备

     e1、3台主机,第1台(7.3)安装haproxy做调试器,第2,3台(6.8)安装httpd做web应用,配置/var/www/html/index.html测试页面,(3台IP之间需互通)

e2、启动服务: service httpd start,并监测80端口是否开启,ss -tnlp |grep 80 , 浏览器访问时确认关闭防火墙:iptables -F 及selinux : getenforce,

e3、确认可正常浏览

HAProxy 入门及基础负载应用

e4、接下来配置haproxy负载,仅更改几个配置点即可,主要更改frontend和backend段

  1.  可自定义frontend的main名称,加端口即可,如web的80 , ohoh *:80
  2.  default_backend 也可自定,不要和main名称一样即好, web_ser
  3. 此段的中间几行,默认即可,也可删除
  4. 配置backend段,修改backend名称同上web_ser
  5. balance默认调度算法 roundrobin简单轮询,默认
  6. 复制一行server, 将后端的两台http服务器IP和端口写入。保存退出
  7. 启动haproxy服务, systemctl  start  haproxy.service

HAProxy 入门及基础负载应用

END:浏览器访问,刷新查看两台切换

HAProxy 入门及基础负载应用

HAProxy 入门及基础负载应用

待续。。。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 我们


推荐阅读
  • 服务网关与流量网关
    一、为什么需要服务网关1、什么是服务网关传统的单体架构中只需要开放一个服务给客户端调用,但是微服务架构中是将一个系统拆分成多个微服务,如果没有网关& ... [详细]
  • 如何在服务器主机上实现文件共享的方法和工具
    本文介绍了在服务器主机上实现文件共享的方法和工具,包括Linux主机和Windows主机的文件传输方式,Web运维和FTP/SFTP客户端运维两种方式,以及使用WinSCP工具将文件上传至Linux云服务器的操作方法。此外,还介绍了在迁移过程中需要安装迁移Agent并输入目的端服务器所在华为云的AK/SK,以及主机迁移服务会收集的源端服务器信息。 ... [详细]
  • t-io 2.0.0发布-法网天眼第一版的回顾和更新说明
    本文回顾了t-io 1.x版本的工程结构和性能数据,并介绍了t-io在码云上的成绩和用户反馈。同时,还提到了@openSeLi同学发布的t-io 30W长连接并发压力测试报告。最后,详细介绍了t-io 2.0.0版本的更新内容,包括更简洁的使用方式和内置的httpsession功能。 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了软件测试知识点之数据库压力测试方法小结相关的知识,希望对你有一定的参考价值。 ... [详细]
  • LVS实现负载均衡的原理LVS负载均衡负载均衡集群是LoadBalance集群。是一种将网络上的访问流量分布于各个节点,以降低服务器压力,更好的向客户端 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • Tomcat/Jetty为何选择扩展线程池而不是使用JDK原生线程池?
    本文探讨了Tomcat和Jetty选择扩展线程池而不是使用JDK原生线程池的原因。通过比较IO密集型任务和CPU密集型任务的特点,解释了为何Tomcat和Jetty需要扩展线程池来提高并发度和任务处理速度。同时,介绍了JDK原生线程池的工作流程。 ... [详细]
  • 本文总结了淘淘商城项目的功能和架构,并介绍了传统架构中遇到的session共享问题及解决方法。淘淘商城是一个综合性的B2C平台,类似京东商城、天猫商城,会员可以在商城浏览商品、下订单,管理员、运营可以在平台后台管理系统中管理商品、订单、会员等。商城的架构包括后台管理系统、前台系统、会员系统、订单系统、搜索系统和单点登录系统。在传统架构中,可以采用tomcat集群解决并发量高的问题,但由于session共享的限制,集群数量有限。本文探讨了如何解决session共享的问题。 ... [详细]
  • 一句话解决高并发的核心原则
    本文介绍了解决高并发的核心原则,即将用户访问请求尽量往前推,避免访问CDN、静态服务器、动态服务器、数据库和存储,从而实现高性能、高并发、高可扩展的网站架构。同时提到了Google的成功案例,以及适用于千万级别PV站和亿级PV网站的架构层次。 ... [详细]
  • 如何使用代理服务器进行网页抓取?
    本文介绍了如何使用代理服务器进行网页抓取,并探讨了数据驱动对竞争优势的重要性。通过网页抓取,企业可以快速获取并分析大量与需求相关的数据,从而制定营销战略。同时,网页抓取还可以帮助电子商务公司在竞争对手的网站上下载数百页的有用数据,提高销售增长和毛利率。 ... [详细]
  • 本文介绍了Sencha Touch的学习使用心得,主要包括搭建项目框架的过程。作者强调了使用MVC模式的重要性,并提供了一个干净的引用示例。文章还介绍了Index.html页面的作用,以及如何通过链接样式表来改变全局风格。 ... [详细]
  • 1.Listener是Servlet的监听器,它可以监听客户端的请求、服务端的操作等。通过监听器,可以自动激发一些操作,比如监听在线的用户的数量。当增加一个HttpSession时 ... [详细]
author-avatar
手机用户2702936061
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有