Windows7 + Nginx + Memcached + Tomcat 集群 session 共享

一,环境说明

操作系统是Windows7家庭版(有点不专业哦,呵呵!),JDK是1.6的版本,

Tomcat是apache-tomcat-6.0.35-windows-x86,下载链接:http://tomcat.apache.org/

Nginx是nginx-1.3.0,下载链接:http://nginx.org/en/download.html

Memcached是memcached-1.2.6-win32-bin,下载链接:http://code.jellycan.com/files/memcached-1.2.6-win32-bin.zip,

其他所需jar包,如下列表:

memcached-session-manager-1.6.1,memcached-session-manager-tc6-1.6.1(因为Tomcat版本为6.0)

javolution-5.4.3.1,msm-javolution-serializer-1.6.1(准备使用javolution序列化方式)

spymemcached-2.7.3(依赖包),以上jar包在http://code.google.com/p/memcached-session-manager/downloads/list中都可以找到,文档http://code.google.com/p/memcached-session-manager/wiki/SetupAndConfiguration中详细介绍了不同的服务器版本,不同的jar包需求。

好,资源已经准备齐全,马上就可以开始搭建啦!

按照配置的顺序,搭建步骤可以分为四个部分:

1,Tomcat的安装和配置

2,Memcached的安装和配置

3,Nginx的安装和配置

4,应用测试

下面将严格按照步骤来介绍集群的搭建工作,请参考《Windows7 + Nginx + Memcached + Tomcat 集群 session 共享(二)》

一、Tomcat的配置安装

既然是要集群,那自然不可能是一个Tomcat咯。将tomcat的安装包apache-tomcat-6.0.35-windows-x86解压到X:/ (这个路径可以自定义),重命名加压目录,我将这个目录改名为“tomcat1”(因为还有第二个tomcat),然后COPY一份tomcat1至X:/目录,重命名为“tomcat2”。做完上述工作,我的X盘中tomcat的列表如下图(注意忽略你看到的两个虚拟机目录,呵呵!它们与本次任务不相关)。

Windows7 + Nginx + Memcached + Tomcat 集群 session 共享(二) - 落羽 - 落羽
接下来的任务就是TOMCAT的配置啦!
操作对象:$TOMCAT_HOME/conf/server.xml文件(这里注意两个TOMCAT中的文件都要修改)。
修改内容:三个端口号一个命名。
(1) <Server port="8085" shutdown="SHUTDOWN">  (tomcat2中可以为“8086”)
(2) <Connector port="8080" protocol="HTTP/1.1"      (tomcat2中可以为“8081”)
               connectionTimeout="20000"
               redirectPort="8443" />
(3) <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />   (tomcat2中可以为“8089”)
(4) <Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat1">   (tomcat2中可以为“tomcat2”)
上面红色部分是需要修改和增加的内容,确保tomcat1和tomcat2两个目录下server.xml中的4个值不相同。
 
下面测试Tomcat是否安装成功。进入$TOMCAT_HOME/bin,运行start.bat文件,出现下图结果,表示tomcat已启动。
Windows7 + Nginx + Memcached + Tomcat 集群 session 共享(二) - 落羽 - 落羽
按照上述方法同时启动前面安装的两个TOMCAT。打开浏览器,分别输入http://localhost:{端口号},如果看到Tomcat的欢迎页,一个奔跑中的大猫,表示第一步骤已经成功完成。如果未成功,那就要仔细查看控制台的错误信息,通常是端口号冲突,一定要确保配置的端口号是未使用的端口号。
一、Memcached的安装和配置

1、 Memcached的安装

      将安装包memcached-1.2.6-win32-bin解压到X:/目录下面,重命名为memcached。打开命令提示符,进入X:/memcached的目录,输入安装命令“memcached.exe –d install”,安装memcached的windows服务,然后输入“memcached -d start”,以后memcached将作为windows的一个服务每次开机时自动启动。默认端口:11211。

      下面插入介绍一些memcached的常用命名,也是最基本的命令,不然你启动了memcached,不知道怎么停止这个服务了,也不知道是否已经启动该服务。

     (1) 查看memcached的服务是否已经启动:tasklist /fi "imagename eq memcached.exe",如下图

    Windows7 + Nginx + Memcached + Tomcat 集群 session 共享(三) - 落羽 - 落羽

