基于用户的反馈和需求,OCS近日新增加了对两个Memcached命令的支持:GAT(getAndTouch)以及flush。
首先来看GAT(getAndTouch)命令。它能够在获取数据的同时更新该数据的过期时间,其用法为:getAndTouch(String key, int newExpTime)
这个命令不属于标准Memcached协议中定义的操作,但是在用户使用中,却有着一定的实际意义。通过使用该命令,我们可以更合理有效地利用OCS的缓存空间,使缓存里始终存储的都是真正的热点数据。目前JAVA SPY和JAVA XMEMCACHED客户端已经支持此命令。
Java程序示例片段如下:
mc.set(“myKey”, 5, “value”);//将数据首次set进OCS
while (true) {
//在取回该数据的同时,将其过期时间更新为2秒后
System.out.println(“GAT:” + mc.getAndTouch(“myKey”, 2));
//暂停半秒。模拟在实际业务中,此数据每隔半秒被访问一次
Thread.sleep(500);
}
在上述代码中可以看见,每次通过getAndTouch读取数据的同时都更新了它的过期时间为2秒后。所以当该数据被频繁访问时(2秒之内被不断访问),它将始终不过期;在实际业务使用中,如果该数据的访问频率降低(2秒之内没有被访问),它将会自动过期被淘汰出OCS缓存。
另外一个为flush命令。它属于Memcached标准协议定义的操作,各主流客户端支持此命令。该命令的功能是清除用户当前的OCS缓存实例内所有的数据及统计信息。之前OCS用户是通过在控制台上点击“清空缓存”按钮来实现此功能,现在则可以通过命令方式实现。用法也非常简单:ocs_cache.flush()即可。
在实现上,OCS与Memcached一样,flush命令是将所有数据标识为expired,并不会真正的立刻释放已有数据的内存,而是用存入的新数据重用那些内存,逐步清理缓存中原有过期数据。需要指出的是,OCS完成此命令的时间精度约为1秒以内。在使用中需要注意如下情况:
ocs_cache.flush();
ocs_cache.set(“key”, 0, “value”);
ocs_cache.get(“key”); //这里可能返回NOT FOUND
在这个例子中,第二行set命令执行的时间点和第一行flush命令在同一个自然秒内,则该数据可能会被flush清理,以至于第三行的get无法取得该数据。这种情况需要在程序中注意避免。