- 浏览: 204847 次
- 性别:
- 来自: 深圳
文章分类
最新评论
-
jongde1:
Axure太难学了,分享mockplus工具,有兴趣可以去了解 ...
Axure RP 原型设计工具 -
di1984HIT:
这里面提到了好几种解决办法。
Spring AOP对日志记录、Exception日志记录 -
di1984HIT:
学习一下。
spring struts2 零配置 -
di1984HIT:
不错,不错啊
Struts2防止表单重复提交 -
di1984HIT:
kettle怎么样啊。
Kettle初探
1.搭建Nginx+Java环境
《高性能Linux服务器构建实战:运维监控、性能调优与集群应用》第1章轻量级HTTP服务器Nginx,本章主要介绍了对高性能HTTP服务器Nginx的安装、配置、管理和使用,以及Nginx在性能优化方面的一些经验和技巧,并通过实例分别演示了Nginx与PHP整合,Nginx和Java、Perl整合的过程。本节为大家介绍搭建Nginx+Java环境。
AD:
1.8.4 搭建Nginx+Java环境
Apache对Java的支持很灵活,它们的结合度也很高,例如Apache+Tomcat和Apache+resin等都可以实现对Java应用的支持。Apache一般采用一个内置模块来和Java应用服务器打交道。与Apache相比,Nginx在配合Java应用服务器方面,耦合度很低,它只能通过自身的反向代理功能来实现与Java应用服务器的支持。但这恰恰是Nginx的一个优点,耦合度的降低,可以使Nginx与Java服务器的相互影响降到最低。
接下来通过Nginx+Tomcat的实例来讲解Nginx对Java的支持。Tomcat在高并发环境下处理动态请求时性能很低,而在处理静态页面更加脆弱。虽然Tomcat的最新版本支持epoll,但是通过Nginx来处理静态页面要比通过Tomcat处理在性能方面好很多。
Nginx可以通过以下两种方式来实现与Tomcat的耦合:
将静态页面请求交给Nginx,动态请求交给后端Tomcat处理。
将所有请求都交给后端的Tomcat服务器处理,同时利用Nginx自身的负载均衡功能进行多台Tomcat服务器的负载均衡。
下面通过两个配置实例分别讲述这两种实现Nginx与Tomcat耦合的方式。
1.动态页面与静态页面分离的实例
这里假定Tomcat服务器的IP地址为192.168.12.130,同时Tomcat服务器开放的服务器端口为8080。Nginx相关配置代码如下:
在这个实例中,首先定义了一个虚拟主机www.ixdba.net,然后通过location指令将/web/www/html/img/目录下的静态文件交给Nginx来完成。最后一个location指令将所有以.jsp、.do结尾的文件都交给Tomcat服务器的8080端口来处理,即http://192.168.12.130:8080。
需要特别注意的是,在location指令中使用正则表达式后,proxy_pass后面的代理路径不能含有地址链接,也就是不能写成http://192.168.12.130:8080/,或者类似http://192.168.12.130:8080/jsp的形式。在location指令不使用正则表达式时,没有此限制。
2.多个Tomcat负载均衡的实例
这里假定有3台Tomcat服务器,分别开放不同的端口,地址如下:
Nginx的相关配置代码如下:
在这个实例中,先通过upstream定义一个负载均衡组,组名为mytomcats,组的成员就是上面指定的3台Tomcat服务器;接着通过server指令定义一个www.ixdba.net的虚拟主机;然后通过location指令以正则表达式的方式将指定类型的文件全部交给Nginx去处理;最后将其他所有请求全部交给负载均衡组来处理。
这里还有一点需要注意,如果在location指令使用正则表达式后再用alias指令,Nginx是不支持的。
download and install jdk 1.6
http://java.sun.com/javase/downloads/widget/jdk6.jsp
安装目录则在执行文件所在目录/u01
Java 环境变量
download and install tomcat
http://tomcat.apache.org/download-60.cgi
解压缩至/uat/shaidanwang/tomcat-6.0.41-1
另外把bin目录下chmod 777
nginx config
修改/etc/nginx/conf.d/default.conf
reference:http://www.blogjava.net/sliverfancy/archive/2012/07/31/384400.html
http://snowolf.iteye.com/blog/1539932
http://zhidao.baidu.com/link?url=1nUEIyKLzrn0tqlwRaBaUV6zhz4vM4l2TCgzNYZbh6TI3CuGraCwGnM0bI650P7vDestKB0w0OCoxqzKzkH1vK
《高性能Linux服务器构建实战:运维监控、性能调优与集群应用》第1章轻量级HTTP服务器Nginx,本章主要介绍了对高性能HTTP服务器Nginx的安装、配置、管理和使用,以及Nginx在性能优化方面的一些经验和技巧,并通过实例分别演示了Nginx与PHP整合,Nginx和Java、Perl整合的过程。本节为大家介绍搭建Nginx+Java环境。
AD:
1.8.4 搭建Nginx+Java环境
Apache对Java的支持很灵活,它们的结合度也很高,例如Apache+Tomcat和Apache+resin等都可以实现对Java应用的支持。Apache一般采用一个内置模块来和Java应用服务器打交道。与Apache相比,Nginx在配合Java应用服务器方面,耦合度很低,它只能通过自身的反向代理功能来实现与Java应用服务器的支持。但这恰恰是Nginx的一个优点,耦合度的降低,可以使Nginx与Java服务器的相互影响降到最低。
接下来通过Nginx+Tomcat的实例来讲解Nginx对Java的支持。Tomcat在高并发环境下处理动态请求时性能很低,而在处理静态页面更加脆弱。虽然Tomcat的最新版本支持epoll,但是通过Nginx来处理静态页面要比通过Tomcat处理在性能方面好很多。
Nginx可以通过以下两种方式来实现与Tomcat的耦合:
将静态页面请求交给Nginx,动态请求交给后端Tomcat处理。
将所有请求都交给后端的Tomcat服务器处理,同时利用Nginx自身的负载均衡功能进行多台Tomcat服务器的负载均衡。
下面通过两个配置实例分别讲述这两种实现Nginx与Tomcat耦合的方式。
1.动态页面与静态页面分离的实例
这里假定Tomcat服务器的IP地址为192.168.12.130,同时Tomcat服务器开放的服务器端口为8080。Nginx相关配置代码如下:
server { listen 80; server_name www.ixdba.net; root /web/www/html; location /img/ { alias /web/www/html/img/; } location ~ (\.jsp)|(\.do)$ { proxy_pass http://192.168.12.130:8080; proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; client_max_body_size 10m; client_body_buffer_size 128k; proxy_connect_timeout 90; proxy_send_timeout 90; proxy_read_timeout 90; proxy_buffer_size 4k; proxy_buffers 4 32k; proxy_busy_buffers_size 64k; proxy_temp_file_write_size 64k; } }
在这个实例中,首先定义了一个虚拟主机www.ixdba.net,然后通过location指令将/web/www/html/img/目录下的静态文件交给Nginx来完成。最后一个location指令将所有以.jsp、.do结尾的文件都交给Tomcat服务器的8080端口来处理,即http://192.168.12.130:8080。
需要特别注意的是,在location指令中使用正则表达式后,proxy_pass后面的代理路径不能含有地址链接,也就是不能写成http://192.168.12.130:8080/,或者类似http://192.168.12.130:8080/jsp的形式。在location指令不使用正则表达式时,没有此限制。
2.多个Tomcat负载均衡的实例
这里假定有3台Tomcat服务器,分别开放不同的端口,地址如下:
192.168.12.131:8000 192.168.12.132:8080 192.168.12.133:8090
Nginx的相关配置代码如下:
upstream mytomcats { server 192.168.12.131:8000; server 192.168.12.132:8080; server 192.168.12.133:8090; #ip_hash; } server { listen 80; server_name www.ixdba.net; location ~* \.(jpg|gif|png|swf|flv|wma|wmv|asf|mp3|mmf|zip|rar)$ { root /web/www/html/; } location / { proxy_pass http://mytomcats; proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; client_max_body_size 10m; client_body_buffer_size 128k; proxy_connect_timeout 90; proxy_send_timeout 90; proxy_read_timeout 90; proxy_buffer_size 4k; proxy_buffers 4 32k; proxy_busy_buffers_size 64k; proxy_temp_file_write_size 64k; } }
在这个实例中,先通过upstream定义一个负载均衡组,组名为mytomcats,组的成员就是上面指定的3台Tomcat服务器;接着通过server指令定义一个www.ixdba.net的虚拟主机;然后通过location指令以正则表达式的方式将指定类型的文件全部交给Nginx去处理;最后将其他所有请求全部交给负载均衡组来处理。
这里还有一点需要注意,如果在location指令使用正则表达式后再用alias指令,Nginx是不支持的。
download and install jdk 1.6
http://java.sun.com/javase/downloads/widget/jdk6.jsp
#/u01 #chmod 755 jdk-6u45-linux-x64.bin #./jdk-6u45-linux-x64.bin
安装目录则在执行文件所在目录/u01
Java 环境变量
#cd /etc #vi profile ************************** JAVA_HOME="/u01/jdk1.6.0_45" CLASS_PATH="$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib:$JAVA_HOME/bin" export JAVA_HOME CLASS_PATH PATH=".:$PATH:$JAVA_HOME/bin" export PATH CATALINA_BASE_1="/uat/shaidanwang/tomcat-6.0.41-1" CATALINA_HOME_1="/uat/shaidanwang/tomcat-6.0.41-1" export CATALINA_BASE_1 CATALINA_HOME_1 CATALINA_BASE_2="/uat/shaidanwang/tomcat-6.0.41-2" CATALINA_HOME_2="/uat/shaidanwang/tomcat-6.0.41-2" export CATALINA_BASE_2 CATALINA_HOME_2 #source profile
download and install tomcat
http://tomcat.apache.org/download-60.cgi
解压缩至/uat/shaidanwang/tomcat-6.0.41-1
另外把bin目录下chmod 777
# chmod 777 -R bin/
nginx config
修改/etc/nginx/conf.d/default.conf
user nobody; worker_processes 2; error_log logs/error.log; #error_log logs/error.log notice; #error_log logs/error.log info; pid logs/nginx.pid; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for"'; access_log logs/access.log main; sendfile on; #tcp_nopush on; #keepalive_timeout 0; keepalive_timeout 65; gzip on; upstream tomcat_server { server 192.168.130.128:8080 weight=5; server 192.168.130.129:8080 weight=5; ip_hash; } server { listen 80; server_name localhost; charset utf-8; access_log logs/host.access.log main; location / { proxy_pass http://tomcat_server; proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; client_max_body_size 10m; client_body_buffer_size 128k; proxy_connect_timeout 90; proxy_send_timeout 90; proxy_read_timeout 90; proxy_buffer_size 4k; proxy_buffers 4 32k; proxy_busy_buffers_size 64k; proxy_temp_file_write_size 64k; } error_page 404 /404.html; error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } }
reference:http://www.blogjava.net/sliverfancy/archive/2012/07/31/384400.html
http://snowolf.iteye.com/blog/1539932
http://zhidao.baidu.com/link?url=1nUEIyKLzrn0tqlwRaBaUV6zhz4vM4l2TCgzNYZbh6TI3CuGraCwGnM0bI650P7vDestKB0w0OCoxqzKzkH1vK
发表评论
-
Linux下部署多个Tomcat多个域名
2015-12-12 19:02 3644一、安装JDK 1、安装jdk-7u79-linux-x64. ... -
Centos6 下的 nginx 安装
2014-08-04 15:41 746Centos6 下的 nginx 安装 ... -
Websphere Community Edition change port 8080 to 80
2013-08-30 21:45 647WebSphere Community Edition Cha ... -
Tomcat配置自己的Classloader
2013-06-08 20:45 1900Tomcat配置自己的Classloader http:// ... -
linux下同时启动2个或者多个tomcat的配置方法
2013-06-08 11:58 1414linux下同时启动2个或者多个tomcat的配置方法 1. ... -
Windows 8 下tomcat7配置
2013-06-08 11:44 1203Windows 8 下tomcat7配置 1.下载tomca ... -
The APR based Apache Tomcat Native library
2013-06-05 18:03 929The APR based Apache Tomcat Nat ... -
Forgot password and cannot access WebSphere Application Server administrative co
2013-04-03 10:51 799Forgot password and cannot acce ... -
Websphere8.0安装与配置
2013-04-01 12:34 1315Websphere8.0配置 reference: We ... -
在tomcat中,通过IP访问web系统,不需要端口号的方法
2013-03-08 10:25 937在tomcat中,通过IP访问web系统,不需要端口号的方法 ... -
如何将基于 Struts、Spring 和 Hibernate 的应用从 Tomcat 迁移到 WebSphere Application Server
2012-12-21 10:28 1140引言 现在很多的企业都 ... -
JAAS介绍
2012-03-08 02:06 1134JAAS是对JCE安全框架的重要补充,通过提供认证用户和确定用 ... -
web.xml中<security-constraint>和四种认证类型
2012-03-08 02:07 908<security-constraint> 的子元 ... -
Error 404: SRVE0190E: File not found: /login.action
2012-03-08 02:07 4658发生这样问题有两种情 ... -
关于websphere中配置 j_security_check 的配置
2012-03-07 23:19 1469系统登录的submit提交的action是j_securit ... -
Websphere 优化技巧
2012-03-07 23:15 10361,更改http server的配置 ... -
WebSphere下应用程序更新,安装war,ear包以及添加单独模块
2012-03-07 23:09 2313websphere 中直接修改web.xml: 一般来讲,单 ... -
websphere中的Single Sign-on 单点登录
2012-03-07 22:37 1046... -
LDAP
2012-03-07 02:23 9421. Websphere5.1.x+JAAS+LDAP配置全 ... -
LDAP
2012-03-07 02:23 01. Websphere5.1.x+JAAS+LDAP配置 ...
相关推荐
很好的学习Windows+Nginx+Tomcat搭建负载均衡和集群环境教材,里面有详细的Demo。
手把手教你搭建Nginx+Tomcat 集群的搭建,多个节点,实现负载均衡最全教程,图文教程
手把手教你搭建https服务器,部署ssl证书到php java服务器(Nginx-Apache PHP-Tomcat java+SSL证书) 1.购买免费的SSL证书 2.下载SSL证书 3.往nginx上新增ssl 4.往Apache上新增ssl 5.往Tomcat上新增ssl 6.解决警告 7....
Tomcat要支持memcached管理Session,需要调用一些jar库文件如下(网上有的文章中可能所说的jar包不全,或者版本不样的会报错,但这里我已经经过验证了): 1) couchbase-client-1.2.2.jar 2) javolution-5.5.1....
本课程介绍了目前处理并发能力非常强悍的开源软件nginx快速入门及使用,介绍nginx+tomcat集群处理并发解决方案,带大家认识虚拟路由,了解虚拟路由的工作流程并安装keepalived,实现nginx+keepalived主备配置,达到...
docker+jenkins+tomcat+mysql+redis+nginx,实现jenkins自动构建部署。Java+maven是单独搭建的。
目的:搭建高可用、高性能的jsp集群 二、初始化系统 #init system 系统环境: CentOS 5.5(定制安装) 组件: Base Development Libraries Development Tools Editors Text-based Internet ./init_system.sh #此脚本...
课程视频中出现的所有配套软件均可下载,下载地址笔记中有! 1. Linux系统安装以及远程操作工具安装2. Linux常用命令讲解3. JDK安装以及环境变量设置4....6、Nginx概述以及使用并通过Nginx实现Tomcat集群的搭建等功能
1、 介绍安装步骤,重点注意事项; 2、 集群规划,搭建主要步骤,重点注意事项; 3、 编制简单脚本进行优化,参数调优。 4、 最全面、最实用 5、 教程适用于各种版本 ...脚本进行优化,tomcat参数调优
以Nginx作为反向代理再用Tomcat驱动Java Web程序是当今很流行的一种方案,那么这里我们就着眼于最基本的生产环境搭建,一起来看一下Linux下Tomcat+Nginx服务器环境安装配置的简明教程
linux nginx双向认证服务搭建tomcat ssl 步骤
redis下载,可使用搭建nginx+tomcat集群.也可以使用Java项目进行缓存使用。
运行环境:jdk8 + nginx1.20 + tomcat9 + IntelliJ IDEA + maven + 宝塔面板 系统管理分为以下功能,分别是用户管理,角色管理,部门管理,菜单管理,用户角色分配, 角色菜单分配,数据字典,流水号规则,定时...
运行环境:jdk8 + nginx1.20 + tomcat9 + IntelliJ IDEA + maven + 宝塔面板 系统按预定的算法完成了创办运动会、广播公告公示、赛事项目拟订、报名参赛、赛后成绩录入、 查看比赛成绩、院系人员的信息存储、反馈...
运行环境:jdk8 + nginx1.20 + tomcat9 + IntelliJ IDEA + maven + 宝塔面板 系统功能介绍 管理员:专业管理、班级管理、学生管理、老师管理、课程管理、开课管理、用户管理 教师:成绩管理、学生查询 学生:...
运行环境:jdk8 + nginx1.20 + tomcat9 + IntelliJ IDEA + maven + 宝塔面板 系统功能介绍 分为管理员,用户两个角色,管理员主要管理后端数据。用户只有查看房间,预定房间,等操作。 修改个人密码、会员信息...
Java项目centos7 环境安装笔记 java环境搭建:jdk下载安装,tomcat下载安装 redis下载安装,nginx下载安装
fastdfs5.08+nginx1.14.0+libfastcommon_v1.04+ngx_cache_purge-master+fastdfs_client_java_v1.10.tar+apache-tomcat-8.5.34.tar+keepalived-1.2.20.tar
服务器使用Linux+Nginx-1.9.15+Tomcat7+Java搭建的。编写脚本检测错误日志和服务器性能指标,一旦新生错误日志或者性能降低到设定的阈值时,则使用云监控将报警上传到云账号。错误日志包含以下三个方面:nginx错误...
java分布式集群电商平台搭建文档demo,环境集群搭建dubbo、rabbitMQ 、redis 集群、mysql集群 、nginx负载、tomcat、zookeeper集群、maven项目构建示例