OCS支持新命令:GAT(getAndTouch)以及flush

简介:

 

基于用户的反馈和需求,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无法取得该数据。这种情况需要在程序中注意避免。

 

相关文章
|
5月前
|
XML JSON Java
老程序员分享:JAVA对象转换JSON
老程序员分享:JAVA对象转换JSON
457 0
|
6月前
|
NoSQL Linux 网络安全
Redis 客户端工具
Redis 客户端工具
227 0
|
关系型数据库 MySQL OLTP
[MySQL FAQ]系列 — 为什么要关闭query cache,如何关闭
[MySQL FAQ]系列 — 为什么要关闭query cache,如何关闭
142 0
|
SQL 存储 缓存
[MySQL FAQ]系列 — 线上环境到底要不要开启query cache
[MySQL FAQ]系列 — 线上环境到底要不要开启query cache
104 0
|
关系型数据库 MySQL 程序员
FAQ系列 | InnoDB Monitor被自动打开
FAQ系列 | InnoDB Monitor被自动打开
poi往word单元格插入图片,支持本地图片和网络图片
最近word导出时需要导出图片,在网上翻了会就发现了好心人分享的代码,但是只支持本地文件读取,我们项目需要从其他服务器获取图片,那肯定得使用网络方式了,于是在源代码上进行了完善,可接收本地和网络两种url方式。
591 1
|
索引
ElasticSearch _version字段的作用
ElasticSearch _version字段的作用
215 0
|
数据采集 存储 API
Elasticsearch 运行时类型 Runtime fields 深入详解
1、实战问题 实战业务中,遇到数据导入后,但发现缺少部分必要字段,一般怎么解决? 比如:emotion 代表情感值,取值范围为:0-1000。 其中:300-700 代表中性;0-300 代表负面;700-1000 代表正面。 但实际业务中,我们需要:中性:0;负面:-1;正面:1。 如何实现呢?
617 0
Elasticsearch 运行时类型 Runtime fields 深入详解
|
SQL 存储 数据库
SQL Server Replication的分发服务器的快照文件夹位置查找
原文:SQL Server Replication的分发服务器的快照文件夹位置查找   SQL Server分发服务器配置中,需要配置快照文件夹(Snapshot Folder),用于存储发布的数据和架构文件的工作目录,那么如何查找当前SQL Server数据库服务器的分发服务器的快照文件夹位置呢?...
973 0