Nginx+Resin实现高性能JAVA平台搭建

现在流行的JavaEE容器有很多:Tomcat、Resin、JBoss、Glassfish等,我们常用的主要是前三种,那这个java容器性能方面到底谁更稳定,并发能力更强呢?那当属resin了,resin官方发布了最新版本4.0.33版,号称并发超越apache,不仅支持jsp语言,还能支持php。

我们以前大多用过tomcat,知道tomcat如果要在一台机器配置多个服务,只需要拷贝不同的配置文件,然后配置不同的端口就ok,相比较而言,resin要想在一台机器配置多个服务,就比较麻烦了,那今天我们一起来研究一下。

一、系统环境

  1. 系统环境:CentOS6.0x86_64
  2. Nginx版本:Nginx-1.2.6
  3. Resin版本:Resin-4.0.33
  4. JDK版本: JDK-1.6.0_18

二、Nginx安装

  1. #首先下载需要安装的软件:【JDK可以去java官网下载并安装】
  2. wget http://nginx.org/download/nginx-1.2.6.tar.gz
  3. wget http://www.caucho.com/download/resin-4.0.33.tar.gz
  4. tar zxvf nginx-1.2.6.tar.gz
  5. cd nginx-1.2.6/
  6. ./configure--user=www --group=www --add-module=../ngx_cache_purge-1.4
  7. \--prefix=/usr/local/nginx\--with-http_stub_status_module --with-http_ssl_module
  8. make && make install

三、Resin安装

  1. tar –xzvf resin-4.0.33.tar.gz
  2. cd resin-4.0.33 &&./configure --prefix=/usr/local/resin
  3. \--with-resin-log=/data/logs/resin/ --with-java-home=/usr/java/jdk1.6.0_18/
  4. make &&make install

四、配置Resin

  1. #cd /usr/local/resin/conf/下
  2. #添加如下代码,在本机配置两个实例端口为8080、8081
  3. <clusterid="app1">
  4. <!-- define the servers in the cluster -->
  5. <server-multiid-prefix="app1"address-list="${app1_servers}"port="6800"/>
  6. <!-- the default host, matching any host name -->
  7. <hostid=""root-directory=".">
  8. <web-appid="/"root-directory="/var/www/html/app1"/>
  9. </host>
  10. </cluster>
  11. <clusterid="app2">
  12. <!-- define the servers in the cluster -->
  13. <server-multiid-prefix="app2"address-list="${app2_servers}"port="6801"/>
  14. <!-- the default host, matching any host name -->
  15. <hostid=""root-directory=".">
  16. <web-appid="/"root-directory="/var/www/html/app2"/>
  17. </host>
  18. </cluster>

修改当前目录vi  resin.properties 修改如下内容:

  1. # app-tier Triad servers: app-0 app-1 app-2
  2. app1_servers : 127.0.0.1:6800
  3. app2_servers : 127.0.0.1:6801
  4. # Use overrides for individual server control, for example: app-0.http : 8081
  5. app1.http : 8080
  6. app2.http : 8081

配置不同的端口,然后启动resin服务:

  1. /usr/local/resin/bin/resinctl start 即可
  2. 然后查看resin 端口 netstat –tnl 我们会看到8080、8081端口

五、配置Nginx

随着Nginx高性能Web服务器大量被使用,目前Nginx最新稳定版为1.2.6,张宴兄在实际应用中大量使用Nginx,并分享Nginx高性能Web服务器知识,使得Nginx在国内也是飞速的发展。那今天咱们再来温习一下Nginx 动静分离知识,这里仅供参考。

一、实践环境:

  1. 系统版本:CentOS6.0 X86_64
  2. Nginx版本:Nginx-1.2.6
  3. Tomcat版本:Tomcat-6.0.18

二、Nginx安装:

实际环境中安装Nginx,首先需要安装pcre库,然后再安装Nginx:

  1. #安装pcre支持rewrite库,也可以安装源码,注*安装源码时,指定pcre路径为解压源码的路径,而不是编译后的路径,否则会报错。
  2. yum install pcre-devel pcre -y
  3. #下载Nginx源码包
  4. cd /usr/src ;wget -c http://nginx.org/download/nginx-1.2.6.tar.gz
  5. #解压Nginx源码包
  6. tar -xzf nginx-1.2.6.tar.gz
  7. #进入解压目录,然后sed修改Nginx版本信息为TDTWS
  8. cd nginx-1.2.6 ; sed -i -e ‘s/1.2.6//g‘ -e ‘s/nginx\//TDTWS/g‘ -e ‘s/"NGINX"/"TDTWS"/g‘ src/core/nginx.
  9. #预编译Nginx
  10. ./configure --user=www --group=www --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module
  11. #.configure预编译成功后,执行make命令进行编译
  12. make
  13. #make执行成功后,执行make install 正式安装
  14. make install
  15. #自此Nginx安装完毕!!!

