博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Nginx + Tomcat + Session
阅读量:5893 次
发布时间:2019-06-19

本文共 4086 字,大约阅读时间需要 13 分钟。

分别下载

tomcat 

nginx 

 

准备两个虚拟机:

server1 192.168.1.112

server2 192.168.1.64

 

Tomcat直接解压,运行,使用默认的8080端口

tar zxvf apache-tomcat-7.0.22.tar.gz
cd apache-tomcat-7.0.22/bin
./startup.sh

访问http://192.168.1.112:8080和http://192.168.1.64:8080出现Tomcat首页即可

 

接下来安装nginx, nginx我就直接安装在server1上

nginx_upstream_jvm_route是一个Nginx的扩展模块,用来实现基于Cookie的SessionSticky的功能, 去SVN下载最新版

svn checkout http://nginx-upstream-jvm-route.googlecode.com/svn/trunk/ /root/dev/nginx-upstream-jvm-route-read-only

解压nginx

tar zxvf nginx-1.1.14.tar.gz cd nginx-1.1.14

 运行

patch -p0 < /root/dev/nginx-upstream-jvm-route-read-only/jvm_route.patch
./configure --prefix=/etc/nginx --with-http_stub_status_module --add-module=/root/dev/nginx-upstream-jvm-route-read-only/
make
make install

在nginx安装目录下的conf/目录新建一个文件proxy.conf(/etc/nginx/conf/proxy.conf), 内容如下:

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;

修改nginx配置文件/etc/nginx/conf/nginx.conf

完整配置如下

http {
include mime.types; #反向代理配置 include proxy.conf; default_type application/octet-stream; sendfile on;
keepalive_timeout  65;     upstream server1{
server 192.168.1.112:8080 srun_id=tomcat1; server 192.168.1.64:8080 srun_id=tomcat2; jvm_route $cookie_JSESSIONID|sessionid reverse; } server {
listen 80; server_name localhost; access_log /var/log/nginx/access.log; location ~ ^/NginxStatus/ { stub_status on; #Nginx 状态监控配置 access_log off; } location ~ ^/(WEB-INF)/ {
deny all; } location / {
root html; index index.html index.htm; proxy_pass http://server1; } location /doc {
root /usr/share; autoindex on; allow 127.0.0.1; deny all; } location /images {
root /usr/share; autoindex on; }

具体配置说明请参考《轻量级WEB服务器Nginx》

然后运行nginx

/etc/nginx/sbin/nginx

访问http://192.168.1.112/NginxStatus,可以看到nginx状态

然后修改tomcat配置文件, 打开apache-tomcat-7.0.22/conf/server.xml, 找到最下面的<Engine name="Catalina" defaultHost="localhost">节点, 修改为

server1

并插入如下配置

server2

...
...

 

jvmRoute="tomcat1"和nginx配置upstream中的srun_id对应
membership中的address=224.0.0.4为组播IP,集群中的tomcat通信之用
receiver中的address设为本机IP,或auto,如果多个Tomcat在同一台电脑上,则要保证port端口不重复
 

在两个tomcat的webapps目录下分别新建一个项目test,

/test

/test/index.jsp

/test/WEB-INF/

/test/WEB-INF/web.xml

index.jsp内容

<%@ page language="java" contentType="text/html; charset=UTF-8"     pageEncoding="UTF-8"%>    
Insert title here <%=session.getId() %>
<% String msg = (String)session.getAttribute("msg"); if(null == msg){
session.setAttribute("msg", "Hello!"); }else{
session.setAttribute("msg", msg + 0); } %> <%=session.getAttribute("msg") %>

web.xml

index.jsp

注意上面的distributable节点,表示该应用是在集群环境下的。

 

重启tomcat后在两台机子上访问http://192.168.1.112/test

从SessionId后面带的服务器名可以看到负载均衡的效果。

然后将server1上的tomcat停掉,再刷新页面,可以看到原来访问server1的页面成功地切换到了server2,而sessionId没有变,session中的msg也和原来一样。

转载于:https://www.cnblogs.com/fx2008/p/4154754.html

你可能感兴趣的文章
《关爱码农成长计划》第一期报告
查看>>
学习进度表 04
查看>>
谈谈javascript中的prototype与继承
查看>>
时序约束优先级_Vivado工程经验与各种时序约束技巧分享
查看>>
minio 并发数_MinIO 参数解析与限制
查看>>
mysql 应用程序是哪个文件夹_Mysql 数据库文件存储在哪个目录?
查看>>
mysql半同步和无损复制_MySQL半同步复制你可能没有注意的点
查看>>
python编译exe用于别的电脑上_Python安装教程(推荐一款不错的Python编辑器)
查看>>
flash back mysql_mysqlbinlog flashback 使用最佳实践
查看>>
hive中如何把13位转化为时间_sqoop1 导入 hive parquet 表中 时间戳调整为日期
查看>>
mysql书外键_[转] mysql 外键(Foreign Key)的详解和实例
查看>>
mysql存储引擎模式_MySQL存储引擎
查看>>
mysql5002_mysql新手进阶02
查看>>
python类 del_全面了解Python类的内置方法
查看>>
前后端传图片用base64好吗_前后端分离 前台传base64的图片 tp5.1.1进行处理
查看>>
java对象的排序_Java对象排序两种方法
查看>>
java jni 原理_使用JNI技术实现Java和C++的交互
查看>>
java 重写system.out_重写System.out.println(String x)方法
查看>>
mysql client命令行选项
查看>>
vc遍历网页表单并自动填写提交 .
查看>>