.Net客户端监听ZooKeeper节点数据变化
一个很简单的例子,用途是监听zookeeper中某个节点数据的变化,具体请参见代码中的注释
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using ZooKeeperNet; namespace ZooKeeperDemo
{
/// <summary>
/// 监听者实现类
/// </summary>
public class Watcher : IWatcher
{
public void Process(WatchedEvent @event)
{
if (@event.Type == EventType.NodeDataChanged)
{
Console.WriteLine(string.Format("节点:{0},数据发生变化...",@event.Path));
zkHelper.NodeDataChangeListen(@event.Path);
}
}
} /// <summary>
/// zookeeper操作帮助类
/// </summary>
public class zkHelper {
/// <summary>
/// 控制zk只有一个实例
/// </summary>
public static ZooKeeper zk = new ZooKeeper("192.168.1.136:2181", new TimeSpan(, , , ), new Watcher()); /// <summary>
/// 监听指定ZooKeeper指定节点数据变化
/// </summary>
/// <param name="nodePath"></param>
public static void NodeDataChangeListen(string nodePath) {
//调用zk的GetData()方法取数据,当数据有变化时会回调Watcher
byte[] byts = zk.GetData(nodePath, true, null);
//打印出变化后的数据
Console.WriteLine(string.Format("获取到节点{0}的数据为:{1}", nodePath, Encoding.Default.GetString(byts)));
}
} class Program
{
static void Main(string[] args)
{
//操作步骤
//0.导入操作Zookeeper的相关类库(NuGet方式),Install-Package ZooKeeperNet
//1.运行当前控制台程序
//2.在linux中连接到zkCli.sh
//3.用命令行在linux中修改zookeeper中/root/childtwo 节点的数据
//4.修改数据的命令为 set /root/childtwo hello888888
//5.当前控制台程序监测到/root/childtwo节点数据变化,并将变化的数据打印到控制台
//6.重复上面第5和底6个步骤,当前控制台的数据会不断的发生变化 zkHelper.NodeDataChangeListen("/root/childtwo");
Console.ReadKey();
}
}
}
最终运行效果如下图:

.Net客户端监听ZooKeeper节点数据变化的更多相关文章
- Android_通过ContentObserver监听短信数据变化
		
1.简单介绍 在小米等一些机型,无法接收系统发出的短信广播. 仅仅能通过观察者ContentObserver,去监听短信数据的变化 2.SMS数据介绍 content://sms/inbox ...
 - Proxy监听对象的数据变化,处理绑定数据很有用
		
Proxy可以监听对象身上发生了什么事情,并在这些事情发生后执行一些相应的操作.一下子让我们对一个对象有了很强的追踪能力,同时在数据绑定方面也很有用处. }; //interceptor 拦截 var ...
 - 使用state改变的jsx监听不到数据变化的问题
		
当使用state来改变一个组件内部的虚拟dom的时候,该虚拟dom是无法监听到state数据的变化的,他只会绑定state改变dom当时的数据.
 - 如何使用Curator监听zookeeper事件变化
		
掌握zookeeper事件监听机制,非常重要,可以说是跨入了进阶的门槛,只有掌握了如何监听某个节点或路径,我们才能在节点变化后,做一些我们想做的事,包括: 1,配置文件同步 2,主从切换 3,分布式队 ...
 - 小程序的数据监听 用法和vue中的watch一样====使用通配符监听所有自数据字段的变化
		
使用通配符监听所有自数据字段的变化
 - 黎活明8天快速掌握android视频教程--21_监听ContentProvider中数据的变化
		
采用ContentProvider除了可以让其他应用访问当前的app的数据之外,还有可以实现当app的数据发送变化的时候,通知注册了数据变化通知的调用者 其他所有的代码都和第20讲的一样,不同的地方看 ...
 - Android 监听ContentProvider的数据改变
		
今天介绍一下怎么监听ContentProvider的数据改变,主要的方法是:getContext().getContentResolver().notifyChange(uri,null),这行代码是 ...
 - js 实时监听input中值变化
		
注意:用到了jquery需要引入jquery.min.js. 需求: 1.每个地方需要分别打分,总分为100; 2.第一个打分总分为40; 3.第二个打分总分为60. 注意:需要判断null.&quo ...
 - javascript --- 实时监听输入框值的变化
		
实时监听文本框值变化是非常常见的功能,通常最简单的办法就是用keyup,keydown来实现,但是这种方法有两个问题,一个是当直接复制粘贴的时候没法监听到事件,另外一个问题是在移动端,使用删除键删除输 ...
 
随机推荐
- windows
			
1.拷贝远程文件 net use \\10.130.80.62\ipc$ 密码 /user:用户名 xcopy "\\10.130.80.62\G$\yt\apache-tomcat-7.0 ...
 - IOS __ 面试题
			
1.下面四种内部排序算法中哪一种在最差的情况下时间复杂度最高:(B) A.快速排序 B.冒泡排序 C.堆排序 D.归并排序 2.Shell中,将command1的输出作为command2的输入应该 ...
 - webview页面缩放 & 自适应
			
0.webview页面自适应: // 1.LayoutAlgorithm.NARROW_COLUMNS : 适应内容大小// 2.LayoutAlgorithm.SINGLE_COLUMN:适应屏幕, ...
 - ExtJs基础知识总结:自定义弹窗和ComboBox自动联想加载(四)
			
概述 Extjs弹窗可以分为消息弹窗.对话框,这些弹窗的方式ExtJs自带的Ext.Msg.alert就已经可以满足简单消息提示,但是相对复杂的提示,比如如何将Ext.grid.Panel的控件显示嵌 ...
 - Flex Layout Attribute
			
GitHub: https://github.com/StefanKovac/flex-layout-attribute 引入基本的样式,可以更好的布局,可以在线制作: http://progress ...
 - 学习微信小程序之css10外边距
			
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
 - Asp.net中延长session失效时间(2点注意web.config和IIS)
			
一个是软件系统中的web.config: 配置文件web.config 的<system.web>下加上<sessionState mode="InProc" ...
 - Tray - a SharedPreferences replacement for Android
			
一个代替SharedPreferences的开源库, no Editor, no commit() no apply(),因此不存在UI卡顿现象,并且支持多线程,在一个线程中存另一个线程中取数据. h ...
 - java调用sqlldr oracle 安装的bin目录
			
package com.jyc.sqlldr; import java.io.BufferedReader;import java.io.InputStream;import java.io.Inpu ...
 - cocoapods导入shareSDK分享实现
			
这个在官方文档没有说这两个库是必须导入的,但是不导入是会有错误的 pod 'ShareSDK3/ShareSDKConfigurationFile' pod 'ShareSDK3/ShareSDKEx ...