(2)  memcached参数使用介绍(Win7用户要以管理员身份启动命令窗口哦!)
-p 监听的端口
     -l 连接的IP地址, 默认是本机
     -d start 启动memcached服务
    -d restart 重起memcached服务
    -d stop|shutdown 关闭正在运行的memcached服务
    -d install 安装memcached服务
    -d uninstall 卸载memcached服务
    -u 以的身份运行 (仅在以root运行的时候有效) 
    -m 最大内存使用,单位MB。默认64MB
    -M 内存耗尽时返回错误,而不是删除项
    -c 最大同时连接数,默认是1024
    -f 块大小增长因子,默认是1.25
    -n 最小分配空间,key+value+flags默认是48
    -h 显示帮助
2、memcached的配置
(1)把《Windows7 + Nginx + Memcached + Tomcat 集群 session 共享(一)》中提到的jar包(总共是5个),COPY到两个TOMCAT安装目录下的lib/中。
(2)修改文件$TOMCAT/conf/context.xml(两个tomcat中的都需要修改),在Context标签中加入如下代码:

 <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager" 

  memcachedNodes="n1:localhost:11211"   //目前机器只安装了一个memcached,所以这里只写一个节点OK。
  requestUriIgnorePattern=".*/.(png|gif|jpg|css|js)$" 
  sessionBackupAsync="false" 
  sessionBackupTimeout="100"
  transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"  //序列化类
  copyCollectionsForSerialization="false"/>

更多信息,请查看:http://code.google.com/p/memcached-session-manager/wiki/SetupAndConfiguration

一、Nginx的安装和配置

1、Nginx的安装

将安装包nginx-1.3.0.zip解压到X:/目录,目录重命名为nginx。到这里为止,我表示已经安装完成啦!

启动Nginx:进入X:/nginx目录,执行命令:start nginx.exe,弹出屏会一闪而逝。接着输入tasklist /fi "imagename eq nginx.exe",出现如下内容,表示nginx已正常启动啦!在浏览器输入http://localhost,可以看到Nginx的欢迎页。

Windows7 + Nginx + Memcached + Tomcat 集群 session 共享(三) - 落羽 - 落羽

 更多Nginx常用命令:

停止Nginx:nginx.exe -s stop|quit

重启Nginx:nginx.exe -s reload

查看Nginx版本:nginx.exe -v

参考页面:http://hi.baidu.com/ihanxo/blog/item/6d3a8a2688d24ce8d6cae201.html

 

2,Nginx的配置

修改文件$NGINX_HOME/conf/nginx.conf。


  #设定负载均衡的服务器列表

     upstream 127.0.0.1 {

         #weigth参数表示权值,权值越高被分配到的几率越大

         server 127.0.0.1:8081 weight=1;

         server 127.0.0.1:8082 weight=1;

     }

  
    server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html;
            index  index.html index.htm;
            proxy_pass    http://127.0.0.1;
        }

     }

     红色部分是需要在nginx.conf中添加的内容。

     黑色粗体表示当前Nginx监听的主机名和端口号,在浏览器中测试的时候需要输入的内容。

    proxy_pass表示代理主机,upstream 127.0.0.1 {……}配置中配置了代理主机处理请求的两个服务。

    上述配置表示:Nginx监听到http://locahost:80的请求之后,转发到代理127.0.0.1中的两个服务中的一个,有它们来处理请求。weight表示被分配到权重,weight值越大,处理请求的机会越多。

    至此,Nginx的安装与配置结束。

