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 ...
随机推荐
- ubuntu开启SSH服务远程登录
http://blog.csdn.net/jackghq/article/details/54974141 ubuntu开启SSH服务远程登录
- PHP 初学之登录查询小case
说明:如误入本文,请忽略即可,内容仅为记录. 功能:登录(不验证),查询所有列表,删除记录.--很简单,仅为熟悉代码. // MySQL,新建数据库data,导入如下sql ; -- -------- ...
- html学习笔记五
关于服务端和client的校验问题 上述的表格信息填写后发现,即使有些信息不添,依旧能够提交 所以针对此问题,我们要在client进行数据填写信息的增强型校验(必添单元,必须填写有效信息,否则无法提交 ...
- 【Java NIO的深入研究5】字符集Charset
Java 语言被定义为基于Unicode.一个字符实体由二个字节表示(如果是用UCS-2).但众多文件和数据流都是基于其它字符编码并以byte传输,操作文件内容就成了一个问题. 操作一个文件首先要对文 ...
- php对gzip的使用(理论)
gzip是GNU zip的缩写,它是一个GNU自由软件的文件压缩程序,也经常用来表示gzip这种文件格式.软件的作者是Jean-loup Gailly和Mark Adler.1992年10月31日第一 ...
- PHP实现MySQL数据导出为EXCEL(CSV格式)
<?php // 输出Excel文件头,可把user.csv换成你要的文件名 header('Content-Type: application/vnd.ms-excel'); header(' ...
- LoadRunner 调用dll方法
本文主要介绍简单DLL的编写方法及在LoadRunner中局部调用与全局调用DLL方法. 1.动态链接库的编写 在Visual C++6.0开发环境下,打开FileNewProject选项,可以选择W ...
- 4 kafka集群部署及kafka生产者java客户端编程 + kafka消费者java客户端编程
本博文的主要内容有 kafka的单机模式部署 kafka的分布式模式部署 生产者java客户端编程 消费者java客户端编程 运行kafka ,需要依赖 zookeeper,你可以使用已有的 zo ...
- struts2的零配置
最近开始关注struts2的新特性,从这个版本开始,Struts开始使用convention-plugin代替codebehind-plugin来实现struts的零配置.配置文件精简了,的确是简便了 ...
- 关于MFC中的OnPaint和OnDraw
当窗口发生改变后,会产生无效区域,这个无效的区域需要重画. 一般Windows会发送两个消息WM_PAINT(通知客户区 有变化)和WM_NCPAINT(通知非客户区有变化). 非客户区的重画系统自己 ...