[置顶] 搭建apache+tomcat+memcached集群环境
一、搭建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集群环境的更多相关文章
- Tomcat:基于Apache+Tomcat的集群搭建
根据Tomcat的官方文档说明可以知道,使用Tomcat配置集群需要与其它Web Server配合使用才可以完成,典型的有Apache和IIS. 这里就使用Apache+Tomcat方式来完成基于To ...
- apache+tomcat分布式集群搭建
今天搭建apche+tomcat分布式集群,遇到很多问题,在网上找到的很多都不成功,然后和同事一起研究了一下,最终搭建成功了.做个笔记,以备自己以后参考. 1,下载apache.在下载Apache(2 ...
- Apache+Tomcat +mod_proxy集群负载均衡及session
序言: 在玩Apache+Tomcat +mod_jk集群负载均衡及session的时候发现,还有一种方式可以实现,就是网上各位大牛们说的mod_proxy反向代理. 实在弄的我的知识细胞洋洋.实 ...
- Nginx+Tomcat+MemCached 集群配置手册
系统实施文档 Nginx+Tomcat+MemCached 集群配置手册 目 录 第1章 概述 1.1 目标 互联网的快速发展带来了互联网系统的高负载和高可用性, 这要求我们在设计系统架 ...
- 基于CentOS与VmwareStation10搭建Oracle11G RAC 64集群环境:2.搭建环境-2.7. 配置资源与参数
2.7.配置资源与参数 2.7.1. 修改主机名称 [root@linuxrac1 ~]# cd /etc/sysconfig [root@linuxrac1 sysconfig]# vi netwo ...
- 基于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 ...
- 基于CentOS与VmwareStation10搭建Oracle11G RAC 64集群环境:2.搭建环境-2.5. 配置网络
2.5. 配置网络 2.5.1. 配置网络 Oracle Rac数据库涉及到公用网络和私有网络,因此要做网络划分和IP地址规划,下表列出了要安装的RAC数据库对应的IP地址.主机名以及网络连接类型: ...
- 基于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 ...
- 基于CentOS与VmwareStation10搭建Oracle11G RAC 64集群环境:2.搭建环境-2.3配置共享磁盘
2.3.配置共享磁盘 2.3.1.创建共享磁盘 在cmd中进入WMware Workstation 10.0 安装目录: 1.创建存储Oracle Clusterware文件 (Oracle Clu ...
随机推荐
- block, inline和inline-block的区别
display:block元素的特点是:总是在新行上开始:高度,行高以及顶和底边距都可控制:宽度缺省是它的容器的100%,除非设定一个宽度<div>, <p>, <h1& ...
- Nginx 之四: Nginx服务器的压缩功能和缓存功能
在Nginx服务器配置文件中可以通过配置Gzip的使用,可以配置在http块,server 块或者location块中设置,Nginx服务器可以通过ngx_http_gzip_module模块.ngx ...
- vagrant 入门4
7. 打包 Packaging , 8080 end 2. 打包Project $ vagrant package --vagrantfile Vagrantfile.pkg 8. 打包完成后,在工程 ...
- bash:xxx:command not found
前几天在centos6.0上配好了oracle 10g并且能够执行oracle相关命令,但是今天准备往oracle里倒数据时,执行sqlplus 出现bash:command not found [o ...
- spring Annotation 笔记2.1
使用注解替代xml 在前几章的笔记基础上添加使用注解的形式 1.配置applicationContext 添加context schema <?xml version="1.0&quo ...
- Ubuntu上用premake编译GDAL
GDAL的编译脚本呈现出不同平台不同解决方案的百花齐放现状.我是从windows平台开始编译GDAL的,用的自然是nmake.那就是一种每个目录下都需要写makefile文件的构建方法,写的人麻烦,我 ...
- java学习之反射
package com.gh.ref; public class Person { private String name; private int age; private char sex; pr ...
- 解题报告 HDU1944 S-Nim
S-Nim Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Problem De ...
- 正确的 zip 压缩与解压代码
网上流传的zip压缩与解压 的代码有非常大的问题 尽管使用了ant进行压缩与解压,可是任务的流程还是用的java.util.zip 的方式写的,我在使用的过程中遇到了压缩的文件夹结构有误,甚至出现不同 ...
- C# 中datagridview行里面有三个cheeckbox,要控制成三选一。
我之前有试过在cellendedit中处理,可以达成效果,当不符合用户打单的界面要求.该事件是在单元格编辑结束之后, 当用户选中两个checkbox,且焦点不移开时,界面上会出现有两个checkbox ...