- 使用 Spring Initializr 创建 Spring Boot 应用程序
- 在Spring Boot中配置Cassandra
- 在 Spring Boot 上配置 Tomcat 连接池
- 将Camel消息路由到嵌入WildFly的Artemis上
本文整理了Java中io.fabric8.groups.internal.ZooKeeperGroup
类的一些代码示例,展示了ZooKeeperGroup
类的具体用法。这些代码示例主要来源于Github
/Stackoverflow
/Maven
等平台,是从一些精选项目中提取出来的代码,具有较强的参考意义,能在一定程度帮忙到你。ZooKeeperGroup
类的具体详情如下:
包路径:io.fabric8.groups.internal.ZooKeeperGroup
类名称:ZooKeeperGroup
[英]A utility that attempts to keep all data from all children of a ZK path locally cached. This class will watch the ZK path, respond to update/create/delete events, pull down the data, etc. You can register a listener that will get notified when changes occur.
IMPORTANT - it's not possible to stay transactionally in sync. Users of this class must be prepared for false-positives and false-negatives. Additionally, always use the version number when updating data to avoid overwriting another process' change.
[中]试图将ZK路径的所有子级的所有数据本地缓存的实用程序。这个类将监视ZK路径,响应更新/创建/删除事件,下拉数据,等等。您可以注册一个监听器,当发生更改时会收到通知。
重要信息-不可能保持交易同步。这门课的用户必须为假阳性和假阴性做好准备。此外,在更新数据时始终使用版本号,以避免覆盖另一个进程的更改。
代码示例来源:origin: io.fabric8/fabric-groups
@Override
public <T extends NodeState> Group<T> createGroup(String path, Class<T> clazz) {
return new ZooKeeperGroup<T>(curator, path, clazz);
}
代码示例来源:origin: io.fabric8/fabric-groups
/**
* Clear out current data and begin a new query on the path
*
* @throws Exception errors
*/
public void clearAndRefresh() throws Exception {
clearAndRefresh(false, false);
}
代码示例来源:origin: fabric8io/jube
@Inject
public Replicator(CuratorFramework curator,
ApiMasterKubernetesModel model,
ProcessManager processManager,
@ConfigProperty(name = "REPLICATOR_POLL_TIME", defaultValue = "2000")
long pollTime) {
this.curator = curator;
this.model = model;
this.processManager = processManager;
this.pollTime = pollTime;
System.out.println("Starting the replicator with poll time: " + pollTime);
group = new ZooKeeperGroup<ReplicatorNode>(curator, KUBERNETES_REPLICATOR, ReplicatorNode.class);
groupListener = new GroupListener<ReplicatorNode>() {
@Override
public void groupEvent(Group<ReplicatorNode> group, GroupEvent event) {
onGroupEvent(group, event);
}
};
group.add(groupListener);
group.update(createState());
group.start();
enableTimer();
}
代码示例来源:origin: io.fabric8/fabric-groups
protected void doUpdate(T state) throws Exception {
if (isConnected()) {
if (state == null) {
if (id != null) {
if (id == null) {
refresh(RefreshMode.FORCE_GET_DATA_AND_STAT);
Map<String, T> members = members();
for (Map.Entry<String, T> entry : members.entrySet()) {
T v = entry.getValue();
id = client.create().creatingParentsIfNeeded()
.withMode(CreateMode.EPHEMERAL_SEQUENTIAL)
.forPath(path + "/0", encode(state));
} else {
try {
client.setData().forPath(id, encode(state));
} catch (KeeperException.NoNodeException e) {
id = client.create().creatingParentsIfNeeded()
.withMode(CreateMode.EPHEMERAL_SEQUENTIAL)
.forPath(path + "/0", encode(state));
代码示例来源:origin: io.fabric8/fabric-groups
@Override
public void process(WatchedEvent event) {
try {
if (event.getType() == Event.EventType.NodeDeleted) {
remove(event.getPath());
} else if (event.getType() == Event.EventType.NodeDataChanged) {
offerOperation(new GetDataOperation(ZooKeeperGroup.this, event.getPath()));
}
} catch (Exception e) {
handleException(e);
}
}
};
代码示例来源:origin: jboss-fuse/fabric8
private void processChildren(List<String> children, RefreshMode mode) throws Exception {
List<String> fullPaths = Lists.newArrayList(Lists.transform
(
children,
new Function<String, String>() {
@Override
public String apply(String child) {
return ZKPaths.makePath(path, child);
}
}
));
Set<String> removedNodes = Sets.newHashSet(currentData.keySet());
removedNodes.removeAll(fullPaths);
for (String fullPath : removedNodes) {
remove(fullPath);
}
for (String name : children) {
String fullPath = ZKPaths.makePath(path, name);
if ((mode == RefreshMode.FORCE_GET_DATA_AND_STAT) || !currentData.containsKey(fullPath)) {
getDataAndStat(fullPath);
}
}
}
代码示例来源:origin: io.fabric8.mq/mq-http-discovery
Map<String, ActiveMQNode> members = ZooKeeperGroup.members(curator, "/fabric/registry/clusters/amq/" + groupName, ActiveMQNode.class);
HashSet<String> masters = new HashSet<String>();
StringBuilder buff = new StringBuilder();
代码示例来源:origin: fabric8io/jube
@PreDestroy
public void destroy() {
disableTimer();
group.remove(groupListener);
Closeables.closeQuietly(group);
group = null;
disableTimer();
}
代码示例来源:origin: jboss-fuse/fabric8
@Override
public void process(WatchedEvent event) {
try {
if (event.getType() == Event.EventType.NodeDeleted) {
remove(event.getPath());
} else if (event.getType() == Event.EventType.NodeDataChanged) {
offerOperation(new GetDataOperation(ZooKeeperGroup.this, event.getPath()));
}
} catch (Exception e) {
handleException(e);
}
}
};
代码示例来源:origin: io.fabric8/fabric-groups
private void processChildren(List<String> children, RefreshMode mode) throws Exception {
List<String> fullPaths = Lists.newArrayList(Lists.transform
(
children,
new Function<String, String>() {
@Override
public String apply(String child) {
return ZKPaths.makePath(path, child);
}
}
));
Set<String> removedNodes = Sets.newHashSet(currentData.keySet());
removedNodes.removeAll(fullPaths);
for (String fullPath : removedNodes) {
remove(fullPath);
}
for (String name : children) {
String fullPath = ZKPaths.makePath(path, name);
if ((mode == RefreshMode.FORCE_GET_DATA_AND_STAT) || !currentData.containsKey(fullPath)) {
try {
getDataAndStat(fullPath);
} catch (KeeperException.NoNodeException ignore) {}
}
}
}
代码示例来源:origin: jboss-fuse/fabric8
Map<String, ActiveMQNode> members = ZooKeeperGroup.members(MAPPER, curator, "/fabric/registry/clusters/amq/" + groupName, ActiveMQNode.class);
HashSet<String> masters = new HashSet<String>();
StringBuilder buff = new StringBuilder();
代码示例来源:origin: io.fabric8/fabric-groups
@Override
public <T extends NodeState> Group<T> createGroup(String path, Class<T> clazz) {
return new ZooKeeperGroup<T>(curator, path, clazz);
}
代码示例来源:origin: jboss-fuse/fabric8
/**
* Clear out current data and begin a new query on the path
*
* @throws Exception errors
*/
public void clearAndRefresh() throws Exception {
clearAndRefresh(false, false);
}
代码示例来源:origin: jboss-fuse/fabric8
@Override
public <T extends NodeState> Group<T> createGroup(String path, Class<T> clazz, ThreadFactory threadFactory) {
return new ZooKeeperGroup<T>(curator, path, clazz, threadFactory);
}
代码示例来源:origin: jboss-fuse/fabric8
public void setGroup(final Group<CxfNodeState> group) throws Exception {
this.group = group;
group.add(new GroupListener<CxfNodeState>() {
@Override
public void groupEvent(Group<CxfNodeState> group, GroupEvent event) {
onUpdate(group);
}
});
if (group instanceof ZooKeeperGroup) {
// trigger refresh synchronously so we have up to date state before being used by clients
((ZooKeeperGroup) group).clearAndRefresh(true, true);
}
}
代码示例来源:origin: jboss-fuse/fabric8
@Override
public <T extends NodeState> Group<T> createGroup(String path, Class<T> clazz) {
return new ZooKeeperGroup<T>(curator, path, clazz);
}
代码示例来源:origin: jboss-fuse/fabric8
private void prunePartialState(final T ourState, final String pathId) throws Exception {
if (ourState.uuid != null) {
clearAndRefresh(true, true);
List<ChildData<T>> children = new ArrayList<ChildData<T>>(currentData.values());
for (ChildData<T> child : children) {
if (ourState.uuid.equals(child.getNode().uuid) && !child.getPath().equals(pathId)) {
LOG.debug("Deleting partially created znode: " + child.getPath());
client.delete().guaranteed().forPath(child.getPath());
}
}
}
}
代码示例来源:origin: jboss-fuse/fabric8
@Override
public <T extends NodeState> Group<T> createGroup(String path, Class<T> clazz) {
return new ZooKeeperGroup<T>(curator, path, clazz);
}
代码示例来源:origin: jboss-fuse/fabric8
@Override
public <T extends NodeState> Group<T> createGroup(String path, Class<T> clazz, ThreadFactory threadFactory) {
return new ZooKeeperGroup<T>(curator, path, clazz, threadFactory);
}
代码示例来源:origin: jboss-fuse/fabric8
protected Group<T> createGroup(CuratorFramework client, String path, Class<T> clazz) {
return new ZooKeeperGroup<T>(client, path, clazz);
}
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: Sample data for IPv6? 除了 wireshark 在其网站上提供的内容之外,是否有可以下
我正在寻找可以集成到现有应用程序中并使用多拖放功能的示例或任何现成的解决方案。我在互联网上找到的大多数解决方案在将多个项目从 ListBox 等控件拖放到另一个 ListBox 时效果不佳。谁能指出我
我是 GATE Embedded 的新手,我尝试了简单的示例并得到了 NoClassDefFoundError。首先我会解释我尝试了什么 在 D:\project\gate-7.0 中下载并提取 Ga
是否有像 Eclipse 中的 SWT 示例那样的多合一 JFace 控件示例?搜索(在 stackoverflow.com 上使用谷歌搜索和搜索)对我没有帮助。 如果它是一个独立的应用程序或 ecl
我找不到任何可以清楚地解释如何通过 .net API(特别是 c#)使用谷歌计算引擎的内容。有没有人可以指点我什么? 附言我知道 API 引用 ( https://developers.google.
最近在做公司的一个项目时,客户需要我们定时获取他们矩阵系统的数据。在与客户进行对接时,提到他们的接口使用的目前不常用的BASIC 认证。天呢,它好不安全,容易被不法人监听,咋还在使用呀。但是没办法呀,
最近在做公司的一个项目时,客户需要我们定时获取他们矩阵系统的数据。在与客户进行对接时,提到他们的接口使用的目前不常用的BASIC 认证。天呢,它好不安全,容易被不法人监听,咋还在使用呀。但是没办法呀,
我正在尝试为我的应用程序设计配置文件格式并选择了 YAML。但是,这(显然)意味着我需要能够定义、解析和验证正确的 YAML 语法! 在配置文件中,必须有一个名为 widgets 的集合/序列。 .这
你能给我一个使用 pysmb 库连接到一些 samba 服务器的例子吗?我读过有类 smb.SMBConnection.SMBConnection(用户名、密码、my_name、remote_name
linux服务器默认通过22端口用ssh协议登录,这种不安全。今天想做限制,即允许部分来源ip连接服务器。 案例目标:通过iptables规则限制对linux服务器的登录。 处理方法:编
我一直在寻找任何 PostProjectAnalysisTask 工作代码示例,但没有看。 This页面指出 HipChat plugin使用这个钩子(Hook),但在我看来它仍然使用遗留的 Po
我发现了 GWT 的 CustomScrollPanel 以及如何自定义滚动条,但我找不到任何示例或如何设置它。是否有任何示例显示正在使用的自定义滚动条? 最佳答案 这是自定义 native 滚动条的
我正在尝试开发一个 Backbone Marionette 应用程序,我需要知道如何以最佳方式执行 CRUD(创建、读取、更新和销毁)操作。我找不到任何解释这一点的资源(仅适用于 Backbone)。
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题?通过 editing this post 添加详细信息并澄清问题. 去年关闭。 Improve this
我需要一个提交多个单独请求的 django 表单,如果没有大量定制,我找不到如何做到这一点的示例。即,假设有一个汽车维修店使用的表格。该表格将列出商店能够进行的所有可能的维修,并且用户将选择他们想要进
我有一个 Multi-Tenancy 应用程序。然而,这个相同的应用程序有 liquibase。我需要在我的所有数据源中运行 liquibase,但是我不能使用这个 Bean。 我的应用程序.yml
我了解有关单元测试的一般思想,并已在系统中发生复杂交互的场景中使用它,但我仍然对所有这些原则结合在一起有疑问。 我们被警告不要测试框架或数据库。好的 UI 设计不适合非人工测试。 MVC 框架不包括一
我正在使用 docjure并且它的 select-columns 函数需要一个列映射。我想获取所有列而无需手动指定。 如何将以下内容生成为惰性无限向量序列 [:A :B :C :D :E ... :A
$condition使用说明和 $param在 findByAttributes在 Yii 在大多数情况下,这就是我使用 findByAttributes 的方式 Person::model()->f
我在 Ubuntu 11.10 上安装了 qtcreator sudo apt-get install qtcreator 安装的版本有:QT Creator 2.2.1、QT 4.7.3 当我启动
我是一名优秀的程序员,十分优秀!