haproxy 动静分离负载均衡、​stats页面实现​。

实验环境:一台主机提供haproxy、nfs、mariadb,后端2台apache部署wordpress

实验目的:haproxy使得动静分离、以及开启stats页面。

haproxy简单介绍

负载均衡的解决方案,支持4、7层,特点是单进程模型(可配置为多进程模型)单进程能支持非常大的并发链接数量(相比较其他软件)。

到今天,马哥课程中的负载均衡方案(lvs、nginx、proxy)已经讲完了,就来简单介绍下自己理解的区别吧,作为一个新手,说错了不要打我啊haproxy 动静分离负载均衡、​stats页面实现​。(相信很多同学和我一样也有这种纠结)

lvs如果在http反代的环境中由于本身工作在四层,无法再分配策略上进行详细调整(最直观的就是动静分离),后端服务器的健康状态检测(虽然也可以利用ldirector和keepalived弥补,但自身缺陷),只能单存的把自定义的ip或端口,按照规则分发至后端主机,因此他可以实现所有应用的负载均衡。(haproxy和nginx1.10的版本已经稳定支持4层负载均衡,但因为本身工作在内核中,我们应该相信在较高并发下,lvs的能力依然比haproxy和nginx强大),另外对网络环境的依赖较大。

haproxy和nginx两样及其相似,自己也曾在网上看了很多篇关于他们两差别的,但有几点也许是因为年代关系还是什么,指出一下错误:

1、haproxy弥补了session保持,nginx同样也支持session保持。

2、haproxy支持四层反代,nginx同样支持四层反代。

3、nginx不支持url做健康状态检测, 其实是支持。

4、haproxy不支持虚拟主机,没搞懂网上指的一个负载均衡要虚拟主机拿来干嘛,我猜也许想用自身做sorryserver,通过errorfile是能做成sorryserver的。


自己认为他们的区别,nginx可以做静态资源的缓存,而haproxy有一个状态的查询页,可以直观的看到后端服务器状况。


说了那么多,还是来做今天的实验吧,haproxy已经被收录在了base源中,插入光盘自己yum安装即可,安装完后配置文件/etc/haproxy/haproxy.cfg

haproxy 动静分离负载均衡、​stats页面实现​。

haproxy 动静分离负载均衡、​stats页面实现​。

给我们的示例配置文件中,一共分为了4端,分别是全局配置段,和proxy配置段,在全局配置中主要定义的是日志、启动haproxy的身份,启动模式、最大并发链接…等等

在proxy配置段又分为了default、frontend、backend三段,在一些指令上如果后两段没有特殊定义就会继承默认配置段,不是所有配置段都可以使用相同的指令,详情查看官方文档

http://cbonte.github.io/haproxy-dconv/1.6/configuration.html#4

haproxy 动静分离负载均衡、​stats页面实现​。

这里是我开启的状态页分别是:

bind:可以理解为监听的ip和端口

stats enable:开启stats页

stats uri:访问stats的url

stats realm:需要认证时,认证框里面的提示信息

stats auth:认证的账号和密码 (账号:密码)

stats refresh:打开页面后每秒刷新间隔

stats admin:是否开启管理功能

haproxy 动静分离负载均衡、​stats页面实现​。

整体页面就是这样了~

接着我们就来配我们的动静分离吧~

haproxy 动静分离负载均衡、​stats页面实现​。

刚刚经过测试,发现不管是discuz还是wordpress,都不能直接尝试动静分离,至少在基于nfs共享上,实现不了,以哪个IP去创建的数据库,静态的图片就会在自动跳转到创建的IP上去加载。。。我也是醉了就换个简单的方法测试吧 以php结尾的发送给一个主机,其他未定义的发送给另一个主机。

然后在web的根目录上分别创建了index.html 和105上创建了index.php 

haproxy 动静分离负载均衡、​stats页面实现​。

haproxy 动静分离负载均衡、​stats页面实现​。

105的主机上创建的index.html是111,106上创建的是222,接着我们就可以打开网页测试了!!!!

haproxy 动静分离负载均衡、​stats页面实现​。haproxy 动静分离负载均衡、​stats页面实现​。

可以看到请求index.html确实是转发到了106上,请求index.php被转发到了105上!


原创文章,作者:N24_Ghost,如若转载,请注明出处:http://www.178linux.com/69275

(0)
N24_GhostN24_Ghost
上一篇 2017-02-18 14:14
下一篇 2017-02-18 17:17

相关推荐

  • phpMyAdmin安装部署

    phpMyAdmin安装部署 phpMyAdmin 是一个用PHP编写的软件工具,可以通过web方式控制和操作MySQL数据库。通过phpMyAdmin 可以完全对数据库进行操作,例如建立、复制和删除数据等等。如果使用合适的工具,MySQL数据库的管理就会变得相当简单。应用 MySQL 命令行方式需要对 MySQL 知识非常熟悉,对SQL语言也是同样的道理。…

    2017-06-13
  • 实现真实的机柜模拟图[原创]

    一般能反映机房设备位置、结构我们都喜欢通过网络拓扑图来展现,但个人感觉还不够直观、明了的表现出自己想要的结果(自己太挑剔了,呵呵)。因此写一个生成真实机柜模拟图平台,实现与真实服务器外观、服务状态、空闲位置等信息。在线效果图http://blog.liuts.com/idc/系统截图1、平台显示某一排截图2、平台显示某台服务器详细信息截图3、状态说明2U服务…

    Linux干货 2015-03-27
  • LVS产生背景、原理及LVS-DR应用实例(二)

    六、LVS-DR应用实例          (一)基本构建思路:           Director: 通过Director实现访问调度到RS1,RS2,实现负载均衡,RS3负责动态分离。…

    Linux干货 2016-10-29
  • awk学习笔记

        awk是一种模式扫描和处理工具,相对于grep的查找,sed的编辑,它在对数据进行分析生成报表时显得尤为强大。awk通过逐行遍历一个或多个文件的方式,查找模式匹配到的行,而后以指定的分隔符(缺省为空格)进行切片,然后针对切片数据进行处理和分析。事实上,gawk有自己的语言,其本身就相当于一个解释器,允许用户创建…

    Linux干货 2015-08-04
  • 数据结构知识点(list,tuple,冒泡法)

    分类 数值型 int、float、complex、bool 序列对象 字符串str、列表list、tuple 键值对 集合set、字典dict 数值型 complex:有实数和虚数部分组成 float:有整数和小数组成。只有双精度 类型转换 int(X) 返回一个整数 float(x) 返回一个浮点数 complex(x)、complex(x,y) 返回一个…

    2017-09-25
  • Awk 高级应用

                              Awk 简介   Awk 是一种变成语言,用于在Linux/UNIX下对文本和数据进行扫描与处理,数据可以来自标准输入,文件 ,管道。Awk分别代表其作者的姓…

    2017-07-17

评论列表(1条)

  • luoweiro
    luoweiro 2017-02-22 22:23

    作业完成的不错,对于多款负载均衡软件有对比,这部分很赞。