08.Curator缓存
1.Path Cache
- PathChildrenCache - Path Cache主要实现类
- PathChildrenCacheEvent - 监听触发时的事件对象,包含事件相关信息
- PathChildrenCacheListener - 监听器接口
- ChildData - 子节点数据封装类
public PathChildrenCache(CuratorFramework client, String path, boolean cacheData)
public class PathCacheTest{private static final String PATH = "/example/cache";public static void main(String[] args) throws Exception{CuratorFramework client = CuratorFrameworkFactory.newClient("127.0.0.1:2181", new ExponentialBackoffRetry(1000, 3));client.start();PathChildrenCache cache = new PathChildrenCache(client, PATH, true);cache.start();PathChildrenCacheListener cacheListener = new PathChildrenCacheListener(){@Overridepublic void childEvent(CuratorFramework client, PathChildrenCacheEvent event) throws Exception{System.out.println("事件类型:" + event.getType());System.out.println("节点数据:" + event.getData().getPath() + " = " + new String(event.getData().getData()));}};cache.getListenable().addListener(cacheListener);client.create().forPath("/example/cache/test01", "01".getBytes());Thread.sleep(10);client.create().forPath("/example/cache/test02", "02".getBytes());Thread.sleep(10);client.setData().forPath("/example/cache/test01", "01_V2".getBytes());Thread.sleep(10);for (ChildData data : cache.getCurrentData()){System.out.println("getCurrentData:" + data.getPath() + " = " + new String(data.getData()));}client.delete().forPath("/example/cache/test01");Thread.sleep(10);client.delete().forPath("/example/cache/test02");Thread.sleep(1000 * 5);cache.close();client.close();System.out.println("OK!");}}
事件类型:CHILD_ADDED节点数据:/example/cache/test01 = 01事件类型:CHILD_ADDED节点数据:/example/cache/test02 = 02事件类型:CHILD_UPDATED节点数据:/example/cache/test01 = 01_V2getCurrentData:/example/cache/test01 = 01_V2getCurrentData:/example/cache/test02 = 02事件类型:CHILD_REMOVED节点数据:/example/cache/test01 = 01_V2事件类型:CHILD_REMOVED节点数据:/example/cache/test02 = 02OK!
2.Node Cache
- NodeCache - Node Cache实现类
- NodeCacheListener - 节点监听器
- ChildData - 节点数据
public class NodeCacheExample{private static final String PATH = "/example/cache";public static void main(String[] args) throws Exception{CuratorFramework client = CuratorFrameworkFactory.newClient("127.0.0.1:2181", new ExponentialBackoffRetry(1000, 3));client.start();final NodeCache cache = new NodeCache(client, PATH);cache.start();NodeCacheListener listener = new NodeCacheListener(){@Overridepublic void nodeChanged() throws Exception{ChildData data = cache.getCurrentData();if (null != data){System.out.println("节点数据:" + new String(cache.getCurrentData().getData()));}else{System.out.println("节点被删除!");}}};cache.getListenable().addListener(listener);client.create().creatingParentsIfNeeded().forPath(PATH, "01".getBytes());Thread.sleep(10);client.setData().forPath(PATH, "02".getBytes());Thread.sleep(10);client.delete().deletingChildrenIfNeeded().forPath(PATH);Thread.sleep(1000 * 2);cache.close();client.close();System.out.println("OK!");}}
节点数据:01节点数据:02节点被删除!OK!
3.Tree Node
- TreeCache - Tree Cache实现类
- TreeCacheListener - 监听器类
- TreeCacheEvent - 触发的事件类
- ChildData - 节点数据
public class TreeCacheExample{private static final String PATH = "/example/cache";public static void main(String[] args) throws Exception{CuratorFramework client = CuratorFrameworkFactory.newClient("127.0.0.1:2181", new ExponentialBackoffRetry(1000, 3));client.start();TreeCache cache = new TreeCache(client, PATH);cache.start();TreeCacheListener listener = new TreeCacheListener(){@Overridepublic void childEvent(CuratorFramework client, TreeCacheEvent event) throws Exception{System.out.println("事件类型:" + event.getType() + " | 路径:" + event.getData().getPath());}};cache.getListenable().addListener(listener);client.create().creatingParentsIfNeeded().forPath("/example/cache/test01/child01");client.setData().forPath("/example/cache/test01", "12345".getBytes());client.delete().deletingChildrenIfNeeded().forPath(PATH);Thread.sleep(1000 * 2);cache.close();client.close();System.out.println("OK!");}}
事件类型:NODE_ADDED | 路径:/example/cache事件类型:NODE_ADDED | 路径:/example/cache/test01事件类型:NODE_ADDED | 路径:/example/cache/test01/child01事件类型:NODE_UPDATED | 路径:/example/cache/test01事件类型:NODE_REMOVED | 路径:/example/cache/test01/child01事件类型:NODE_REMOVED | 路径:/example/cache/test01事件类型:NODE_REMOVED | 路径:/example/cacheOK!
-------------------------------------------------------------------------------------------------------------------------------
08.Curator缓存的更多相关文章
- HTML5学习总结-08 应用缓存(Application Cache)
一 应用缓存(Application Cache) 1 应用缓存 HTML5 引入了应用程序缓存,这意味着 web 应用可进行缓存,并可在没有因特网连接时进行访问. 应用程序缓存为应用带来三个优势: ...
- 08 redis缓存穿透、缓存雪崩、缓存击穿
Redis缓存的使用,极大的提升了应用程序的性能和效率,特别是数据查询方面.但同时,它也带来了一些问题.其中,最要害的问题,就是数据的一致性问题,从严格意义上讲,这个问题无解.如果对数据的一致性要求很 ...
- Redis 慢日志
redis的slowlog是redis用于记录记录慢查询执行时间的日志系统.由于slowlog只保存在内存中,因此slowlog的效率很高,完全不用担心会影响到redis的性能.Slowlog是Red ...
- 08.Hibernate的一级缓存-->>Session
Hibernate提供了两种缓存: 1.一级缓存:自带的不可卸载的,一级缓存的生命周期与Session一致,一级缓存成为Session级别的缓存 2.二级缓存:默认没有开启,需要手动配置才可以使用,二 ...
- PowerDotNet平台化软件架构设计与实现系列(08):缓存平台
几乎所有后端应用都会或多或少用到缓存,尤其是分布式缓存服务,以及和本地缓存构造的二级缓存.根据我们一贯的节约代码的风格,为了复用的目标,抽象出缓存平台,进行缓存管理. 考虑到很多公司都会自己造或者直接 ...
- SpringBoot2.0 基础案例(08):集成Redis数据库,实现缓存管理
一.Redis简介 Spring Boot中除了对常用的关系型数据库提供了优秀的自动化支持之外,对于很多NoSQL数据库一样提供了自动化配置的支持,包括:Redis, MongoDB, Elastic ...
- Apache Curator获得真正的
Apache Curator获得真正的 Curator它是Netflix一家公司来源Zookeeper顾客,与Zookeeper相比于提供本地客户端,Curator的抽象层次更高,简化了Zookeep ...
- Apache Curator入门实战
Apache Curator入门实战 Curator是Netflix公司开源的一个Zookeeper客户端,与Zookeeper提供的原生客户端相比,Curator的抽象层次更高,简化了Zookeep ...
- Windows下Redis缓存服务器的使用 .NET StackExchange.Redis Redis Desktop Manager
Redis缓存服务器是一款key/value数据库,读110000次/s,写81000次/s,因为是内存操作所以速度飞快,常见用法是存用户token.短信验证码等 官网显示Redis本身并没有Wind ...
随机推荐
- 获取platformVersion、deviceName、appPackage
命令获取如下: 手机与电脑连接 devicename: adb devices platformversion : adb shell getprop ro.build.version.re ...
- 第二百九十一节,RabbitMQ多设备消息队列-安装与简介
RabbitMQ多设备消息队列-安装与简介 RabbitMQ简介 解释RabbitMQ,就不得不提到AMQP(Advanced Message Queuing Protocol)协议. AMQP协议是 ...
- windows下安装TA-Lib库
步骤一: https://sourceforge.net/projects/ta-lib/files/ta-lib/0.4.0/ta-lib-0.4.0-msvc.zip/download?use_m ...
- linux下简单好用的端口映射转发工具rinetd 转
linux下简单好用的工具rinetd,实现端口映射/转发/重定向 官网地址http://www.boutell.com/rinetd 软件下载 wget http://www.boutell.com ...
- Discuz论坛post登录C#源码
总结: loginhash formhash 表单参数 seccode 参数最重要 全局 的 获取验证码 判断验证码 到最后提交登录 它都有存在 ,seccode==idhash COOKIE自动维 ...
- Oracle从字符串资源中得到想要的数据分析
[oracle]从字符串资源中得到想要的数据分析需求:订单分析,按照游戏,帐号级别,游戏帐号职业,区服,价格区间分析各款交易数据走势 .目标:订单表(order)处理分析:订单中可以直接读到的标示有游 ...
- 你与论文达人只差一个MathType的距离
在理工类的论文文档中总是少不了数学公式的出现,各种符号夹杂在期间导致论文在编写时总是会出现各种各样的问题.但是这些问题在论文达人们手中全都不是事儿!分分钟搞定你数学公式上出现的问题!论文达人们是怎么搞 ...
- 帝国CMS 列表模板list.var支持程序代码
1.增加模板时list.var模板需要勾选“使用程序代码”选项.如图: 2.直接添加PHP代码,不需要加<?和?>程序开始和结束标记. 3.字段值数组变量为$r,对应的字段变量为$r[字段 ...
- hdu 4849 最短路 西安邀请赛 Wow! Such City!
http://acm.hdu.edu.cn/showproblem.php?pid=4849 会有非常多奇怪的Wa的题.当初在西安就不知道为什么wa,昨晚做了,由于一些Sb错误也wa了非常久.这会儿怎 ...
- GIS-006-ArcGIS API 空间关系
Name Description 解释 SPATIAL_REL_CONTAINS Part or all of a feature from feature class 1 is contained ...