配置Nginx+keepalived高可用负载均衡服务器

1.Nginx与lvs负载均衡软件的比较(原文地址:http://www.ha97.com/5646.html)

目前关于网站架构一般比较合理流行的架构方案:Web前端采用Nginx/HAProxy+Keepalived作负载均衡器;后端采用MySQL数据库一主多从和读写分离,采用LVS+Keepalived的架构。当然要根据项目具体需求制定方案。
下面说说各自的特点和适用场合。

(1)Nginx的特点

①工作在网络的7层之上,可以针对http应用做一些分流的策略,比如针对域名、目录结构,它的正则规则比HAProxy更为强大和灵活,这也是它目前广泛流行的主要原因之一,Nginx单凭这点可利用的场合就远多于LVS了。
②Nginx对网络稳定性的依赖非常小,理论上能ping通就就能进行负载功能,这个也是它的优势之一;相反LVS对网络稳定性依赖比较大,这点本人深有体会;
③Nginx安装和配置比较简单,测试起来比较方便,它基本能把错误用日志打印出来。LVS的配置、测试就要花比较长的时间了,LVS对网络依赖比较大。
④可以承担高负载压力且稳定,在硬件不差的情况下一般能支撑几万次的并发量,负载度比LVS相对小些。
⑤Nginx可以通过端口检测到服务器内部的故障,比如根据服务器处理网页返回的状态码、超时等等,并且会把返回错误的请求重新提交到另一个节点,不过其中缺点就是不支持url来检测。比如用户正在上传一个文件,而处理该上传的节点刚好在上传过程中出现故障,Nginx会把上传切到另一台服务器重新处理,而LVS就直接断掉了,如果是上传一个很大的文件或者很重要的文件的话,用户可能会因此而不满。
⑥Nginx不仅仅是一款优秀的负载均衡器/反向代理软件,它同时也是功能强大的Web应用服务器。LNMP也是近几年非常流行的web架构,在高流量的环境中稳定性也很好。
⑦Nginx现在作为Web反向加速缓存越来越成熟了,速度比传统的Squid服务器更快,可以考虑用其作为反向代理加速器。
⑧Nginx可作为中层反向代理使用,这一层面Nginx基本上无对手,唯一可以对比Nginx的就只有lighttpd了,不过lighttpd目前还没有做到Nginx完全的功能,配置也不那么清晰易读,社区资料也远远没Nginx活跃。
⑨Nginx也可作为静态网页和图片服务器,这方面的性能也无对手。还有Nginx社区非常活跃,第三方模块也很多。

(2)lvs的特点

①抗负载能力强、是工作在网络4层之上仅作分发之用,没有流量的产生,这个特点也决定了它在负载均衡软件里的性能最强的,对内存和cpu资源消耗比较低。
②配置性比较低,这是一个缺点也是一个优点,因为没有可太多配置的东西,所以并不需要太多接触,大大减少了人为出错的几率。
③工作稳定,因为其本身抗负载能力很强,自身有完整的双机热备方案,如LVS+Keepalived,不过我们在项目实施中用得最多的还是LVS/DR+Keepalived。
④无流量,LVS只分发请求,而流量并不从它本身出去,这点保证了均衡器IO的性能不会收到大流量的影响。
⑤应用范围比较广,因为LVS工作在4层,所以它几乎可以对所有应用做负载均衡,包括http、数据库、在线聊天室等等。

2.架构设计及lnmp服务器搭建

(1)架构设计图:

配置Nginx+keepalived高可用负载均衡服务器

(2)基础环境配置及lnmp服务器搭建已在“lvs+keepalived高可用负载均衡”文章中说明,不再赘述

3.Nginx配置高可用(LVS1,LVS2)

(1)使用yum方式安装nginx

(2)编辑/etc/nginx/nginx.conf文件,添加反向代理地址,修改如下:

配置Nginx+keepalived高可用负载均衡服务器

(2)修改/etc/nginx/conf.d/default.conf 文件,开启反向代理

配置Nginx+keepalived高可用负载均衡服务器

(4)启动nginx服务,在浏览器中访问192.168.183.11/index.php,及192.168.183.12/index.php,若可以轮流访问web1,web2主页,则负载均衡配置成功。

配置Nginx+keepalived高可用负载均衡服务器配置Nginx+keepalived高可用负载均衡服务器配置Nginx+keepalived高可用负载均衡服务器配置Nginx+keepalived高可用负载均衡服务器

4.配置keepalived高可用

(1)使用yum方式安装keepalived

(2)LVS1修改/etc/keepalived/keepalived.conf 文件

配置Nginx+keepalived高可用负载均衡服务器

(3)LVS2修改/etc/keepalived/keepalived.conf 文件

配置Nginx+keepalived高可用负载均衡服务器

(4)启动keepalived服务,在浏览器中访问192.168.183.10/index.php,轮流出现web1,web2主页,此时lvs1工作,当lvs1出现故障,仍可轮流访问web1,web2主页面,此时lvs2工作。高可用配置成功。

配置Nginx+keepalived高可用负载均衡服务器

此时,nginx+keepalived高可用负载均衡配置成功