memcached组件缓存的对象必须实现序列化

原创 2017年01月03日 15:41:34

在测试用Memcached组件缓存对象的时候,发现总是无法正确存储,保存的地方也没有报告任何异常,从服务器控制台看到的信息也没有保存成功的信息,但是取数据的时候,取出来的也是空的,在获取user对象name属性的地方抛出了空指针异常。很显然没有保存成功,这是为什么呢?昨天用字符串测试都OK,今天用对象就不行了呢?Memcached不号称是内存对象缓存组件吗?

想了下,终于知道为什么了?因为Memcached有独立的服务器端组件,是独立于应用系统的,从客户端(应用系统)保存对象到memcached是必须通过网络传输,而网络传入都是2进制数据,所以必须经过序列化,否则无法存储到Memcached服务器端的缓存中。而昨天测试的字符串成功是因为Java的String对象本身已经实现了序列化接口。于是将需要缓存的User对象序列化处理,然后再次测试,一切OK.

部分测试代码如下:

    public void put(String key,Object value)
    {   
     long start = System.nanoTime();
     memcachedClient.set(key, value);   
        System.out.println("put time :" + (System.nanoTime()-start)/1000000D);
    }

    public User get(String key)
    {   
     long start = System.nanoTime();
     User obj =  (User)memcachedClient.get(key);  
        System.out.println("get time :" + (System.nanoTime()-start)/1000000D);
        return obj;
    }

    public static void main(String[] args) 
    {      
     CacheClient cache = new CacheClient();
     User user = ObjectFactory.createUser(32);
     cache.put("32", user);
     user = cache.get("32");
     System.out.println(user.getName());
    } 

版权声明:本文为博主原创文章,未经博主允许不得转载。

Memcache中实体类序列化的总结

在客户端调用服务器端的Memcache缓存的时候,我需要将一个实体类存入到一个List中,然后将这个List进行缓存,在这个过程中,实体类需要进行 implements java.io.Seriali...

Memcached中对象反序列化和json字符串用jackson解析成对象的比较

如果项目已经发布,如果临时想对某个在Memcached中的key修改值,那么以对象形式存储的话,将很难修改,但如果以字符串形式存储,通过json解析成对象的话,则会方便很多,因为通过界面往Memcac...

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

Memcached的序列化处理保存数据

在我们使用Memcached的时候,有时候需要对其进行序列化处理才能够把自己想要的东西正常的显示出来。 那么,我们可以这么去做; ...

memcached简介及java使用方法

一、 概念 Memcached是danga.com(运营LiveJournal的技术团队)开发的一套分布式内存对象缓存系统,用于在动态系统中减少数据库负载,提升性能。 二、 适用场合 1. 分布...
  • seelye
  • seelye
  • 2013年01月16日 21:37
  • 61783

Simple-Spring-Memcached使用Protobuf序列化Java对象

本文提供一段代码示例,演示如何在Simple-Spring-Memcached中使用Protobuf序列化Java对象。主要解决的问题有: Protobuf序列化Map对象实现SSM中Cache...

memcache 怎么存储的对象

memchache 怎样存储的对象

unserialize的这个问题是由一个emlog论坛用户在使用时报错而发现的 问题表现情况如下: emlog缓存的保存方式是将php的数据对象(数组)序列化(serialize)后以文件的形式存放,

unserialize的这个问题是由一个emlog论坛用户在使用时报错而发现的 问题表现情况如下: emlog缓存的保存方式是将php的数据对象(数组)序列化(serialize)后以文件...
  • farcall
  • farcall
  • 2014年10月05日 14:09
  • 584

unserialize的这个问题是由一个emlog论坛用户在使用时报错而发现的 问题表现情况如下: emlog缓存的保存方式是将php的数据对象(数组)序列化(serialize)后以文件的形式存放,

unserialize的这个问题是由一个emlog论坛用户在使用时报错而发现的 问题表现情况如下: emlog缓存的保存方式是将php的数据对象(数组)序列化(serialize)后以文件...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:memcached组件缓存的对象必须实现序列化
举报原因:
原因补充:

(最多只允许输入30个字)