Nginx+Memcached+Tomcat集群配置

1.   Nginx

Nginx是通过将多个Web Server绑定到同一个IP地址下,以实现多个WebServer间的负载均衡,降低单个Web Server的负荷,以提高整体的性能与稳定性。

安装和配置Nginx的简单方式如下:

1)      下载并解压Nginx到本地目录:http://nginx.org/en/download.html

2)      对Nginx的配置主要是对它的配置文件/conf/nginx.conf的修改。如下链接是nginx.conf配置文件各个属性的详细说明:

http://www.cnblogs.com/xiaogangqq123/archive/2011/03/02/1969006.html

要利用nginx配置Web Server的负载均衡,需要修改的地方有:

a)        在http标签下,配置upstream属性,如:

[plain] view plaincopy

  1. upstream mysvr {
  2. #weigth参数表示权值,权值越高被分配到的几率越大
  3. server   192.168.8.1x:3128  weight=5;
  4. server   192.168.8.2x:80       weight=1;
  5. server   192.168.8.3x:80       weight=6;
  6. }

其中,weight是可选项;若不配置weight,则默认所有的Web Server具有相同的权重。

b)        在http标签下的server标签中,做适当的修改,如:

[plain] view plaincopy

  1. server {
  2. listen       83;
  3. server_name  localhost;
  4. location / {
  5. root   /root;
  6. index  index.jsp;
  7. proxy_pass        http:// mysvr;
  8. proxy_set_header  Host $host:83;
  9. proxy_set_header  X-Real-IP  $remote_addr;
  10. proxy_set_header  X-Forwarded-For $proxy_add_x_forwarded_for;
  11. }
  12. ……
  13. }

其中需要说明的是,server_name和listen分别设置的是用户访问的地址和端口;proxy_pass指定转向的服务器列表(在upstream中定义);proxy_set_header Host设置跳转的http报文中的地址为proxy_pass中指定的地址,同时可以在此处指定端口号,若不指定,则默认会跳到80端口。

其它一些需要设置的属性请参见上述链接中的详细介绍。

3)      配置完成后,在控制台中进入Nginx的根目录,运行nginx或nginx –s start则可启动Nginx服务器,运行nginx –s stop或nginx –s quit可关闭Nginx(不可使用Ctrl+C强制结束)。

2.   Memcached

Memcached是一个key-value映射的缓存系统。在WebApplication中可以利用Memcached完成一些频繁访问对象的缓存。而在分布式的Web Server集群中,由于需要保证各个单独的Web Server中的Session相一致,因此需要利用Memcached来支持。

这里需要使用一个开源项目,即Memcached Session Manager(MSM),如下链接是该开源项目的官网:

http://code.google.com/p/memcached-session-manager/

如下链接是官方的安装和配置向导:

http://code.google.com/p/memcached-session-manager/wiki/SetupAndConfiguration

利用MSM对已经通过Nginx实现集群的Tomcat服务器组进行统一Session存储管理的简单方法如下:

1)      下载、安装、运行Memcached:

Linux版:http://memcached.org/

Windows版:http://code.jellycan.com/memcached/

2)      下载所需的jar包并放置到Tomcat的lib路径下:

a)        memcached-session-manager-${version}.jar,基础包

b)        memcached-session-manager-tc6-${version}.jar(针对Tomcat 6)或者memcached-session-manager-tc7-${version}.jar(针对Tomcat 7),服务器支持包

c)        spymemcached-2.8.12.jar和couchbase-client-1.1.4.jar,缓存支持包

d)        msm-javolution-serializer.jar和javolution-5.4.3.1.jar,序列化支持包

3)      在Tomcat的/conf/context.xml文件中,在根标签<context>下添加如下代码:

[html] view plaincopy

  1. <ManagerclassNameManagerclassName="de.javakaffee.web.msm.MemcachedBackupSessionManager"
  2. memcachedNodes="${tag}:localhost:11211"
  3. requestUriIgnorePattern=".*/.(png|gif|jpg|css|js)$"
  4. sessionBackupAsync="false"
  5. sessionBackupTimeout="100"
  6. transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"
  7. copyCollectionsForSerialization="false"/>

其中${tag}可以替换成任意字符串,作为该WebServer的标记

4)      完成上述配置后,启动Tomcat,若无错误则表示配置成功。通过HttpSession的getId方法获取到session id时,可以看到在id的最后有上述的标记

转载:http://blog.csdn.net/sadfishsc/article/details/9151083

Nginx+Memcached+Tomcat集群配置,布布扣,bubuko.com

时间: 2024-10-05 05:57:16

Nginx+Memcached+Tomcat集群配置的相关文章

nginx+memcached+tomcat集群 session共享完整版

