热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Nginx和resin(tomcat)集群中解决session共享的问题

在web服务器中需要中修改配置:resion中:shell$vimresin.conf##查找httpaddress*port8080/##注释掉!--httpaddress*port8080/--##查找serveridaddress127.0.0.1port6800##替换成serveridaaddress192.
在web服务器中需要中修改配置:
resion中:
shell $> vim resin.conf
##  查找    
## 注释掉
## 查找     
## 替换成   
   
   
   
   

   
   
   
   

tomcat中:(经过试验确认,虚拟主机也支持,只需按下面修改一次即可)
设置tomcat的server.xml, 在两台服务器的tomcat的配置文件中分别找到:

分别修改为:
Tomcat01:(192.168.0.100)

Tomcat02:(192.168.0.101)

nginx的修改:
nginx_upstream_jvm_route 是一个 Nginx 的扩展模块,用来实现基于 COOKIE 的 Session Sticky 的功能。
安装方法:
1.先获得nginx_upstream_jvm_route模块:
地址:http://sh0happly.blog.51cto.com/attachment/201004/1036375_1271836572.zip,解压后上传到/root下
2.进入Nginx源码目录:
cd nginx-0.7.61
patch -p0 <../nginx-upstream-jvm-route/jvm_route.patch
会出现以下提示:
patching file src/http/ngx_http_upstream.c
Hunk #1 succeeded at 3869 (offset 132 lines).
Hunk #3 succeeded at 4001 (offset 132 lines).
Hunk #5 succeeded at 4100 (offset 132 lines).
patching file src/http/ngx_http_upstream.h
3.安装nginx:
shell $> ./configure  --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module --add-module=/root/nginx-upstream-jvm-route/
shell $> make
shell $> make install
4.修改配置,例如:
1.For resin
upstream backend {
    server 192.168.0.100 srun_id=a;   #这里srun_id=a对应的是 server1  resin配置里的 server id="a"
    server 192.168.0.101 srun_id=b;
    jvm_route $COOKIE_JSESSIONID|sessionid;
}
2.For tomcat
upstream tomcat {
server 192.168.0.100:8080 srun_id=a;  #这里srun_id=a对应的是 tomcat01 配置里的 jvmRoute="a"
server 192.168.0.101:8080 srun_id=b;  #这里srun_id=a对应的是 tomcat02 配置里的 jvmRoute="b"
jvm_route $COOKIE_JSESSIONID|sessionid reverse;
}
   
