一、搭建apache server服务器

1、apache server图示:(加载图片要一张一张,所以可以到下面网站下载带图片的word)

http://download.csdn.net/user/y0908105023

环境:linux6.2 apache服务器地址(192.168.181.140)tomcat1(192.168.181.141)tomcat2(192.168.181.142)memcached(192.168.181.131)

2、使用apache的原因

apacheserver在处理静态页面的能力上面要比tomcat服务器好很多,所以,它可以用来响应客户的静态页面,对于那些jsp之类的动态页面交给后台的tomcat服务器进行响应,可以大大的提供效率。

并且,在大型的服务网站中,apache+tomcat+lvs进行负载均衡,可以很有效的承载高并发、高访问。

3、搭建apache server集群

1)、基础知识补充

SELinux:Security Enhencedlinux,是一种权限机制,分为DAC、MAC,MAC就是通过SELinux控制的,可以手动的改动SELinux的设置,命令:

setenforce 0

这样就可以安全的访问了,要想启动就修改,可以修改/etc/selinux/config文件,修改为下边:

2)、搭建apache+tomcat+memcached的图示

搭建此集群的官方网站:

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

3)、粘性session和非粘性session的区别:

粘性session就是指,apache服务器会把某个用户的请求,交给tomcat集群中的一个节点,以后此节点就负责该保存该用户的session,如果此节点挂掉,那么该用户的session也会消失。

非粘性session:这种方式下,通过负载均衡器会根据节点的情况,把用户的请求进行分发,也就是会复制多份session分发给多个节点,这样,如果节点中其中一个session挂掉的话,其它的还能继续工作,也就是只要有一个节点没有挂掉,该用户的信息就不会消失。

4)、采用memcached策略的引言

MSM:memcachedsession manager,是一种高可用的tomcat session支持方案,它可以支持粘性session,也可以支持非粘性session,这里,我采用的是非粘性session,也就是多个tomcat之间的session复制,当然,除了MSM只是一个组件,还可以选择其它的组件,比如memcacheddb,membase。

5)、挑选jar包

根据采用序列化方式的不同,分为kryo、javolution两种方式,下面第一种方式需要的jar包:

6)、配置apach eserver服务器

如果要配置apacheserver服务器,就要安装httpd服务,一般linux默认已经安装好了,如果你的还没有安装好,那就到网上搜一下安装。判断是否安装好:

上图已经安装成功,下面修改配置,加入负载均衡和反向代理配置:

<VirtualHost *:80>

ServerAdmin xxx@126.com

ServerName localhost

ServerAlias   localhost

ProxyPass / balancer://cluster/ stickysession=JSESSIONID nofailover=On

ProxyPassReverse / balancer://cluster/

ErrorLog "logs/apache-error.log"

CustomLog "logs/apache-access.log" common

</VirtualHost>

ProxyRequests Off

<proxy balancer://cluster>

BalancerMember ajp://192.168.181.141:8009 loadfactor=1route=jvm1

BalancerMember ajp://192.168.181.142:8009 loadfactor=1 route=jvm2

</proxy>

在/etc/httpd/conf/httpd.conf的后面加入上面的配置,BalancerMember指的就是负载均衡中的一个节点和所对应的tomcat。保存退出。重启httpd服务。

7)、配置tomcat服务器

安装java环境,并配置环境变量:如下图

安装apache的tomcat,我的版本是apache-tomcat-6.0.37

首先,把第五步挑选的jar包放入到tomcat的安装目录的lib里边,并修改tomcat安装目录下的conf文件下的context.xml,修改如下:

<ManagerclassName="de.javakaffee.web.msm.MemcachedBackupSessionManager"

memcachedNodes="n1:192.168.181.131:12000"

requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"

transcoderFactoryClass="de.javakaffee.web.msm.serializer.kryo.KryoTranscoderFactory"

/>

注意:这个是从下面这个网站中找出的配置,根据你采用的不同,需要修改

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

memcachedNodes是指安装memcached服务器的地方。

然后修改server.xml文件,此文件也在conf目录下,这是其中一部分,注意jvm1跟上边httpd.conf中的配置对应起来

配置好这个之后,就按照这个方法配置第二个tomcat服务器,但是修改server.xml的时候,下面的要换成jvm2.

8)、配置memcached服务器

对于memcached服务器,只需要安装完之后启动就行,启动的端口要与上边保持一致,这样这个memcached服务器才能被找到。

4、测试

如下图,刷新改变了jvm,但并没有使session改变,session中的值也没有丢失。

