因tomcat处理静态资源的速度比较慢,所以首先想到的就是把所有静态资源(JS,CSS,image,swf) 提到单独的服务器,用更加快速的HTTP服务器,这里选择了nginx了,nginx相比apache,更加轻量级, 配置更加简单,而且nginx不仅仅是高性能的HTTP服务器,还是高性能的反向代理服务器。 目前很多大型网站都使用了nginx,新浪、网易、QQ等都使用了nginx,说明nginx的稳定性和性能还是非常不错的。 1.[b]准备工作[/b] [b] [/b]下载tomcat([url=http://tomcat.apache.org/download-70.cgi]http://tomcat.apache.org/download-70.cgi[/url]),下载nginx([url=http://nginx.org/en/download.html]http://nginx.org/en/download.html[/url]),我用的版本是tomcat 7.0,nginx 1.1.1,分别解压tomcat,和nginx到独立的目录,下图是我解压的目录 如果你的电脑上没有jdk,那么还需要下载jdk([url=http://www.oracle.com/technetwork/java/javase/downloads/index.html]http://www.oracle.com/technetwork/java/javase/downloads/index.html[/url]),我用的jdk版本是1.6 。tomcat的运行需要JAVA_HOME环境变量中加上jdk的路径。 如图 我的电脑右键--》属性 高级选项卡--->环境变量 系统变量中的 新建按钮--->输入变量名JAVA_HOME和变量值F:\JAVA\jdk1.6.0_02 ( 这里是你自己的jdk路径 ),确定,确定。 [b]2.配置tomcat[/b],接下来,需要修改一下tomcat的默认ROOT目录,使其指向nginx的目录。 打开tomcat/conf/server.xml文件。找到标签,在中加入以下内容。 记得保存,这句话的意思是,在这个主机中,打开的站点为 "F:\service\nginx-0.8.54\html\www" 下的目录,如图 -------------------------------------------------------------------- 接下来,我们需要在这个目录中("F:\service\nginx-0.8.54\html\www" )中新建一个用于测试的index.jsp文件。如图 index.jsp中可以简单几句话用于测试即可: this is Tomcat 1+2 = 然后我们就可以打开tomcat了(tomcat/bin下面的startup.bat双击就好)。默认端口是8080。如图 打开服务器后,我们就可以打开浏览器localhost:8080测试tomcat是否配置正确了。如图 --------------------------------------------------------------- 如果出现了上面这个页面,则tomcat配置成功,我们就可以放下tomcat了。 3.[b]配置nginx[/b], 打开nginx/conf/nginx.conf文件,这个文件是nginx服务器的核心配置文件。如图 里面的内容替换成 #user nobody; worker_processes 1; #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; include proxy.conf; #这个文件是我们新建的,要导入 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; server { listen 80; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; location / { root html\www; index index.jsp index.html index.htm; } location ~ .*.jsp$ { #匹配以jsp结尾的,tomcat的网页文件是以jsp结尾 index index.jsp; proxy_pass http://localhost:8080; #主要在这里,设置一个代理 } location /nginxstatus { stub_status on; access_log on; auth_basic "nginxstatus"; auth_basic_user_file htpasswd; } # redirect server error pages to the static page /50x.html # #error_page 500 502 503 504 /50x.html; #error_page 404 /404.html; location = /50x.html { root html; } # proxy the PHP scripts to Apache listening on 127.0.0.1:80 # #location ~ \.php$ { # proxy_pass http://127.0.0.1; #} # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 # #location ~ \.php$ { # root html; # fastcgi_pass 127.0.0.1:9000; # fastcgi_index index.php; # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; # include fastcgi_params; #} # deny access to .htaccess files, if Apache's document root # concurs with nginx's one # #location ~ /\.ht { # deny all; #} } # another virtual host using mix of IP-, name-, and port-based configuration # #server { # listen 8000; # listen somename:8080; # server_name somename alias another.alias; # location / { # root html; # index index.html index.htm; # } #} # HTTPS server # #server { # listen 443; # server_name localhost; # ssl on; # ssl_certificate cert.pem; # ssl_certificate_key cert.key; # ssl_session_timeout 5m; # ssl_protocols SSLv2 SSLv3 TLSv1; # ssl_ciphers ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP; # ssl_prefer_server_ciphers on; # location / { # root html; # index index.html index.htm; # } #} } -------------------------------------------------------- 在conf文件夹下再建一文件proxy.conf,内容如下 # proxy.conf proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; #获取真实IP #proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; #获取代理者的真实ip 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; ------------------------------------------------------------- 双击nginx.exe,启动服务器,nginx的默认端口是80,所以和tomcat不会冲突,如果tomcat也是80的话,那么就需要调整一下了。 打开浏览器,输入localhost回车,如果我们看到了以下的内容,则表示配置成功了,如图 ------------------------------------------------------------ 这是nginx默认的错误页,如图 ----------------------------------------------------------------- 至此,tomcat和nginx已经整合成功了。
分享到:
相关推荐
在构建高性能、高可用性的Web服务时,"redis+tomcat+nginx负载均衡配置"是一个常见且有效的架构模式。这个组合充分利用了各个组件的优势,确保系统稳定、响应快速,并能够处理大量的并发请求。以下是关于这个配置的...
在构建高性能、高可用性的Web服务时,"Nginx+Tomcat+Redis"的组合是一种常见的架构模式。这个架构充分利用了每个组件的优势,以实现高效的数据处理、动态内容渲染和负载均衡。以下是对这套技术栈的详细解释: 1. **...
在与Nginx结合使用时,Keepalived可以实现VIP(Virtual IP)漂移,确保即使在一台服务器宕机的情况下,客户端仍然可以连接到集群中的其他正常服务器。 综上所述,这个压缩包提供的JDK是构建整个架构的起点,它为...
在构建高性能、高可用性的Web服务时,"tomcat+nginx集群"是一个常见的架构模式。这个模式结合了Tomcat作为应用服务器处理Java EE应用程序,而Nginx则作为反向代理和负载均衡器,确保流量的高效分配和系统的稳定运行...
通过上述步骤,我们构建了一个基于Redis + Tomcat + Nginx的分布式部署方案,不仅实现了负载均衡,还解决了Session共享的问题。这种架构设计不仅可以提高Web应用的服务性能,还能增强系统的容错能力和可扩展性,是...
在IT行业中,构建高效、可扩展的Web服务是至关重要的,而Windows+Nginx+Tomcat的组合在处理高并发请求时,常被用来搭建负载均衡系统,同时通过session共享来保证用户会话的一致性。这个“Windows+Nginx+Tomcat做负载...
在此场景下,当用户在某台Tomcat服务器上创建或更新session时,相关信息会被同步到Redis中。其他服务器在处理请求时,可以从Redis中获取并使用该session数据。 实现步骤包括: 1. **安装和配置Redis**:首先,你...
1. 在Nginx配置文件中添加负载均衡配置,例如使用轮询策略: ```nginx upstream backend { server backend1.example.com; server backend2.example.com; server backend3.example.com; } location / { ...
在构建高性能、高可用性的Web应用系统时,整合Apache Tomcat、Nginx以及Redis作为会话管理器是一个常见的选择。这个"tomcat-redis-session-manager tomcat+nginx+redis集群所需jar"压缩包提供了在这样的架构中实现...
最近自己做了一个前后端分离项目,前端采用HBuilderX开发,后端采用IDEA开发,在本地开发也跨域,部署到云服务器也跨域,下面介绍两种解决方案。 出于浏览器的同源策略限制。同源策略(Sameoriginpolicy)是一种约定...
【标题】"tomcat7+memcached+nginx 集群架包(无ngnix架包)"指的是一个用于构建高性能、可扩展的Web应用集群的解决方案,但不包括nginx配置部分。在这个架构中,Tomcat7作为Java应用服务器处理HTTP请求,Memcached...
在构建高性能、高可用性的Web服务时,"Tomcat+redis+nginx配置"是一个常见的解决方案。这个架构将Nginx作为反向代理服务器,Redis作为会话共享存储,多台Tomcat作为应用服务器组成集群。下面我们将详细探讨这些组件...
- **定义Upstream**:在`nginx.conf`的`http`部分定义`tomcat`的`Upstream`,指定两台Tomcat服务器的地址。 - **配置Location**:在`server`部分为`/test`路径配置`Proxy_pass`指令,转发请求至Tomcat集群,并传递...
这个实例“tomcat+nginx+redis 实现sessionId共享”旨在教你如何在使用Tomcat作为应用服务器、Nginx作为反向代理服务器的环境中,利用Redis来实现跨服务器的会话(sessionId)共享。这对于在分布式系统中保持用户...
"Tomcat+Nginx+MyBatis+Redis"的整合就是一个典型的案例,它利用了Tomcat作为Java应用服务器,Nginx作为反向代理和负载均衡器,MyBatis作为持久层框架,以及Redis作为高速缓存系统。 一、部署启动多个Tomcat 1. ...
在Nginx中配置负载均衡,你需要定义一个upstream块,指定后端服务器(如多个Tomcat实例),然后在server块中使用proxy_pass指令将请求转发到upstream。同时,Nginx还可以缓存静态资源,进一步提升响应速度。 为了...
Nginx是一个高性能的反向代理服务器和HTTP缓存服务器,用于接收来自LVS的流量,并根据预设规则将请求转发给合适的后端Tomcat服务器。Nginx支持HTTP、HTTPS以及TCP协议,可以通过配置stream模块处理TCP流量。在本...
本教程将探讨如何在Windows环境下,利用Nginx作为反向代理和负载均衡器,与Tomcat应用服务器配合,搭建一个负载均衡和集群环境。这种配置能够提升系统的稳定性和处理能力,确保即使在服务器压力大的情况下,也能为...
在构建高性能、高可用性的Web服务时,"tomcat8+Redis+nginx"组合是一个常见的架构选择。这个架构主要利用了Tomcat作为Java应用服务器,Redis作为缓存系统,以及Nginx作为反向代理和负载均衡器。下面将详细阐述这三者...