在IDEAL下运行测试Memcached缓存数据功能的时候,缓存时间过期之坑

环境信息:
1、 一台运行win7 64位系统机器(本机), 安装ideal 14的IDE, 具有JDK1.8和JDK1.6
2、一台memcached服务器,linux suse 64位系统, JDK1.6

问题详情:
用JAVA代码Memcached缓存数据,不管是通过set(key, value, seconds)还是set(key, value, expirationDate)方式都有问题(要么一设置就返回null,要不就是一直有返回数据),但是通过telnet方式连接memcached服务器,然后对缓存数据设置时间都是OK的。
代码中我测试过程如下(T0我这边测试大概是1000秒):
1、当设置的时间是(当前时间t + 常量T0)之前,set完然后去取缓存,发现返回是null
2、当设置的时间是(当前时间t + 常量T0)之后,set完然后去取缓存,第2天去取发现还是有数据

分析:
1、 是不是我本机ideal环境下的系统时间和memcached服务器系统时间有差导致的
2、 是不是代码中关于memcached有设置相关项或者启动memcached需要指定什么参数

结论:
我发现分析1中系统时间都没有差别,然后我查看memcached文档以及网上资源,也没发现有相关参数,百思不得其解,后面工具打开memcached相关类的时候,发现IDE是jdk1.8编译出来的,去设置了一下ideal的编译环境信息,然后意外发现测试都OK了
但是对事情缘由,我这边还是不太明白,有知道的朋友还望告知一下!

    原文作者:fiwlks
    原文地址: https://segmentfault.com/a/1190000008095609
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