[置顶] 搭建apache+tomcat+memcached集群环境的更多相关文章

  1. Tomcat:基于Apache+Tomcat的集群搭建

    根据Tomcat的官方文档说明可以知道,使用Tomcat配置集群需要与其它Web Server配合使用才可以完成,典型的有Apache和IIS. 这里就使用Apache+Tomcat方式来完成基于To ...

  2. apache+tomcat分布式集群搭建

    今天搭建apche+tomcat分布式集群,遇到很多问题,在网上找到的很多都不成功,然后和同事一起研究了一下,最终搭建成功了.做个笔记,以备自己以后参考. 1,下载apache.在下载Apache(2 ...

  3. Apache+Tomcat +mod_proxy集群负载均衡及session

      序言: 在玩Apache+Tomcat +mod_jk集群负载均衡及session的时候发现,还有一种方式可以实现,就是网上各位大牛们说的mod_proxy反向代理. 实在弄的我的知识细胞洋洋.实 ...

  4. Nginx+Tomcat+MemCached 集群配置手册

    系统实施文档 Nginx+Tomcat+MemCached 集群配置手册 目    录 第1章   概述 1.1   目标 互联网的快速发展带来了互联网系统的高负载和高可用性, 这要求我们在设计系统架 ...

  5. 基于CentOS与VmwareStation10搭建Oracle11G RAC 64集群环境:2.搭建环境-2.7. 配置资源与参数

    2.7.配置资源与参数 2.7.1. 修改主机名称 [root@linuxrac1 ~]# cd /etc/sysconfig [root@linuxrac1 sysconfig]# vi netwo ...

  6. 基于CentOS与VmwareStation10搭建Oracle11G RAC 64集群环境:2.搭建环境-2.6. 安装Oracle所依赖的必要包

    2.6. 安装Oracle所依赖的必要包 2.6.1. 检查Oracle所依赖的必要rpm包 [root@localhost /]#rpm -q binutils compat-libstdc elf ...

  7. 基于CentOS与VmwareStation10搭建Oracle11G RAC 64集群环境:2.搭建环境-2.5. 配置网络

    2.5. 配置网络 2.5.1. 配置网络 Oracle Rac数据库涉及到公用网络和私有网络,因此要做网络划分和IP地址规划,下表列出了要安装的RAC数据库对应的IP地址.主机名以及网络连接类型: ...

  8. 基于CentOS与VmwareStation10搭建Oracle11G RAC 64集群环境:2.搭建环境-2.4. 安装JDK

    2.4.安装JDK 2.4.1.准备JDK 在百度搜索:JDK下载 2.4.2.上传JDK put E:\软件安装文件\jdk-8u11-linux-x64.rpm /home/linuxrac1/D ...

  9. 基于CentOS与VmwareStation10搭建Oracle11G RAC 64集群环境:2.搭建环境-2.3配置共享磁盘

    2.3.配置共享磁盘 2.3.1.创建共享磁盘 在cmd中进入WMware Workstation 10.0 安装目录: 1.创建存储Oracle Clusterware文件  (Oracle Clu ...

随机推荐

  1. Mini-project # 4 - "Pong"___An Introduction to Interactive Programming in Python"RICE"

    Mini-project #4 - "Pong" In this project, we will build a version of Pong, one of the firs ...

  2. C#变量命名规范

    1.1命名 1.  所有命名必须有意义 2.  成员变量声明在类的顶端,并且每个变量一行 3.  局部变量声明在引用之前 1.1.1  常量命名 1.  常量名用全大写:MAX_PARAMETER_C ...

  3. VM VirtualBox安装Centos6.5

    · · 参考资料:http://www.jb51.net/os/239738.html 如果安装图形界面,内存分配要大于628M 和下图安装选项无关,1.2都可以 界面说明: Install or u ...

  4. pip install 出现报asciii码错误的解决

    原因是pip安装python包会加载我的用户目录,我的用户目录恰好是中文的,ascii不能编码.解决办法是: python目录 Python27\Lib\site-packages 建一个文件site ...

  5. hdu1695 GCD

    http://acm.hdu.edu.cn/showproblem.php?pid=16951 /** 大意: a<=x<=b , c<= y <= d ,求在此范围内 有多少 ...

  6. GridView用法的修改和删除

    (前台) <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="Fa ...

  7. ZOJ 1825 compoud words

    题目大意:输入一串递增的单词序列,需要找出符合条件的单词递增输出,条件是:将一个单词拆成左右两个单词后,能在输入中找到这两个单词.例如单词 alien,可以拆成 a 和 lien,而输入中刚好同时有a ...

  8. 复习知识点:UITableView和UICollectionView的常用属性

    UITableView UICollectionView  //UICollectionViewLayout //UICollectionViewLayout决定了UICollectionView如何 ...

  9. 用newLISP读取Hive的元数据

    思想是通过调用hive -e命令,然后解析返回的结果. 以下的hive.lsp文件是一个样例,提供了读取本地hive数据库名称.表名,表结构和依据hive表的创建语句生成相应的MySQL的创建语句. ...

  10. sc delete 服务名

    当我们在cmd里使用 sc delete  服务名  ,来删除服务的时候,报错误,SC OpenService 失败5:拒绝访问. 这似乎是因为权限不够,解决方法. 首先,我们必须先取得管理员权限,以 ...