首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

图文解说:Nginx+tomcat配备集群负载均衡

2012-09-28 
图文解说:Nginx+tomcat配置集群负载均衡??作者:niumd? ? Blog:http://ari.iteye.com? 转载请注明出处,谢谢

图文解说:Nginx+tomcat配置集群负载均衡

??作者:niumd?

? Blog:http://ari.iteye.com

? 转载请注明出处,谢谢


??? 开发的应用采用F5负载均衡交换机,F5将请求转发给5台hp unix服务器,每台服务器有多个webserver实例,对外提供web服务和socket等接口服务。之初,曾有个小小的疑问为何不采用开源的apache、Nginx软件负载,F5设备动辄几十万,价格昂贵?自己一个比较幼稚的问题,后续明白:F5是操作于IOS网络模型的传输层,Nginx、apache是基于http反向代理方式,位于ISO模型的第七层应用层。直白些就是TCP UDP 和http协议的区别,Nginx不能为基于TCP协议的应用提供负载均衡。


????? 了解了二者之间的区别于应用场景,对Nginx产生浓厚的兴趣,阅读张宴的<实战Nginx>(这个85年的小伙子年轻有为羡慕+妒忌),搞明白了大致原理和配置,Ubuntu10.10,window下对Nginx+tomcat负载均衡做了配置尝试,将全部请求转发到tomcat,并未做静态,动态分开,图片防盗链等配置。
Nginx 介绍


???? Nginx (发音同 engine x)是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行。? 其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页伺服器中表现较好.目前中国大陆使用nginx网站用户有:新浪、网易、 腾讯,另外知名的微网志Plurk也使用nginx。


??? 上面的全是Nginx介绍基本上是废话,下面转入正题,图文结合展示基本配置,首先是window环境、其次是Ubuntu环境(Vbox虚拟)。本文主要基于Nginx下配置两台tomcat,结构如下图:
图文解说:Nginx+tomcat配备集群负载均衡
?

Window xp环境:Nginx+Tomcat6

1、下载地址

?????? http://nginx.org/en/download.html,这里我们推荐下载稳定版(stable versions),本文采用nginx-0.8.20。


2、目录结构


????? Nginx-

?????????????? |_? conf?? 配置目录

?????????????? |_? contrib

?????????????? |_? docs 文档目录

?????????????? |_? logs? 日志目录

?????????????? |_? temp 临时文件目录

?????????????? |_? html 静态页面目录

?????????????? |_? nginx.exe 主程序


????? window下安装Nginx极其简单,解压缩到一个无空格的英文目录即可(个人习惯,担心中文出问题),双击nginx启动,这里我安装到:D:\server目录,下面涉及到的tomcat也安装在此目录。

??
图文解说:Nginx+tomcat配备集群负载均衡

DOS环境启动

?
图文解说:Nginx+tomcat配备集群负载均衡

若果想停止nginx,dos环境运行命令:nginx -s stop


3、nginx.conf配置


?? Nginx配置文件默认在conf目录,主要配置文件为nginx.conf,我们安装在D:\server\nginx-0.8.20、默认主配置文件为D:\server\nginx-0.8.20\nginx.conf。下面是nginx作为前端反向代理服务器的配置。

?
?? 代理设置如下:

?
?? 第二处端口修改:

?

?? 第三处端口修改:

?

?? Engine元素增加jvmRoute属性:

?
??? 两个tomcat的端口别重复,保证能启动起来,另一个tomcat配置希捷省略,监听端口为18080,附件中我们将上传所有的配置信息。


5、验证配置与测试负载均衡


??? 首先测试nginx配置是否正确,测试命令:nginx -t? (默认验证:conf\nginx.conf),也可以指定配置文件路径。

?此例nginx安装目录:D:\server\nginx-0.8.20,dos环境下图画面成功示例:
图文解说:Nginx+tomcat配备集群负载均衡

???其次验证tomcat,启动两个tomcat,不出现端口冲突即为成功(tomcat依赖的java等搞“挨踢”的就废话不说了);