三、配置Nginx:

这里鉴于我的51CTO博客已经有Tomcat安装和配置了,这里忽略,只配置Nginx。

  1. #进入Nginx应用目录
  2. cd /usr/local/nginx/conf
  3. #备份原nginx.conf文件
  4. mv nginx.conf nginx.bak

创建 vi nginx.conf ,并写入如下内容:

  1. user www www;
  2. worker_processes 8;
  3. worker_cpu_affinity 00000001 00000010 00000100 00001000 00010000 00100000 01000000 10000000;
  4. pid /usr/local/nginx/nginx.pid;
  5. worker_rlimit_nofile 102400;
  6. events
  7. {
  8. use epoll;
  9. worker_connections 102400;
  10. }
  11. http
  12. {
  13. include mime.types;
  14. default_type application/octet-stream;
  15. fastcgi_intercept_errors on;
  16. charset utf-8;
  17. server_names_hash_bucket_size 128;
  18. client_header_buffer_size 4k;
  19. large_client_header_buffers 4 32k;
  20. client_max_body_size 300m;
  21. sendfile on;
  22. tcp_nopush on;
  23. keepalive_timeout 60;
  24. tcp_nodelay on;
  25. client_body_buffer_size 512k;
  26. proxy_connect_timeout 5;
  27. proxy_read_timeout 60;
  28. proxy_send_timeout 5;
  29. proxy_buffer_size 16k;
  30. proxy_buffers 4 64k;
  31. proxy_busy_buffers_size 128k;
  32. proxy_temp_file_write_size 128k;
  33. gzip on;
  34. gzip_min_length 1k;
  35. gzip_buffers 4 16k;
  36. gzip_http_version 1.1;
  37. gzip_comp_level 2;
  38. gzip_types text/plain application/x-javascript text/css application/xml;
  39. gzip_vary on;
  40. ###2012-12-19 change nginx logs
  41. log_format main ‘$http_x_forwarded_for - $remote_user [$time_local] "$request" ‘
  42. ‘$status $body_bytes_sent "$http_referer" ‘
  43. ‘"$http_user_agent" $request_time $remote_addr‘;
  44. #这里为后端服务器wugk应用集群配置,根据后端实际情况修改即可,tdt_wugk为负载均衡名称,可以任意指定
  45. #但必须跟vhosts.conf虚拟主机的pass段一致,否则不能转发后端的请求。
  46. upstream tdt_wugk {
  47. server 10.10.141.30:8080 weight=1max_fails=2fail_timeout=30s;
  48. server 10.10.141.30:8081 weight=1max_fails=2fail_timeout=30s;
  49. server 10.10.141.31:8080 weight=1max_fails=2fail_timeout=30s;
  50. server 10.10.141.31:8081 weight=1max_fails=2fail_timeout=30s;
  51. server 10.10.141.32:8080 weight=1max_fails=2fail_timeout=30s;
  52. server 10.10.141.32:8081 weight=1max_fails=2fail_timeout=30s;
  53. }
  54. #这里为后端APP应用负载均衡配置,根据后端实际情况修改即可。tdt_app为负载均衡名称,可以任意指定
  55. upstream tdt_app {
  56. server 10.10.141.40:8080 weight=1max_fails=2fail_timeout=30s;
  57. server 10.10.141.40:8081 weight=1max_fails=2fail_timeout=30s;
  58. server 10.10.141.41:8080 weight=1max_fails=2fail_timeout=30s;
  59. server 10.10.141.41:8081 weight=1max_fails=2fail_timeout=30s;
  60. server 10.10.141.42:8080 weight=1max_fails=2fail_timeout=30s;
  61. server 10.10.141.42:8081 weight=1max_fails=2fail_timeout=30s;
  62. }
  63. #include引用vhosts.conf,该文件主要用于配置Nginx 虚拟主机
  64. include vhosts.conf;
  65. }

