zoukankan      html  css  js  c++  java
  • memcached 不同客户端的问题

    摘要: memcached-java客户端调用get方法获取数据失败

    主要演示一下在memcached服务器端set数据之后,在客户端调用java api获取数据。不过此过程如果不慎会读取数据失败。

    服务器端添加测试数据

    set username 5
    chencanjian
    STORED
    get username
    VALUE username 5
    chencanjian
    END

    表示在memcached服务器端获取username的值是正常的

    memcached客户端代码如下:

    package com.memcached.util;
    
    import com.danga.MemCached.MemCachedClient;
    import com.danga.MemCached.SockIOPool;
    
    public class MemcachedUtil {
    	
    	protected static MemCachedClient mcc = new MemCachedClient();
    	
    	static {
    		String[] servers = {"192.168.0.100:11211"};
    		Integer[] weights = {3};
    
    		// grab an instance of our connection pool
    		SockIOPool pool = SockIOPool.getInstance();
    
    		// set the servers and the weights
    		pool.setServers(servers);
    		pool.setWeights(weights);
    
    		pool.setInitConn( 5 );
    		pool.setMinConn( 5 );
    		pool.setMaxConn( 250 );
    		pool.setMaxIdle( 1000 * 60 * 60 * 6 );
    
    		// set the sleep for the maint thread
    		// it will wake up every x seconds and
    		// maintain the pool size
    		pool.setMaintSleep( 30 );
    
    		pool.setNagle( false );
    		pool.setSocketTO( 3000 );
    		pool.setSocketConnectTO( 0 );
    
    		// initialize the connection pool
    		pool.initialize();
    	}
    	
    	public static void main(String[] args) {
    		System.out.println(mcc.get("username"));
    	}
    }

    执行main方法后,出现了读取异常,异常如下

    75 [main] ERROR com.danga.MemCached.MemCachedClient - ++++ exception thrown while trying to get object from cache for key: username
    76 [main] ERROR com.danga.MemCached.MemCachedClient invalid stream header: 6C696C65
    java.io.StreamCorruptedException: invalid stream header: 6C696C65
    	at java.io.ObjectInputStream.readStreamHeader(ObjectInputStream.java:801)
    	at java.io.ObjectInputStream.<init>(ObjectInputStream.java:298)

    失败的原因为:

    在memcached中,不同的客户端在set或者add值时,对命令的第二个参数的使用是不一致的
    <command name> <key> <flags> <exptime> <bytes>
    <data block>
    JAVA客户端flags字段填写的都是32,不是32的是无法通过java客户端get出来的
    所以在通过memcached服务器端进行数据set时,需要显示指定flags值为32
    或者通过java客户端提供的接口set数据
  • 相关阅读:
    复合文档(Compound Document)读写栗子
    JavaScript修改IE注册表
    mysql_real_connect 端口号说明
    _beginthreadex创建线程,立即执行?
    Access 是/否 字段
    JavaScript格式化日期输出
    STM32-串行SPI nor
    全球唯一标识符:GUID在线生成
    如何交叉编译Python到ARM-Linux平台(转)
    CMOS Sensor的调试经验分享(转)
  • 原文地址:https://www.cnblogs.com/chencanjian/p/7088268.html
Copyright © 2011-2022 走看看