本文整理汇总了Java中org.I0Itec.zkclient.IZkDataListener类的典型用法代码示例。如果您正苦于以下问题:Java IZkDataListener类的具体用法?Java IZkDataListener怎么用?Java IZkDataListener使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
IZkDataListener类属于org.I0Itec.zkclient包,在下文中一共展示了IZkDataListener类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: processDataOrChildChange
import org.I0Itec.zkclient.IZkDataListener; //导入依赖的package包/类
private void processDataOrChildChange(WatchedEvent event) {
final String path = event.getPath();
if (event.getType() == EventType.NodeChildrenChanged || event.getType() == EventType.NodeCreated
|| event.getType() == EventType.NodeDeleted) {
Set<IZkChildListener> childListeners = _childListener.get(path);
if (childListeners != null && !childListeners.isEmpty()) {
fireChildChangedEvents(path, childListeners);
}
}
if (event.getType() == EventType.NodeDataChanged || event.getType() == EventType.NodeDeleted
|| event.getType() == EventType.NodeCreated) {
Set<IZkDataListener> listeners = _dataListener.get(path);
if (listeners != null && !listeners.isEmpty()) {
fireDataChangedEvents(event.getPath(), listeners);
}
}
}
示例2: fireDataChangedEvents
import org.I0Itec.zkclient.IZkDataListener; //导入依赖的package包/类
private void fireDataChangedEvents(final String path, Set<IZkDataListener> listeners) {
for (final IZkDataListener listener : listeners) {
_eventThread.send(new ZkEvent("Data of " + path + " changed sent to " + listener) {
@Override
public void run() throws Exception {
// reinstall watch
exists(path, true);
try {
Object data = readData(path, null, true);
listener.handleDataChange(path, data);
} catch (ZkNoNodeException e) {
listener.handleDataDeleted(path);
}
}
});
}
}
示例3: doAddDataListener
import org.I0Itec.zkclient.IZkDataListener; //导入依赖的package包/类
public void doAddDataListener(String path, DataListener listener) {
try {
// 第一步:获取-校验-创建监听器
IZkDataListener iZkDataListener = dataListenerMap.get(listener);
if(iZkDataListener != null){// 已监听
return;
} else {
// 添加外部监听器
Set<DataListener> dataListenerSet = dataListenersMap.get(path);
if(dataListenerSet == null){
dataListenersMap.put(path, dataListenerSet = new ConcurrentHashSet<DataListener>());
}
dataListenerSet.add(listener);
dataListenerMap.put(listener, iZkDataListener = new IZkDataListenerImpl(path));
}
// 第二步:启动监听
client.subscribeDataChanges(path, iZkDataListener);
} catch (Exception e) {
throw new IllegalStateException(e.getMessage(), e);
}
}
示例4: processDataOrChildChange
import org.I0Itec.zkclient.IZkDataListener; //导入依赖的package包/类
private void processDataOrChildChange(WatchedEvent event) {
final String path = event.getPath();
if (event.getType() == EventType.NodeChildrenChanged || event.getType() == EventType.NodeCreated
|| event.getType() == EventType.NodeDeleted) {
Set<IZkChildListener> childListeners = _childListener.get(path);
if (childListeners != null && !childListeners.isEmpty()) {
fireChildChangedEvents(path, childListeners);
}
}
if (event.getType() == EventType.NodeDataChanged || event.getType() == EventType.NodeDeleted
|| event.getType() == EventType.NodeCreated) {
Set<IZkDataListener> listeners = _dataListener.get(path);
if (listeners != null && !listeners.isEmpty()) {
fireDataChangedEvents(event.getPath(), listeners);
}
}
}
示例5: fireDataChangedEvents
import org.I0Itec.zkclient.IZkDataListener; //导入依赖的package包/类
private void fireDataChangedEvents(final String path, Set<IZkDataListener> listeners) {
for (final IZkDataListener listener : listeners) {
_eventThread.send(new ZkEvent("Data of " + path + " changed sent to " + listener) {
@Override public void run() throws Exception {
// reinstall watch
exists(path, true);
try {
Object data = readData(path, null, true);
listener.handleDataChange(path, data);
} catch (ZkNoNodeException e) {
listener.handleDataDeleted(path);
}
}
});
}
}
示例6: subscribeDataChanges
import org.I0Itec.zkclient.IZkDataListener; //导入依赖的package包/类
public void subscribeDataChanges(String path, IZkDataListener listener) {
Set<IZkDataListener> listeners;
synchronized (_dataListener) {
listeners = _dataListener.get(path);
if (listeners == null) {
listeners = new CopyOnWriteArraySet<IZkDataListener>();
_dataListener.put(path, listeners);
}
listeners.add(listener);
}
watchForData(path);
LOG.debug("Subscribed data changes for " + path);
}
示例7: unsubscribeDataChanges
import org.I0Itec.zkclient.IZkDataListener; //导入依赖的package包/类
public void unsubscribeDataChanges(String path, IZkDataListener dataListener) {
synchronized (_dataListener) {
final Set<IZkDataListener> listeners = _dataListener.get(path);
if (listeners != null) {
listeners.remove(dataListener);
}
if (listeners == null || listeners.isEmpty()) {
_dataListener.remove(path);
}
}
}
示例8: hasListeners
import org.I0Itec.zkclient.IZkDataListener; //导入依赖的package包/类
private boolean hasListeners(String path) {
Set<IZkDataListener> dataListeners = _dataListener.get(path);
if (dataListeners != null && dataListeners.size() > 0) {
return true;
}
Set<IZkChildListener> childListeners = _childListener.get(path);
if (childListeners != null && childListeners.size() > 0) {
return true;
}
return false;
}
示例9: numberOfListeners
import org.I0Itec.zkclient.IZkDataListener; //导入依赖的package包/类
public int numberOfListeners() {
int listeners = 0;
for (Set<IZkChildListener> childListeners : _childListener.values()) {
listeners += childListeners.size();
}
for (Set<IZkDataListener> dataListeners : _dataListener.values()) {
listeners += dataListeners.size();
}
listeners += _stateListener.size();
return listeners;
}
示例10: doRemoveDataListener
import org.I0Itec.zkclient.IZkDataListener; //导入依赖的package包/类
public void doRemoveDataListener(String path, DataListener listener) {
try {
// 第一步:移除dataListenerMap中的数据
IZkDataListener iZkDataListener = dataListenerMap.get(listener);
if(iZkDataListener == null){
return;
} else {
dataListenerMap.remove(listener);
// 第二步:移除Set<DataListener>中的数据
Set<DataListener> dataListenerSet = dataListenersMap.get(path);
if(dataListenerSet != null && dataListenerSet.contains(listener)){
dataListenerSet.remove(listener);
}
// 第三步:移除dataListenersMap和childDataMap中的数据
if(dataListenerSet == null || dataListenerSet.isEmpty()){
dataListenersMap.remove(path);
childDataMap.remove(path);
}
}
// 第四步:取消监听
client.unsubscribeDataChanges(path, iZkDataListener);
} catch (Exception e) {
throw new RuntimeException(e.getMessage(), e);
}
}
示例11: readAndListen
import org.I0Itec.zkclient.IZkDataListener; //导入依赖的package包/类
public static NamePairs readAndListen(String zkUrl, String path, IZkDataListener listener) {
ZkClient client = ZkClientHolder.getZkClient(zkUrl);
if (!client.exists(path)) {
return null;
}
String data = ZkClientHolder.data2String(client.readData(path));
if (listener != null) {
client.subscribeDataChanges(path, listener);
}
return new NamePairs(data);
}
示例12: ZkLeaderElector
import org.I0Itec.zkclient.IZkDataListener; //导入依赖的package包/类
@VisibleForTesting
public ZkLeaderElector(String processorIdStr,
ZkUtils zkUtils,
IZkDataListener previousProcessorChangeListener) {
this.processorIdStr = processorIdStr;
this.zkUtils = zkUtils;
this.keyBuilder = zkUtils.getKeyBuilder();
this.hostName = getHostName();
this.previousProcessorChangeListener = previousProcessorChangeListener;
}
示例13: subscribeDataChanges
import org.I0Itec.zkclient.IZkDataListener; //导入依赖的package包/类
public void subscribeDataChanges(String path, IZkDataListener listener) {
Set<IZkDataListener> listeners;
synchronized (_dataListener) {
listeners = _dataListener.get(path);
if (listeners == null) {
listeners = new CopyOnWriteArraySet<>();
_dataListener.put(path, listeners);
}
listeners.add(listener);
}
watchForData(path);
LOG.debug("Subscribed data changes for " + path);
}
示例14: unsubscribeDataChanges
import org.I0Itec.zkclient.IZkDataListener; //导入依赖的package包/类
public void unsubscribeDataChanges(String path, IZkDataListener dataListener) {
synchronized (_dataListener) {
final Set<IZkDataListener> listeners = _dataListener.get(path);
if (listeners != null) {
listeners.remove(dataListener);
}
if (listeners == null || listeners.isEmpty()) {
_dataListener.remove(path);
}
}
}
示例15: hasListeners
import org.I0Itec.zkclient.IZkDataListener; //导入依赖的package包/类
private boolean hasListeners(String path) {
Set<IZkDataListener> dataListeners = _dataListener.get(path);
if (dataListeners != null && dataListeners.size() > 0) {
return true;
}
Set<IZkChildListener> childListeners = _childListener.get(path);
if (childListeners != null && childListeners.size() > 0) {
return true;
}
return false;
}