memcached+nginx+tomcat 负债均衡

最近时间学习了下以memcached作为缓存服务器,nginx和tomcat实现负载均衡,步骤如下:

1.在linux服务器上单独安装了memcached,(网上有很多安装方式).

2.在linux服务器上安装了nigix,conf/nginx.conf 主要配置如下:

#keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;
 
 upstream  xxx{
  server 192.168.88.173:80 weight=8 max_fails=1 fail_timeout=10s;//安装在不同服务器上的tomcat
  server 192.168.88.21:80 weight=10 max_fails=1 fail_timeout=10s;//安装在不同服务器上的tomcat
 }

 

server {
        listen       8888;//我修改了端口号
        server_name  xxx;//与上面的对应

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            #root   html;
            #index  index.html index.htm;
             proxy_pass        http://xxx;//与上面的对应
             proxy_set_header  X-Real-IP  $remote_addr;
             client_max_body_size  100m;
        }

.....//下面的就不拷贝了

 

}

 

3.用tomcat的缓存插件memcached-session-manager 管理session共享,需要将如下的几个包放在tomcat的

lib下:

memcached-session-manager.jar;

msm-javolution-serializer-jodatime-1.3.0.jar;

msm-javolution-serializer-cglib-1.3.0.jar;

memcached-2.4.2.jar;

javolution-5.4.3.1.jar

 

4.修改tomcat下conf/server.xml文件

<Context docBase="xxx" path="" debug="0" reloadable="false">
     <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"

     memcachedNodes="n1:192.168.77.160:11211"   //这里是缓存服务器的地址

     requestUriIgnorePattern=".*\.(png|gif|jpg|css|js)$"//这里是过滤的样式

     sessionBackupAsync="false"

     sessionBackupTimeout="100"

     transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"  

     copyCollectionsForSerialization="false" />
    </Context>

 

5. 在java代码中可以如下操作缓存

import java.util.Date;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.whalin.MemCached.MemCachedClient;
import com.whalin.MemCached.SockIOPool;
 
/**
 * 统一缓存管理中心
 * @author H.Huang
 * Aug 30, 2013
 * 
 * 1.如果试用MemCachedClient.add(...)方法,若value值是一般的java对象,则值会丢失
 * 2.如果要存,则需要对java对象进行序列化
 */
public class MemCachedManager {
	
	private static Logger log = LoggerFactory.getLogger(MemCachedManager.class);
    // 创建全局的唯一实例
    protected static MemCachedClient mcc = new MemCachedClient();
    protected static MemCachedManager memCached = new MemCachedManager();
     
    // 设置与缓存服务器的连接池
    static {
    	try{
		log.info("开始连接MemCached 缓存服务器");
        // 服务器列表和其权重
        String[] servers = { "192.168.77.160:11211" };
        Integer[] weights = { 10 };
  
        // 获取socke连接池的实例对象
        SockIOPool pool = SockIOPool.getInstance();
  
        // 设置服务器信息
        pool.setServers( servers );
        pool.setWeights( weights );
  
        // 设置初始连接数、最小和最大连接数以及最大处理时间
        pool.setInitConn( 5 );
        pool.setMinConn( 5 );
        pool.setMaxConn( 250 );
        pool.setMaxIdle( 1000 * 60 * 60 * 6 );
        // 设置主线程的睡眠时间
        pool.setMaintSleep( 30 );
        // 设置TCP的参数,连接超时等
        pool.setNagle( false );
        pool.setSocketTO( 3000 );
        pool.setSocketConnectTO( 0 );
  
        // 初始化连接池
        pool.initialize();
  
//        mcc.setDefaultEncoding("UTF-8");
        // 压缩设置,超过指定大小(单位为K)的数据都会被压缩
//        mcc.setCompressEnable( true );
//        mcc.setCompressThreshold( 64 * 1024 );
        log.info("连接MemCached 缓存服务器成功");
    	}catch (Exception e) {
    		e.printStackTrace();
    		log.error("连接MemCached 缓存服务器成功");
		}
    }
     
    /**
     * 保护型构造方法,不允许实例化!
     *
     */
    protected MemCachedManager()
    {
         
    }
    /**
     * 获取唯一实例.
     * @return
     */
    public static MemCachedManager getInstance()
    {
        return memCached;
    }
     
    /**
     * 添加一个指定的值到缓存中.
     * @param key
     * @param value
     * @return
     */
    public boolean add(String key, Object value)
    {
    	if(mcc.keyExists(key)){
    		return mcc.replace(key, value);
    	}else{
    		return mcc.add(key, value);
    	}
    }
     
    public boolean add(String key, Object value, Date expiry)
    {
    	if(mcc.keyExists(key)){
    		return mcc.replace(key, value, expiry);
    	}else{
    		return mcc.add(key, value, expiry);
    	}
    }
    
    public boolean replace(String key, Object value)
    {
        return mcc.replace(key, value);
    }
     
    public boolean replace(String key, Object value, Date expiry)
    {
        return mcc.replace(key, value, expiry);
    }
     
    /**
     * 根据指定的关键字获取对象.
     * @param key
     * @return
     */
    public Object get(String key)
    {
        return mcc.get(key);
    }
     
    /** 
     * 删除一个指定的值到缓存中. 
     * 
     * @param key 
     * @param value 
     * @return 
     */ 
    public boolean delete(String key) { 
        return mcc.delete(key); 
    } 
    
    public static void main(String[] args)
    {
    	MemCachedManager cache = MemCachedManager.getInstance();
        long startDate=System.currentTimeMillis();
         cache.add("zf", 18); 
         cache.replace("zf", 19); 
        cache.delete("zf"); 
        long endDate=System.currentTimeMillis();
          
        long nowDate=(endDate-startDate)/1000;
        System.out.println(nowDate);
        System.out.println( " get value : " + cache.get( "zf" ));
    }
}

 6.以上只是一个关键步骤,作为笔记之用!

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值