nginx+memcached+tomcat集群 session共享完整版 集群环境 1.nginx版本 nginx-1.6.2.tar.gz 2.jdk 版本 jdk-7u21-linux-x64.tar.gz 3.tomcat 版本  7.0.29 4.memcached 版本 memcached-1.4.22.tar.gz 5. CentOS 6.5 系统采用一台服务做测试 一.nginx安装 安装依赖包 yum -y install gcc gcc-c++ 1.安装pcre库 tar z

【nginx+memcached+tomcat集群 session共享完整版】

集群环境 1.nginx版本 nginx-1.6.2.tar.gz 2.jdk 版本 jdk-7u21-linux-x64.tar.gz 3.tomcat 版本  7.0.29 4.memcached 版本 memcached-1.4.22.tar.gz 5. CentOS 6.5 系统采用一台服务做测试 阅读全文 更多java,java学习,java面试题 http://techfoxbbs.com

搭建了Nginx + Memcached + Tomcat 集群记录

一:环境 Memcached是memcached-1.2.6-win32-bin,下载链接: http://www.jb51.net/softs/205838.html#down Tomcat6: 二:Memcached配置 1. Memcached的安装 将安装包memcached-1.2.6-win32-bin解压到X:/目录下面,重命名为memcached. 打开命令提示符,进入X: /memcached的目录,输入安装命令"memcached.exe –d install",安

nginx+tomcat集群配置(1)---根目录设定和多后端分发配置

前言: 对于javaer而言, nginx+tomcat集群配置, 已然成了web应用部署的主流. 大公司如此, 小公司亦然. 对于个人开发者而言, 资源有限, 往往多个web应用混部于一台服务器(云主机), 如何隔离访问这些服务资源? 彼此又不影响呢? nginx来为你排忧解难, ^_^. 本文将介绍tomcat的简单配置和部署, 以及nginx作为反向代理, 如何分流. 基础架构: 不成文的约定: 1). 一个tomcat容器部署一个webapp应用实例 2). url根目录访问webapp

nginx+tomcat集群配置(4)--rewrite规则和多应用根目录设定思路

前言: nginx中有一块很重要的概念, 就是rewrite规则. 它会对URL进行修改, 然后进行内部的重定向. rewrite授予了nginx更多的自由, 使得后级服务的接入更加地方便. 本文将简单讲述nginx的rewrite规则和原理, 同时讲解下如何借助rewrite实现单tomcat实例/多Web App服务 对应的多域名根目录访问. 案列目标: 首先来谈一下之前对于多Web App服务对应多域名根目录访问的方案. 注: 一个域名对应一个tomcat实例, 一个tomcat实例只包含

tomcat集群配置方案对比

Tomcat集群配置方案大体上可以分为两种配置方案:共享Session型与不同享Session型.当然,其中各有千秋,如果不共享需要上层需要有一定结构进行一致化路由.何谓一致化路由,简单来讲,就是你上次怎么走路,这次还是怎么走,实现的方式有很多种,例如直接按照nginx进行来源或者目的ip进行相应的hash,dns进行地域划分等等,只要能保证上一次和下一次踏入的是"同一条河流"即可. 另一方面,如果不共享需要有一定机制进行共享Session机制,此时共享一般分为两种,找个第三方存储Se

nginx整合tomcat集群并做session共享----测试案例

最近出于好奇心,研究了一下tomcat集群配置,并整合nginx,实现负载均衡,session共享,写篇记录,防止遗忘.---------菜鸡的自我修炼. 说明:博主采用一个web项目同时部署到两台tomcat下,(tomcat-A,tomca-B),使用nginx做反向代理,按照设置的权值,将请求分发到后台的tomcatA/tomcat-B,并且实现session共享. 配置好本地域名指向:修改host文件:添加 127.0.0.1  www.domain.com.cn 新建项目:tiny-d

nginx+双tomcat集群负载均衡(一台机器)

nginx简介 Nginx ("engine x") 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器. Nginx 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,第一个公开版本0.1.0发布于2004年10月4日.其将源代码以类BSD许可证的形式发布,因它的稳定性.丰富的功能集.示例配置文件和低系统资源的消耗而闻名. 下面是采用一台机器nginx+双tomcat集群负载均衡方案.当更新项目时可以停止

Apache+Tomcat集群配置

本文Apache+Tomcat集群配置 基于最新的Apache和Tomcat,具体是2011年4月20日最新的Tomcat和Apache集群和负载均衡配置. 准备环境 Apache[下载地址] 企业框架源码 Apache是http服务器,我们利用其对Tomcat进行负载均衡.目前最新版本为2.2.17,下载地址为http://httpd.apache.org/download.cgi#apache22.如下图: 目前已经出现Apache2.3.11,但是为beta版本,所以没有使用. 下载后直接