如上nginx.conf配置完毕,继续配置nginx虚拟主机,继续在当前目录创建vhosts.conf

vi vhosts.conf 内容如下:

  1. ####www.wuguangke.cn
  2. server
  3. {
  4. listen 80;
  5. server_name www.wuguangke.cn;
  6. index index.html index.htm;
  7. #配置发布目录为/data/www/wugk
  8. root /data/www/wugk;
  9. location /
  10. {
  11. proxy_next_upstream http_502 http_504 error timeout invalid_header;
  12. proxy_set_header Host $host;
  13. proxy_set_header X-Real-IP $remote_addr;
  14. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  15. proxy_pass http://tdt_wugk;
  16. expires 3d;
  17. }
  18. #动态页面交给http://tdt_wugk,也即我们之前在nginx.conf定义的upstream tdt_wugk 均衡
  19. location ~ .*\.(php|jsp|cgi)?$
  20. {
  21. proxy_set_header Host $host;
  22. proxy_set_header X-Real-IP $remote_addr;
  23. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  24. proxy_pass http://tdt_wugk;
  25. }
  26. #配置Nginx动静分离,定义的静态页面直接从Nginx发布目录读取。
  27. location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$
  28. {
  29. root /data/www/wugk;
  30. #expires定义用户浏览器缓存的时间为3天,如果静态页面不常更新,可以设置更长,这样可以节省带宽和缓解服务器的压力
  31. expires 3d;
  32. }
  33. #定义Nginx输出日志的路径
  34. access_log /data/logs/nginx_wugk/access.log main;
  35. error_log /data/logs/nginx_wugk/error.log crit;
  36. }
  37. ##########chinaapp.sinaapp.com 2012-12-19
  38. server
  39. {
  40. listen 80;
  41. server_name chinaapp.sinaapp.com;
  42. index index.html index.htm;
  43. root /data/www;
  44. location /
  45. {
  46. proxy_next_upstream http_502 http_504 error timeout invalid_header;
  47. proxy_set_header Host $host;
  48. proxy_set_header X-Real-IP $remote_addr;
  49. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  50. proxy_pass http://tdt_app;
  51. expires 3d;
  52. }
  53. location ~ .*\.(php|jsp|cgi)?$
  54. {
  55. proxy_set_header Host $host;
  56. proxy_set_header X-Real-IP $remote_addr;
  57. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  58. proxy_pass http://tdt_app;
  59. }
  60. location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$
  61. {
  62. root /data/www/app;
  63. expires 3d;
  64. }
  65. access_log /data/logs/nginx_app/access.log main;
  66. error_log /data/logs/nginx_app/error.log crit;
  67. }

六、部署测试:

后端配置好Tomcat服务,并启动,发布的程序需同步到Nginx的/data/www对应的目录,因为配置动静分离后,用户请求你定义的静态页面,默认会去nginx的发布目录请求,而不会到后端请求,所以这时候你要保证后端跟前端的程序保持一致,可以使用Rsync做服务端自动同步。

  1. #检查Nginx配置文件是否配置正确,提示Ok and successful表示正确,如下:
  2. [[email protected] ~]# /usr/local/nginx/sbin/nginx -t
  3. nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
  4. nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
  5. #启动Nginx服务
  6. /usr/local/nginx/sbin/nginx
  7. #查看Nginx进程是否启动
  8. ps -ef |grep nginx

本文只是一个简单的实际案例,里面的配置和参数这里没有做过多的说明,后期会继续更新。

时间: 2025-01-12 03:27:13

Nginx+Resin实现高性能JAVA平台搭建的相关文章

Nginx结合memcached实现LNMMP平台搭建

Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器.由俄罗斯的程序设计师Igor Sysoev所开发,其特点是占有内存少,并发能力强,它的主要功用中还有一项是作为缓存服务器,在某些场景下,如后端的服务器是数据库服务器时,Nginx与其他就需要配合其他专门用于缓存数据库中数据的软件结合起来可以更好的完成缓存数据的功能,比如memcached,此时的Nginx作为代理服务器使用. 实验:完成LNNMP平台

基于CentOS 5.4搭建nginx+php+spawn-fcgi+mysql高性能php平台

一.安装准备 1.1平台环境: CentOS 5.4 x86_64 GNU/Linux nginx-0.8.21 php-5.2.9 spawn-fcgi-1.6.3 mysql-5.1.34 .2系统安装及分区:1.2.1操作系统安装:         安装过程中选择最少的包,采用文本模式安装,不安装图形.1.2.3系统分区:         /boot  100M    (大约100左右)          SWAP  4G      物理内存的2倍(如果你的物理内存大于4G,分配4G即可)

