- 使用 Spring Initializr 创建 Spring Boot 应用程序
- 在Spring Boot中配置Cassandra
- 在 Spring Boot 上配置 Tomcat 连接池
- 将Camel消息路由到嵌入WildFly的Artemis上
本文整理了Java中com.yahoo.pulsar.zookeeper.ZooKeeperCache
类的一些代码示例,展示了ZooKeeperCache
类的具体用法。这些代码示例主要来源于Github
/Stackoverflow
/Maven
等平台,是从一些精选项目中提取出来的代码,具有较强的参考意义,能在一定程度帮忙到你。ZooKeeperCache
类的具体详情如下:
包路径:com.yahoo.pulsar.zookeeper.ZooKeeperCache
类名称:ZooKeeperCache
暂无
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker-common
public ZooKeeper getZooKeeper() {
return this.cache.getZooKeeper();
}
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
private void initZK() throws PulsarServerException {
String[] paths = new String[] { MANAGED_LEDGER_ROOT, OWNER_INFO_ROOT, LOCAL_POLICIES_ROOT };
// initialize the zk client with values
try {
ZooKeeper zk = cache.getZooKeeper();
for (String path : paths) {
if (cache.exists(path)) {
continue;
}
try {
ZkUtils.createFullPathOptimistic(zk, path, new byte[0], Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
} catch (KeeperException.NodeExistsException e) {
// Ok
}
}
} catch (Exception e) {
LOG.error(e.getMessage(), e);
throw new PulsarServerException(e);
}
}
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
private boolean isBrokerActive(String candidateBroker) throws KeeperException, InterruptedException {
Set<String> activeNativeBrokers = pulsar.getLocalZkCache().getChildren(LoadManager.LOADBALANCE_BROKERS_ROOT);
for (String brokerHostPort : activeNativeBrokers) {
if (candidateBroker.equals("http://" + brokerHostPort)) {
if (LOG.isDebugEnabled()) {
LOG.debug("Broker {} found for SLA Monitoring Namespace", brokerHostPort);
}
return true;
}
}
if (LOG.isDebugEnabled()) {
LOG.debug("Broker not found for SLA Monitoring Namespace {}",
candidateBroker + ":" + config.getWebServicePort());
}
return false;
}
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
@POST
@Path("/{cluster}")
@ApiOperation(value = "Update the configuration for a cluster.", notes = "This operation requires Pulsar super-user privileges.")
@ApiResponses(value = { @ApiResponse(code = 204, message = "Cluster has been updated"),
@ApiResponse(code = 403, message = "Don't have admin permission"),
@ApiResponse(code = 404, message = "Cluster doesn't exist") })
public void updateCluster(@PathParam("cluster") String cluster, ClusterData clusterData) {
validateSuperUserAccess();
validatePoliciesReadOnlyAccess();
try {
String clusterPath = path("clusters", cluster);
globalZk().setData(clusterPath, jsonMapper().writeValueAsBytes(clusterData), -1);
globalZkCache().invalidate(clusterPath);
log.info("[{}] Updated cluster {}", clientAppId(), cluster);
} catch (KeeperException.NoNodeException e) {
log.warn("[{}] Failed to update cluster {}: Does not exist", clientAppId(), cluster);
throw new RestException(Status.NOT_FOUND, "Cluster does not exist");
} catch (Exception e) {
log.error("[{}] Failed to update cluster {}", clientAppId(), cluster, e);
throw new RestException(e);
}
}
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
/**
* If load balancing is enabled, load shedding is enabled by default unless forced off by setting a flag in global
* zk /admin/flags/load-shedding-unload-disabled
*
* @return false by default, unload is allowed in load shedding true if zk flag is set, unload is disabled
*/
public static boolean isUnloadDisabledInLoadShedding(final PulsarService pulsar) {
if (!pulsar.getConfiguration().isLoadBalancerEnabled()) {
return true;
}
boolean unloadDisabledInLoadShedding = false;
try {
unloadDisabledInLoadShedding = pulsar.getGlobalZkCache()
.exists(AdminResource.LOAD_SHEDDING_UNLOAD_DISABLED_FLAG_PATH);
} catch (Exception e) {
log.warn("Unable to fetch contents of [{}] from global zookeeper",
AdminResource.LOAD_SHEDDING_UNLOAD_DISABLED_FLAG_PATH, e);
}
return unloadDisabledInLoadShedding;
}
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
private static CompletableFuture<PartitionedTopicMetadata> fetchPartitionedTopicMetadataAsync(PulsarService pulsar,
String path) {
CompletableFuture<PartitionedTopicMetadata> metadataFuture = new CompletableFuture<>();
try {
// gets the number of partitions from the zk cache
pulsar.getGlobalZkCache().getDataAsync(path, new Deserializer<PartitionedTopicMetadata>() {
@Override
public PartitionedTopicMetadata deserialize(String key, byte[] content) throws Exception {
return jsonMapper().readValue(content, PartitionedTopicMetadata.class);
}
}).thenAccept(metadata -> {
// if the partitioned topic is not found in zk, then the topic is not partitioned
if (metadata.isPresent()) {
metadataFuture.complete(metadata.get());
} else {
metadataFuture.complete(new PartitionedTopicMetadata());
}
}).exceptionally(ex -> {
metadataFuture.completeExceptionally(ex);
return null;
});
} catch (Exception e) {
metadataFuture.completeExceptionally(e);
}
return metadataFuture;
}
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
public void close() {
if (this.rackawarePolicyZkCache != null) {
this.rackawarePolicyZkCache.stop();
}
if (this.clientIsolationZkCache != null) {
this.clientIsolationZkCache.stop();
}
}
}
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
@Override
public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain)
throws IOException, ServletException {
try {
String minApiVersion = pulsar.getLocalZkCache().getData(MIN_API_VERSION_PATH,
Deserializers.STRING_DESERIALIZER).orElseThrow(() -> new KeeperException.NoNodeException());
String requestApiVersion = getRequestApiVersion(req);
if (shouldAllowRequest(req.getRemoteAddr(), minApiVersion, requestApiVersion)) {
// Allow the request to continue by invoking the next filter in
// the chain.
chain.doFilter(req, resp);
} else {
// The client's API version is less than the min supported,
// reject the request.
HttpServletResponse httpResponse = (HttpServletResponse) resp;
HttpServletResponseWrapper respWrapper = new HttpServletResponseWrapper(httpResponse);
respWrapper.sendError(HttpServletResponse.SC_BAD_REQUEST, "Unsuported Client version");
}
} catch (Exception ex) {
LOG.warn("[{}] Unable to safely determine client version eligibility. Allowing request",
req.getRemoteAddr());
chain.doFilter(req, resp);
}
}
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
globalZkCache().invalidate(namespacePath);
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
private void setDynamicConfigurationToZK(String zkPath, Map<String, String> settings) throws IOException {
byte[] settingBytes = ObjectMapperFactory.getThreadLocal().writeValueAsBytes(settings);
try {
if (pulsar.getLocalZkCache().exists(zkPath)) {
pulsar.getZkClient().setData(zkPath, settingBytes, -1);
} else {
ZkUtils.createFullPathOptimistic(pulsar.getZkClient(), zkPath, settingBytes, Ids.OPEN_ACL_UNSAFE,
CreateMode.PERSISTENT);
}
} catch (Exception e) {
log.warn("Got exception when writing to ZooKeeper path [{}]:", zkPath, e);
}
}
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
protected CompletableFuture<LookupResult> createLookupResult(String candidateBroker) throws Exception {
CompletableFuture<LookupResult> lookupFuture = new CompletableFuture<>();
try {
checkArgument(StringUtils.isNotBlank(candidateBroker), "Lookup broker can't be null " + candidateBroker);
URI uri = new URI(candidateBroker);
String path = String.format("%s/%s:%s", LoadManager.LOADBALANCE_BROKERS_ROOT, uri.getHost(),
uri.getPort());
pulsar.getLocalZkCache().getDataAsync(path, pulsar.getLoadManager().get().getLoadReportDeserializer()).thenAccept(reportData -> {
if (reportData.isPresent()) {
ServiceLookupData lookupData = reportData.get();
lookupFuture.complete(new LookupResult(lookupData.getWebServiceUrl(),
lookupData.getWebServiceUrlTls(), lookupData.getPulsarServiceUrl(),
lookupData.getPulsarServiceUrlTls()));
} else {
lookupFuture.completeExceptionally(new KeeperException.NoNodeException(path));
}
}).exceptionally(ex -> {
lookupFuture.completeExceptionally(ex);
return null;
});
} catch (Exception e) {
lookupFuture.completeExceptionally(e);
}
return lookupFuture;
}
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
private void saveQuotaToZnode(String zpath, ResourceQuota quota) throws Exception {
ZooKeeper zk = this.localZkCache.getZooKeeper();
if (zk.exists(zpath, false) == null) {
try {
ZkUtils.createFullPathOptimistic(zk, zpath, new byte[0], Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT);
} catch (KeeperException.NodeExistsException e) {
}
}
zk.setData(zpath, this.jsonMapper.writeValueAsBytes(quota), -1);
}
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
/**
* Checks whether the broker is allowed to do read-write operations based on the existence of a node in global
* zookeeper.
*
* @throws WebApplicationException
* if broker has a read only access if broker is not connected to the global zookeeper
*/
public void validatePoliciesReadOnlyAccess() {
boolean arePoliciesReadOnly = true;
try {
arePoliciesReadOnly = globalZkCache().exists(POLICIES_READONLY_FLAG_PATH);
} catch (Exception e) {
log.warn("Unable to fetch contents of [{}] from global zookeeper", POLICIES_READONLY_FLAG_PATH, e);
throw new RestException(e);
}
if (arePoliciesReadOnly) {
log.debug("Policies are read-only. Broker cannot do read-write operations");
throw new RestException(Status.FORBIDDEN, "Broker is forbidden to do read-write operations");
} else {
// Make sure the broker is connected to the global zookeeper before writing. If not, throw an exception.
if (globalZkCache().getZooKeeper().getState() != States.CONNECTED) {
log.debug("Broker is not connected to the global zookeeper");
throw new RestException(Status.PRECONDITION_FAILED,
"Broker needs to be connected to global zookeeper before making a read-write operation");
} else {
// Do nothing, just log the message.
log.debug("Broker is allowed to make read-write operations");
}
}
}
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
globalZkCache().invalidate(propertyPath);
log.info("[{}] updated property {}", clientAppId(), property);
} catch (RestException re) {
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
@GET
@Path("/{cluster}")
@ApiOperation(value = "Get the list of active brokers (web service addresses) in the cluster.", response = String.class, responseContainer = "Set")
@ApiResponses(value = { @ApiResponse(code = 403, message = "Don't have admin permission"),
@ApiResponse(code = 404, message = "Cluster doesn't exist") })
public Set<String> getActiveBrokers(@PathParam("cluster") String cluster) throws Exception {
validateSuperUserAccess();
validateClusterOwnership(cluster);
try {
// Add Native brokers
return pulsar().getLocalZkCache().getChildren(LoadManager.LOADBALANCE_BROKERS_ROOT);
} catch (Exception e) {
LOG.error(String.format("[%s] Failed to get active broker list: cluster=%s", clientAppId(), cluster), e);
throw new RestException(e);
}
}
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker-common
private void initZK() throws PulsarServerException {
String[] paths = new String[] { CLUSTERS_ROOT, POLICIES_ROOT };
// initialize the zk client with values
try {
ZooKeeper zk = cache.getZooKeeper();
for (String path : paths) {
try {
if (zk.exists(path, false) == null) {
ZkUtils.createFullPathOptimistic(zk, path, new byte[0], Ids.OPEN_ACL_UNSAFE,
CreateMode.PERSISTENT);
}
} catch (KeeperException.NodeExistsException e) {
// Ok
}
}
} catch (Exception e) {
LOG.error(e.getMessage(), e);
throw new PulsarServerException(e);
}
}
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
try {
globalZk().delete(path, -1);
globalZkCache().invalidate(path);
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
protected ZooKeeper globalZk() {
return pulsar().getGlobalZkCache().getZooKeeper();
}
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
String clusterPath = path("clusters", cluster);
globalZk().delete(clusterPath, -1);
globalZkCache().invalidate(clusterPath);
log.info("[{}] Deleted cluster {}", clientAppId(), cluster);
} catch (KeeperException.NoNodeException e) {
代码示例来源:origin: com.yahoo.pulsar/pulsar-broker
/**
* Disable bundle in local cache and on zk
*
* @param bundle
* @throws Exception
*/
public void disableOwnership(NamespaceBundle bundle) throws Exception {
String path = ServiceUnitZkUtils.path(bundle);
updateBundleState(bundle, false);
localZkCache.getZooKeeper().setData(path, jsonMapper.writeValueAsBytes(selfOwnerInfoDisabled), -1);
ownershipReadOnlyCache.invalidate(path);
}
我正在使用 Yahoo! 创建一些 RSS!管道,但更新间隔太长。我怎样才能改变它?如果不能改变,究竟是多久? 最佳答案 管道文档说它honors the standard HTTP expirati
我有一项使用 Yahoo!财务表yahoo.finance.xchange .今天早上我注意到它已经停止工作,因为突然 Yahoo!开始返回一个错误说: { "error": { "l
我正在尝试将 yql 用于雅虎财务数据。我检查了 YQL 控制台上的 Show Community Table 以查看 Yahoo 标签下的数据库。 我发布了示例 yql: https://devel
我正在尝试使用如下链接向 Yahoo 授权: https://api.login.yahoo.com/oauth2/request_auth?client_id=dj0yJmk9ZHNUWExxZmh
我想获取 Yahoo! 中给定交易品种的关键统计数据金融。 我找到了几种使用 Yahoo Finance API 获取统计数据的方法。例如获取Apple的名称(n),ask(a),bid(b),mar
如何从 Yahoo Weather API 获取 3,5 或 7 天的天气预报,而不仅仅是今天和明天? http://weather.yahooapis.com/forecastrss?w=locat
我的站点上运行着 Yahoo Pipe,Romneyomics它使用来自 Delicious 和 Topsy 的饲料。Delicious 提要不提供“描述”字段,但 Topsy 提供,并且不仅仅是一个
我目前正在编写一个 JAVA 应用程序,我需要在其中访问来自用户 Yahoo 电子邮件的以下信息(以显示给他们)。 YQL 看起来像是一种“快速简便的方法”,但事实证明它更加困难。我运行的所有测试都在
我上周开发并测试了这个 API。今天,我注意到即使从示例查询中我也没有收到任何结果。 https://developer.yahoo.com/yql/console/?q=show%20tables&
我使用 Yahoo BOSS 的时间很短。这是一个简单的搜索 API,但拼写建议支持确实不那么强大。周围的人是否有任何关于在 BOSS 上获得更好的拼写建议的想法。 最佳答案 不幸的是,甚至在几年后,
我正在寻找一种允许雅虎应用程序通过 IMAP 读取用户电子邮件的方法。它适用于旧应用程序(在 Yahoo Mail API 已弃用之前创建),但尝试访问新应用程序的 IMAP 给我一个错误 [AUTH
我正在开发一个使用 Yahoo OAuth 的应用程序。 OAuth 一直运行良好,但我刚刚在 Yahoo 注册了我的域,现在它不允许我在本地开发时使用 OAuth,因为 “不允许自定义端口或主机未使
对于我们的生产应用程序,我们在雅虎帐户上设置了 API。我们得到消费者 key 和消费者 secret 。 当用户点击访问来自 yahoo 的联系人时,我们收到 401 Forbidden 错误。Om
我正在使用 OAuth 2.0 规范检索梦幻足球数据,其方式与本网站使用它的方式相同:http://yfantasysandbox.herokuapp.com/resource/user/game_t
我尝试按照 read.csv("http://ichart.finance.yahoo.com/table.csv?s=SPY") Not Working 的建议同时使用 http 和 https .
我正在检索雅虎金融公司的数据,我成功地获得了公司的股票数据。除了基本数据外,我还尝试检索同一家公司的关键统计数据。下图是我需要的关键统计字段。 我正在使用 yahoo web service api
我想使用 Beautiful Soup 和 urllib 从 python 脚本对雅虎搜索引擎进行基本查询。我对谷歌也做了同样的事情,这相当容易,但事实证明雅虎有点困难。查询雅虎搜索引擎的最小示例脚本
我最近一直在开发 Ruby on Rails 应用程序。我们使用 Yahoo Web Player 来播放我们的音频和视频文件。它工作得非常好,特别是对于不允许使用 Flash 的平板电脑和智能手机。
我想知道如果我们谈论压力单位,“in”代表什么?我相信 mb = mili bars = hPa。有了这个假设,就有些奇怪了。我分别使用 u=c 和 u=f 取了 2 个不同的 WOEID,结果如下
我需要一种方法来使用 javascript 返回某个城市的当前天气吗?我最好使用哪个 API?或者是否有任何其他应用程序可以使用 ajax 请求来获取当前天气? GeoPlanit 需要一个 appi
我是一名优秀的程序员,十分优秀!