?
图文解说:Nginx+tomcat配备集群负载均衡

??? 最后验证配置负载均衡设置,http://localhost/或http://localhost/index.jsp。我修改了index.jsp页面,增加日志输出信息,便于观察。注意:左上角小猫头上的:access tomcat2、access tomcat1。说明访问了不同的tomcat。

?
图文解说:Nginx+tomcat配备集群负载均衡
?
???? 至此window下nginx+tomcat负载均衡配置结束,关于tomcat Session的问题通常是采用memcached,或者采用nginx_upstream_jvm_route ,他是一个 Nginx 的扩展模块,用来实现基于 Cookie 的 Session Sticky 的功能。如果tomcat过多不建议session同步,server间相互同步session很耗资源,高并发环境容易引起Session风暴。请根据自己应用情况合理采纳session解决方案。

?

?

?作者:niumd?

? Blog:http://ari.iteye.com

?

?

Ubuntu10.10环境:Nginx+Tomcat6


我们下面简单说下ubuntu10.10下如何安装配置,主要以图片为主,简单解释。

1、下载Nginx

????? 地址:http://nginx.org/en/download.html,linux版本:nginx-0.8.20.tar.。解压缩命令:


tar -zxvf nginx-0.8.20.tar.gz


2、编译安装Nginx


???? Nginx依赖一些其他PCRE、openssl(依赖libssl-dev),本人笔记本Ubuntu环境已经安装PCRE,仅需安装依赖的openssl,下面我们简单说下如何安装PCRE和openssl等


???? PCRE下载地址:ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/

?


?
?依赖的软件包安装完毕,下面来编译Nginx:

安装结果截图如下:

?
图文解说:Nginx+tomcat配备集群负载均衡

编译安装正确结束,按照上述window下方法检查默认配置,然后在默认配置下启动nginx,访问http://127.0.0.1,如下图说明成功

?
图文解说:Nginx+tomcat配备集群负载均衡

Nginx配置成功后我们对window下nginx.conf少做修改,如下:

??对于上面关于ubuntu下Nginx配置和window下基本相同,区别在使用的IO网络模型,linux下建议使用epoll,另外就是运行所用的用户和组;

?

3、配置tomcat

??? 请参考window下配置,完全相同。

4、启动停止nginx

??? ubuntu下启动nginx与window稍有不同,大致启动停止方法如下。

?

注意:在启动时linux提示一句警告【warn】……,是因为我们设置的 #允许最大连接数 worker_connections? 2048,超过linux默认1024的限制。

?????? 停止:kill -信号类型 pid

?????? nginx/logs目录下有个nginx。pid的文件,此文件记录了每次运行的pid,也可以通过ps命令查询。

信号类型如下:

?

信号控制信号类型描述RERM.INT快速关闭HUP平滑重启,加载配置USR1重新加载日志USER2平滑升级执行程序WINCH从容关闭工作进程QUIT从容关闭

?

参考资料:

http://www.oschina.net/bbs/thread/9301

oschina.net 生产配置,此网站采用java语言,nginx,tomcat服务器。

http://nginx.org/

张宴:<<实战Nginx>>

?

?

1 楼 bluemaple 2011-09-29   为什么我按照你的这种方法在Linux下面没有配置成功呢?在/usr/local/nginx/sbin/下面并没有nginx这个文件呢? 2 楼 niumd 2011-09-30   bluemaple 写道为什么我按照你的这种方法在Linux下面没有配置成功呢?在/usr/local/nginx/sbin/下面并没有nginx这个文件呢?
是否正确编译? 3 楼 liujialong0404 2012-04-04   怎么修改了index.jsp页面,增加日志输出信息。 4 楼 niumd 2012-05-08   liujialong0404 写道怎么修改了index.jsp页面,增加日志输出信息。
修改下webapps\ROOT\index文件,随便添加点东西,请求被转发到不同的tomca,会展示此tomcat对应的index文件

热点排行