图文解说: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,结构如下图:
?
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也安装在此目录。
??
DOS环境启动
?
若果想停止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环境下图画面成功示例:
???其次验证tomcat,启动两个tomcat,不出现端口冲突即为成功(tomcat依赖的java等搞“挨踢”的就废话不说了);
?
??? 最后验证配置负载均衡设置,http://localhost/或http://localhost/index.jsp。我修改了index.jsp页面,增加日志输出信息,便于观察。注意:左上角小猫头上的:access tomcat2、access tomcat1。说明访问了不同的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:安装结果截图如下:
?
编译安装正确结束,按照上述window下方法检查默认配置,然后在默认配置下启动nginx,访问http://127.0.0.1,如下图说明成功
?
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文件