配置工作已经结束了,马上开始测试吧!(记得以管理员身份启动命令提示符窗口

1、启动memcached:进入X:/memcached目录,执行memcached.exe -d start;

2、启动Nginx:进入X:/nginx目录,执行start nginx.exe;

3、启动两个TOMCAT,分别进入$TOMCAT_HOME/bin目录,执行start.bat;

4、准备测试页面test.jsp。

<%@ page contentType="text/html; charset=GBK" %>

<%@ page import="java.util.*" %>

<html><head><title>Cluster Test (TOMCAT1|TOMCAT2)</title></head>

<body>

<%

System.out.println(session.getId());

out.println("<br> This is (TOMCAT1|TOMCAT2), SESSION ID:" + session.getId()+"<br>");

%>

</body>

</html>

      不同的Tomcat下放置不同的文件,以便从结果中看出SESSION共享的效果,即:不论是访问TOMCAT1还是TOMCAT2,session都是不变的,同一个sessioin。

在浏览器输入http://localhost/test.jsp,然后不停的刷新页面,即可看到效果了。

我的页面效果:

Windows7 + Nginx + Memcached + Tomcat 集群 session 共享(四) - 落羽 - 落羽
Windows7 + Nginx + Memcached + Tomcat 集群 session 共享(四) - 落羽 - 落羽
结果说明:n1:memcached节点ID,我们在$TOMCAT/conf/context.xml中仅配置了一个节点,ID为“n1”,显示的sessionID就是存储在这个节点上的,后面跟着的tomcatN,表示目前所访问的web应用服务器的名称,这个值在$TOMCAT_HOME/conf/server.xml中的<Engine>标签的jvmRoute属性中已配置。

杨航收集技术资料,分享给大家


 



本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/388391.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

git 版本控制(一)

新建代码库repository 1、在当前目录新建一个git代码库 git init git init projectname 2、下载一个项目&#xff0c;如果已经有了远端的代码&#xff0c;则可以使用clone下载 git clone url 增加/删除/改名文件 1、添加指定文件到暂存区 git add filename 2、添加指定目录到暂…

rollup学习小记

周末在家重构网关的Npm包&#xff0c;用到了rollup&#xff0c;记下笔记 rollup适合库library的开发&#xff0c;而webpack适合应用程序的开发。 rollup也支持tree-shaking&#xff0c;自带的功能。 package.json 也具有 module 字段&#xff0c;像 Rollup 和 webpack 2 这样的…

大数据 vr csdn_VR中的数据可视化如何革命化科学

大数据 vr csdnAstronomy has become a big data discipline, and the ever growing databases in modern astronomy pose many new challenges for analysts. Scientists are more frequently turning to artificial intelligence and machine learning algorithms to analyze…

object-c 日志

printf和NSlog区别 NSLog会自动加上换行符&#xff0c;不需要自己添加换行符&#xff0c;NSLog会加上时间和进程信息&#xff0c;而printf仅将输入的内容输出不会添加任何额外的东西。两者的输入类型也是有区别的NSLog期待NSString*&#xff0c;而printf期待const char *。最本…

计算机真正管理的文件名是什么,计算机题,请大家多多帮忙,谢谢

4、在资源管理器中&#xff0c;若想显示文件名、文件大小和文件类型&#xff0c;应采用什么显示方式。( )A、小图标显示 B、列表显示 C、详细资料显示 D、缩略图显示5、在EXCEL中&#xff0c;可以依据不同要求来提取和汇总数据&#xff0c;4、在资源管理器中&#xff0c;若想显…

小a的排列

链接&#xff1a;https://ac.nowcoder.com/acm/contest/317/G来源&#xff1a;牛客网小a有一个长度为nn的排列。定义一段区间是"萌"的&#xff0c;当且仅当把区间中各个数排序后相邻元素的差为11 现在他想知道包含数x,yx,y的长度最小的"萌"区间的左右端点 …

Xcode做简易计算器

1.创建一个新项目&#xff0c;选择“View-based Application”。输入名字“Cal”&#xff0c;这时会有如下界面。 2.选择Resources->CalViewController.xib并双击&#xff0c;便打开了资源编辑对话框。 3.我们会看到几个窗口。其中有一个上面写着Library&#xff0c;这里…

计算机 编程 教程 pdf,计算机专业教程-第3章编程接口介绍.pdf

下载第3章 编程接口介绍• DB2 UDB应用程序概述• 嵌入S Q L编程• CLI/ODBC应用程序• JAVA应用程序• DAO 、R D O 、A D O应用程序本章将介绍对DB2 UDB 可用的编程方法及其特色&#xff0c;其中一些方法附有简单的例子&#xff0c;在这些例子中&#xff0c;有些并不是只适用…

导入数据库怎么导入_导入必要的库

导入数据库怎么导入重点 (Top highlight)With the increasing popularity of machine learning, many traders are looking for ways in which they can “teach” a computer to trade for them. This process is called algorithmic trading (sometimes called algo-trading)…

windows查看系统版本号

windows查看系统版本号 winR,输入cmd&#xff0c;确定&#xff0c;打开命令窗口&#xff0c;输入msinfo32&#xff0c;注意要在英文状态下输入&#xff0c;回车。然后在弹出的窗口中就可以看到系统的具体版本号了。 winR,输入cmd&#xff0c;确定&#xff0c;打开命令窗口&…

02:Kubernetes集群部署——平台环境规划

1、官方提供的三种部署方式&#xff1a; minikube&#xff1a; Minikube是一个工具&#xff0c;可以在本地快速运行一个单点的Kubernetes&#xff0c;仅用于尝试Kubernetes或日常开发的用户使用。部署地址&#xff1a;https://kubernetes.io/docs/setup/minikube/kubeadm Kubea…

更便捷的画决策分支图的工具_做出更好决策的3个要素

更便捷的画决策分支图的工具Have you ever wondered:您是否曾经想过&#xff1a; How did Google dominate 92.1% of the search engine market share? Google如何占领搜索引擎92.1&#xff05;的市场份额&#xff1f; How did Facebook achieve 74.1% of social media marke…

供来宾访问计算机打开安全吗,计算机安全设置操作手册(22页)-原创力文档

计算机安全设置操作手册ISO27001项目实施电脑配置(以XP为例)账户设置user每台电脑设置administrator和user帐户&#xff1b;管理员账户密码至少 8位, 账户至少6位user将Administrator和user账户以外的其他账户禁用用具体步骤如下&#xff1a;、右击【我的电脑】选择【管理】如图…

Windows半透明窗口开发技巧

Windows半透明窗口开发技巧 www.visual-gear.com 原创技术文章 在windows平台上从窗口绘图有两种方法&#xff1a; 第一种响应窗口的WM_PAINT消息&#xff0c;使用窗口DC进行绘制 第二种是将窗口样式设置为层窗口&#xff0c;即 WS_EX_LAYERED设置为该样式之后窗口将不会产生任…

标识为普通SQL语法

在SQL语句的最前面增加 /*dialect*/转载于:https://www.cnblogs.com/zouhuaxin/p/10333209.html

的界面跳转

在界面的跳转有两种方法&#xff0c;一种方法是先删除原来的界面&#xff0c;然后在插入新的界面&#xff1a;如下代码 if (self.rootViewController.view.superview nil) { [singleDollController.view removeFromSuperview]; [self.view insertSubview:rootViewControlle…

计算性能提升100倍,Uber推出机器学习可视化调试工具

为了让模型迭代过程更加可操作&#xff0c;并能够提供更多的信息&#xff0c;Uber 开发了一个用于机器学习性能诊断和模型调试的可视化工具——Manifold。机器学习在 Uber 平台上得到了广泛的应用&#xff0c;以支持智能决策制定和特征预测&#xff08;如 ETA 预测 及 欺诈检测…

计算机应用基础成教作业,(计算机应用基础成教08A卷1.doc

一、判断题(每空1分&#xff0c;共10分&#xff0c;正确填A错误填B)1、计算机按照用途划分可以分为数字计算机、模拟计算机、数字模拟混合式计算机。()2、微型计算机就是指体积微小的计算机。()3、WindowsXP的窗口是不可改变大小的。( )4、操作系统是用户和计算机之间的接口。…

iPhone程序运行流程浅谈

1. 和大多数语言一样&#xff0c;每一个iPhone应用也都是从主函数开始运行&#xff0c;它的main函数都在XCode的Other Reasource逻辑目录下。 [cpp] view plaincopyprint?UIApplicationMain(argc, argv, nil, nil); [cpp] view plaincopyprint?UIApplicationMain(argc, arg…

Trie树kmpAC自动机后缀数组Manacher

Trie 计数Trie&#xff0c;读清题意很重要 https://vjudge.net/problem/UVALive-5913 kmp AC自动机 模板&#xff1a;https://vjudge.net/problem/UVA-11488 https://vjudge.net/problem/UVA-11019 https://vjudge.net/problem/UVA-11468 https://vjudge.net/problem/UVALive-4…