server {
server_name  test.com;
charset utf-8,GB2312;
index  index.html;
if (-d $request_filename) {
rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent;
}
location / {
proxy_pass http://tomcat/;
proxy_redirect    off;
proxy_set_header X-Forwarded-For $remote_addr;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header Host $host;
}
在两台的tomcat上增加配置:
     
         prefix="crm_log." suffix=".txt" timestamp="true"/>
        
        

     

在/usr/local/tomcat/apps/jsp的下面新增index.jsp





<%
String name=request.getParameter("name");
out.println("this is 192.168.0.100:hello "+name+"!
");  #或192.168.0.101
%>


通过访问:http://test.com,页面会一直保持在192.168.0.100的页面,当清空COOKIEs和session后,再次刷新,页面会保持在192.168.0.101上。
一个实例:http://hi.baidu.com/scenkoy/blog/item/2cd89da9b57696f71e17a29e.html
测试环境:
server1   服务器上安装了 nginx + tomcat01
server2 服务器上只安装了 tomcat02        
server1 IP 地址: 192.168.2.88
server2 IP 地址: 192.168.2.89
安装步骤:
1. 在server1 上安装配置 nginx + nginx_upstream_jvm_route
shell $> wget -c http://sysoev.ru/nginx/nginx-0.7.61.tar.gz
shell $> svn checkout http://nginx-upstream-jvm-route.googlecode.com/svn/trunk/ nginx-upstream-jvm-route-read-only
shell $> tar zxvf nginx-0.7.61
shell $> cd nginx-0.7.61
shell $> patch -p0 < ../nginx-upstream-jvm-route-read-only/jvm_route.patch
shell $> useradd www
shell $> ./configure --user=www --group=www --prefix=/usr/local//nginx --with-http_stub_status_module --with-http_ssl_module --add-module=/root/nginx-upstream-jvm-route-read-only
shell $> make
shell $> make install
2.分别在两台机器上安装 tomcat和java (略)
设置tomcat的server.xml, 在两台服务器的tomcat的配置文件中分别找到:

分别修改为:
Tomcat01:

Tomcat02:

并在webapps下面建立aa文件夹,在里面建立要测试的index.jsp文件,内容如下:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
%>


   
     
       88
      
       

       <%out.print(request.getSession()) ;%>
      
       

        <%out.println(request.getHeader("COOKIE")); %>
     
     

两个tomcat一样只需要修改红色的部分
分别启动两个tomcat
3.设置nginx
shell $> cd /usr/local/nginx/conf
shell $> mv nginx.conf nginx.bak
shell $> vi nginx.conf
## 以下是配置 ###
user www www;
worker_processes 4;
error_log logs/nginx_error.log crit;
pid        /usr/local/nginx/nginx.pid;
#Specifies the value for maximum file descriptors that can be opened by this process.
worker_rlimit_nofile 51200;
events
{
use epoll;
worker_connections 2048;
}
http
{
upstream backend {
    server 192.168.2.88:8080 srun_id=a;
   server 192.168.2.89:8080 srun_id=b;
   jvm_route $COOKIE_JSESSIONID|sessionid reverse;
}
include       mime.types;
default_type application/octet-stream;
#charset gb2312;
charset UTF-8;
server_names_hash_bucket_size 128;
client_header_buffer_size 32k;
large_client_header_buffers 4 32k;
client_max_body_size 20m;
limit_rate 1024k;
sendfile on;
tcp_nopush     on;
keepalive_timeout 60;
tcp_nodelay on;
fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
fastcgi_buffer_size 64k;
fastcgi_buffers 4 64k;
fastcgi_busy_buffers_size 128k;
fastcgi_temp_file_write_size 128k;
gzip on;
#gzip_min_length 1k;
gzip_buffers     4 16k;
gzip_http_version 1.0;
gzip_comp_level 2;
gzip_types       text/plain application/x-Javascript text/css application/xml;
gzip_vary on;
#limit_zone crawler $binary_remote_addr 10m;
server
{
   listen       80;
   server_name 192.168.2.88;
   index index.html index.htm index.jsp;
   root /var/www;
   #location ~ .*\.jsp$
   location / aa/
{
     proxy_pass http://backend;
     proxy_redirect    off;
     proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
     proxy_set_header X-Real-IP $remote_addr;
     proxy_set_header Host $http_host;
   }
   location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
   {
     expires      30d;
   }
   location ~ .*\.(js|css)?$
   {
     expires      1h;
   }
   location /Nginxstatus {
     stub_status on;
     access_log   off;
   }
log_format access '$remote_addr - $remote_user [$time_local] "$request" '
             '$status $body_bytes_sent "$http_referer" '
             '"$http_user_agent" $http_x_forwarded_for';
# access_log off;
}
}
4.测试
打开浏览器,输入:http://192.168.2.88/aa/
刷新了N次还都是88,也就是补丁起作用了,COOKIE 值也获得了,为了测试,我又打开了“遨游浏览器”(因为session 和 COOKIE问题所以从新打开别的浏览器),输入网址:
http://192.168.2.88/aa/
显示89,刷新N次后还是89,大家测试的时候如果有疑问可一把 nginx 配置文件的
srun_id=a srun_id=b 去掉,然后在访问,就会知道页面是轮询访问得了!!

推荐阅读
  • 我的读书清单(持续更新)201705311.《一千零一夜》2006(四五年级)2.《中华上下五千年》2008(初一)3.《鲁滨孙漂流记》2008(初二)4.《钢铁是怎样炼成的》20 ... [详细]
  • Centos7 Tomcat9 安装笔记
    centos7,tom ... [详细]
  • Asynchronous JavaScript and XML (AJAX) 的流行很大程度上得益于 Google 在其产品如 Google Suggest 和 Google Maps 中的应用。本文将深入探讨 AJAX 在 .NET 环境下的工作原理及其实现方法。 ... [详细]
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • 在使用 Nginx 作为服务器时,发现 Chrome 能正确从缓存中读取 CSS 和 JS 文件,而 Firefox 却无法有效利用缓存,导致加载速度显著变慢。 ... [详细]
  • 本文探讨了如何通过优化 DOM 操作来提升 JavaScript 的性能,包括使用 `createElement` 函数、动画元素、理解重绘事件及处理鼠标滚动事件等关键主题。 ... [详细]
  • 本文介绍了SIP(Session Initiation Protocol,会话发起协议)的基本概念、功能、消息格式及其实现机制。SIP是一种在IP网络上用于建立、管理和终止多媒体通信会话的应用层协议。 ... [详细]
  • 华为与红帽联手,加速开源电信软件革新
    华为与红帽携手合作,旨在加速开源电信软件的发展,以满足大型电信运营商对灵活网络解决方案的需求。 ... [详细]
  • 深入理解:AJAX学习指南
    本文详细探讨了AJAX的基本概念、工作原理及其在现代Web开发中的应用,旨在为初学者提供全面的学习资料。 ... [详细]
  • 本文详细探讨了在Web开发中常见的UTF-8编码问题及其解决方案,包括HTML页面、PHP脚本、MySQL数据库以及JavaScript和Flash应用中的乱码问题。 ... [详细]
  • HTML前端开发:UINavigationController与页面间数据传递详解
    本文详细介绍了如何在HTML前端开发中利用UINavigationController进行页面管理和数据传递,适合初学者和有一定基础的开发者学习。 ... [详细]
  • 在尝试启动Java应用服务器Tomcat时,遇到了org.apache.catalina.LifecycleException异常。本文详细记录了异常的具体表现形式,并提供了有效的解决方案。 ... [详细]
  • 使用 jQuery 实现页面加载进度条
    页面加载进度条是提升用户体验的重要工具,通过在页面头部显示一个加载状态,并在页面完全加载后隐藏,可以有效减少用户的等待焦虑。本文将详细介绍如何使用 jQuery 实现这一功能。 ... [详细]
  • MySQL Administrator: 监控与管理工具
    本文介绍了 MySQL Administrator 的主要功能,包括图形化监控 MySQL 服务器的实时状态、连接健康度、内存健康度以及如何创建自定义的健康图表。此外,还详细解释了状态变量和系统变量的管理。 ... [详细]
  • 本文详细探讨了Spring框架中遇到的NoSuchBeanDefinitionException异常,具体涉及com.thinkplatform.dao.UserLogDao Bean未定义的问题,并提供了相应的解决方案。 ... [详细]
author-avatar
平凡屋之换
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有