LNMP平台搭建---Nginx安装篇

在上一篇博文<LNMP平台搭建---Linux系统安装篇>中,我们安装了CentOS版本的Linux操作系统,现在,我们来安装一个Web服务器,大标题写着LNMP,其中的N就是Nginx,开始安装前,先大致了解一下Nginx这个后起之秀的Web服务器吧. Nginx第一次正式发布是在2004年10月,它是一款免费开源的高性能HTTP服务器和反向代理服务器,并且可作为邮件服务器,在它的官网:http://www.nginx.org 可以了解更多,当前最新的稳定版本是1.10.2,12年来,在全世

Linux中用Nginx和FTP搭建WS幸运飞艇平台搭建图片服务器

一.需要的组件WS幸运飞艇平台搭建论坛:haozbbs.com Q1446595067 图片服务器两个服务:Nginx(图片访问): 1.http服务:可以使用nginx做静态资源服务器.也可以使用apache.推荐使用nginx,效率更高. 2.反向代理 实现 负载均衡ftp服务(图片上传): 使用linux做服务器,在linux中有个ftp组件vsftpd.二.Nginx服务器搭建1.安装Nginx 要求安装vmware虚拟机. Linux:CentOS6.4(32) Nginx:1.8.0

学习java随笔第一篇:搭建java平台(java se)

电脑系统:windows8 在这里介绍一下java平台的3个版本: Java SE--Java Standard Edition,Java的标准版,主要用于桌面级的应用和数据库开发. Java EE--Java Enterprise Edition,Java的企业版,提供了企业级开发的各种技术,主要用于企业级开发. Java ME--Java Micro Edition,主要用于潜入式和移动式的开发,最常用的就是手机应用软件开发. 这里我们用的是java se 第一步:下载Java SE,下载地

超详细java中 大发彩_票平台搭建 的ClassLoader详解

ClassLoader翻译过来就是类加载器,普通的java开发者其实用到的不多,但对于某些框架开发者来说却非常常见.理解ClassLoader的加载机制,也有利于我们编写出更高效的代码.ClassLoader的具体作用就是将class文件加载到jvm虚拟机中去,程序就可以正确运行了.但是,jvm启动的时候,并不会一次性加载所有的class文件,而是根据需要去动态加载.想想也是的,一次性加载那么多jar包那么多class,那内存不崩溃.本文的目的也是学习ClassLoader这种加载机制. 大发彩

开源 java OA现金盘平台搭建2.8 会员管理

从左侧管理OA现金盘平台搭建Q1446595067菜单点击会员管理进入. 添加会员 在会员列表下方点击"添加"按钮. 填写相关属性后点击"保存"按钮即可. 编辑会员 选择需要编辑的会员,然后点击"编辑"按钮. 注意:同时只能编辑一个会员. 填写相关属性后点击"保存"按钮即可. 提示:如果需要修改密码,请勾选"我要修改密码",然后输入新的密码即可. 会员启用 选择需要启用的会员,然后点击"启用&qu

开源日志分析系统ELK平台搭建部署

开源日志分析系统ELK平台搭建部署 一.前言 日志主要包括系统日志.应用程序日志和安全日志.系统运维和开发人员可以通过日志了解服务器软硬件信息.检查配置过程中的错误及错误发生的原因.经常分析日志可以了解服务器的负荷,性能安全性,从而及时采取措施纠正错误. 通常,日志被分散的储存不同的设备上.如果你管理数十上百台服务器,你还在使用依次登录每台机器的传统方法查阅日志.这样是不是感觉很繁琐和效率低下.当务之急我们使用集中化的日志管理,例如:开源的syslog,将所有服务器上的日志收集汇总. 集中化管理

FILEBEAT+ELK日志收集平台搭建流程

filebeat+elk日志收集平台搭建流程 1.         整体简介: 模式:单机 平台:Linux - centos - 7 ELK:elasticsearch.logstash.kibana三款开源软件的集合. FILEBEAT:代替logstash的采集功能,轻量.耗用小. 目前收集的有nginx日志.java日志[单行|多行]. 都是通过在客户端的生成日志配置文件中定义好初步json格式,然后利用filebeat采集到logstash,存储到elasticsearch,最后通过k