欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

spring/springboot整合curator遇到的坑及解決

 更新時(shí)間:2022年05月07日 09:48:00   作者:lishentao_1122  
這篇文章主要介紹了spring/springboot整合curator遇到的坑及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

近期本人在搭建自己的調(diào)度平臺(tái)項(xiàng)目使用到了zookeeper做執(zhí)行器自動(dòng)注冊(cè)中心時(shí),使用到了springboot2.0+curator4.0版本整合

整個(gè)代碼

pom.xml 

<dependency>
? ? ?<groupId>org.apache.curator</groupId>
? ? ?<artifactId>curator-framework</artifactId>
? ? ?<version>4.0.0</version>
</dependency>
<dependency>
? ? ? <groupId>org.apache.curator</groupId>
? ? ? <artifactId>curator-recipes</artifactId>
? ? ? <version>4.0.0</version>
</dependency>

zookeeper的config類:

application.properties
?
################################## zookeeper ##################################
kafka.zookeeper.host=127.0.0.1:2181
kafka.zookeeper.maxRetry=3
kafka.zookeeper.sessionTimeout=60000
kafka.zookeeper.connectTimeout=10000
kafka.zookeeper.namespace=sensecrowd
@Configuration
@ConfigurationProperties(prefix = "kafka.zookeeper")
public class ZookeeperConfig {
? ? private final Logger LOGGER = LoggerFactory.getLogger(ZookeeperConfig.class);?
? ? private String host;?
? ? private int maxRetry;?
? ? private int sessionTimeout;?
? ? private int connectTimeout;?
? ? private String namespace;
?
? ? @Bean
? ? public CuratorFramework curatorFramework(){
? ? ? ? RetryPolicy retryPolicy = new ExponentialBackoffRetry(1000, 1);
? ? ? ? CuratorFramework client =
? ? ? ? ? ? ? ? CuratorFrameworkFactory.builder()
? ? ? ? ? ? ? ? ? ? ? ? .connectString(host)
? ? ? ? ? ? ? ? ? ? ? ? .sessionTimeoutMs(sessionTimeout)
? ? ? ? ? ? ? ? ? ? ? ? .connectionTimeoutMs(connectTimeout)
? ? ? ? ? ? ? ? ? ? ? ? .retryPolicy(retryPolicy)
? ? ? ? ? ? ? ? ? ? ? ? /*.aclProvider(new ACLProvider() {
? ? ? ? ? ? ? ? ? ? ? ? ? ? private List<ACL> acl ;
? ? ? ? ? ? ? ? ? ? ? ? ? ? @Override
? ? ? ? ? ? ? ? ? ? ? ? ? ? public List<ACL> getDefaultAcl() {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? if(acl ==null) {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ArrayList<ACL> acl = ZooDefs.Ids.CREATOR_ALL_ACL;
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? acl.clear();
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? acl.add(new ACL(ZooDefs.Perms.ALL, new Id("auth", "admin:admin")));
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? this.acl = acl;
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? return acl;
? ? ? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? ? ? ? ? @Override
? ? ? ? ? ? ? ? ? ? ? ? ? ? public List<ACL> getAclForPath(String s) {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? return acl;
? ? ? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? ? ? })*/
// ? ? ? ? ? ? ? ? ? ? ? ?.namespace(namespace)
? ? ? ? ? ? ? ? ? ? ? ? .build();
? ? ? ? client.start();
? ? ? ? client.getConnectionStateListenable().addListener(new ZookeeperConnectionListener(host,maxRetry,sessionTimeout,connectTimeout,namespace));
? ? ? ? return client;
? ? }
?
? ? @PreDestroy
? ? private void destroyClient(){
? ? ? ? curatorFramework().close();
? ? ? ? LOGGER.info("==================關(guān)閉成功==================");
? ? }
?
? ? public String getHost() {
? ? ? ? return host;
? ? }
?
? ? public void setHost(String host) {
? ? ? ? this.host = host;
? ? }
?
? ? public int getMaxRetry() {
? ? ? ? return maxRetry;
? ? }
?
? ? public void setMaxRetry(int maxRetry) {
? ? ? ? this.maxRetry = maxRetry;
? ? }
?
? ? public int getSessionTimeout() {
? ? ? ? return sessionTimeout;
? ? }
?
? ? public void setSessionTimeout(int sessionTimeout) {
? ? ? ? this.sessionTimeout = sessionTimeout;
? ? }
?
? ? public int getConnectTimeout() {
? ? ? ? return connectTimeout;
? ? }
?
? ? public void setConnectTimeout(int connectTimeout) {
? ? ? ? this.connectTimeout = connectTimeout;
? ? }
?
? ? public String getNamespace() {
? ? ? ? return namespace;
? ? }
?
? ? public void setNamespace(String namespace) {
? ? ? ? this.namespace = namespace;
? ? }
}

可項(xiàng)目遇到了兩個(gè)問(wèn)題

1)、項(xiàng)目運(yùn)行控制臺(tái)會(huì)報(bào)Log4j日志警告,原因是我的項(xiàng)目使用的springboot整合的log4j模塊而curator包含slf4j的日志包,zookeeper包含log4j的日志包,所以log4j的版本沖突導(dǎo)致。

2)、curator可以查看節(jié)點(diǎn)信息,但創(chuàng)建節(jié)點(diǎn)會(huì)導(dǎo)致程序進(jìn)程阻塞,根據(jù)zookeeper版本不同報(bào)出不同的問(wèn)題,我使用的是默認(rèn)的curator4.0.0自帶的zookeeper版本,3.5.+-beta版,添加節(jié)點(diǎn)報(bào),并且程序阻塞:

Unable to read additional data from server sessionid 0x1002fd7768a015f

解決辦法

修改pom依賴,第一解決log4j和slaf4j依賴版本沖突問(wèn)題,第二curator依賴的zookeeper版本修改成你服務(wù)器安裝的zookeeper服務(wù)的版本,完美解決。

<!-- zookeeper -->
? ? ? ? ? ? <dependency>
? ? ? ? ? ? ? ? <groupId>org.apache.zookeeper</groupId>
? ? ? ? ? ? ? ? <artifactId>zookeeper</artifactId>
? ? ? ? ? ? ? ? <version>3.4.10</version>
? ? ? ? ? ? ? ? <exclusions>
? ? ? ? ? ? ? ? ? ? <exclusion>
? ? ? ? ? ? ? ? ? ? ? ? <groupId>org.slf4j</groupId>
? ? ? ? ? ? ? ? ? ? ? ? <artifactId>slf4j-log4j12</artifactId>
? ? ? ? ? ? ? ? ? ? </exclusion>
? ? ? ? ? ? ? ? ? ? <exclusion>
? ? ? ? ? ? ? ? ? ? ? ? <groupId>org.slf4j</groupId>
? ? ? ? ? ? ? ? ? ? ? ? <artifactId>slf4j-api</artifactId>
? ? ? ? ? ? ? ? ? ? </exclusion>
? ? ? ? ? ? ? ? ? ? <exclusion>
? ? ? ? ? ? ? ? ? ? ? ? <groupId>log4j</groupId>
? ? ? ? ? ? ? ? ? ? ? ? <artifactId>log4j</artifactId>
? ? ? ? ? ? ? ? ? ? </exclusion>
? ? ? ? ? ? ? ? </exclusions>
? ? ? ? ? ? </dependency>
?
? ? ? ? ? ? <dependency>
? ? ? ? ? ? ? ? <groupId>org.apache.curator</groupId>
? ? ? ? ? ? ? ? <artifactId>curator-framework</artifactId>
? ? ? ? ? ? ? ? <version>4.0.0</version>
? ? ? ? ? ? ? ? <exclusions>
? ? ? ? ? ? ? ? ? ? <exclusion>
? ? ? ? ? ? ? ? ? ? ? ? <groupId>org.slf4j</groupId>
? ? ? ? ? ? ? ? ? ? ? ? <artifactId>slf4j-api</artifactId>
? ? ? ? ? ? ? ? ? ? </exclusion>
? ? ? ? ? ? ? ? </exclusions>
? ? ? ? ? ? </dependency>
? ? ? ? ? ? <dependency>
? ? ? ? ? ? ? ? <groupId>org.apache.curator</groupId>
? ? ? ? ? ? ? ? <artifactId>curator-recipes</artifactId>
? ? ? ? ? ? ? ? <version>4.0.0</version>
? ? ? ? ? ? </dependency>

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。 

相關(guān)文章

  • 使用java實(shí)現(xiàn)LIS算法,出操隊(duì)形的問(wèn)題

    使用java實(shí)現(xiàn)LIS算法,出操隊(duì)形的問(wèn)題

    下面小編就為大家?guī)?lái)一篇使用java實(shí)現(xiàn)LIS算法,出操隊(duì)形的問(wèn)題。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-09-09
  • java學(xué)習(xí)之JasperReport踩坑

    java學(xué)習(xí)之JasperReport踩坑

    本篇文章介紹的是在JAVA學(xué)習(xí)中JasperReport遇到的坑以及解決辦法,有需要的朋友參考下吧。
    2018-01-01
  • SpringBoot JWT實(shí)現(xiàn)token登錄刷新功能

    SpringBoot JWT實(shí)現(xiàn)token登錄刷新功能

    JWT本身是無(wú)狀態(tài)的,這點(diǎn)有別于傳統(tǒng)的session,不在服務(wù)端存儲(chǔ)憑證。這種特性使其在分布式場(chǎng)景,更便于擴(kuò)展使用。接下來(lái)通過(guò)本文給大家分享SpringBoot JWT實(shí)現(xiàn)token登錄刷新功能,感興趣的朋友一起看看吧
    2021-09-09
  • SpringBoot使用AOP實(shí)現(xiàn)防重復(fù)提交功能

    SpringBoot使用AOP實(shí)現(xiàn)防重復(fù)提交功能

    這篇文章主要為大家詳細(xì)介紹了SpringBoot如何使用AOP實(shí)現(xiàn)防重復(fù)提交功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-03-03
  • Java8接口中引入default關(guān)鍵字的本質(zhì)原因詳析

    Java8接口中引入default關(guān)鍵字的本質(zhì)原因詳析

    Default方法是在java8中引入的關(guān)鍵字,也可稱為Virtual extension methods—虛擬擴(kuò)展方法,這篇文章主要給大家介紹了關(guān)于Java8接口中引入default關(guān)鍵字的本質(zhì)原因,需要的朋友可以參考下
    2022-01-01
  • Java開(kāi)發(fā)之普通web項(xiàng)目轉(zhuǎn)為Maven項(xiàng)目的方法

    Java開(kāi)發(fā)之普通web項(xiàng)目轉(zhuǎn)為Maven項(xiàng)目的方法

    這篇文章主要給大家介紹了關(guān)于Java開(kāi)發(fā)之普通web項(xiàng)目轉(zhuǎn)為Maven項(xiàng)目的相關(guān)資料,文中通過(guò)圖文將轉(zhuǎn)換的方法步驟介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-12-12
  • 如何用java生成指定范圍的隨機(jī)數(shù)

    如何用java生成指定范圍的隨機(jī)數(shù)

    以生成[10,20]隨機(jī)數(shù)為例,首先生成0-20的隨機(jī)數(shù),然后對(duì)(20-10+1)取模得到[0-10]之間的隨機(jī)數(shù),然后加上min=10,最后生成的是10-20的隨機(jī)數(shù)
    2013-09-09
  • 利用Spring?Boot和JPA創(chuàng)建GraphQL?API

    利用Spring?Boot和JPA創(chuàng)建GraphQL?API

    這篇文章主要介紹了利用Spring?Boot和JPA創(chuàng)建GraphQL?API,GraphQL既是API查詢語(yǔ)言,也是使用當(dāng)前數(shù)據(jù)執(zhí)行這些查詢的運(yùn)行時(shí),下文更多相關(guān)內(nèi)容介紹需要的小伙伴可以參考一下
    2022-04-04
  • SpringBoot利用自定義注解實(shí)現(xiàn)隱私數(shù)據(jù)脫敏(加密顯示)的解決方案

    SpringBoot利用自定義注解實(shí)現(xiàn)隱私數(shù)據(jù)脫敏(加密顯示)的解決方案

    這兩天在整改等保測(cè)出的問(wèn)題,里面有一個(gè)“用戶信息泄露”的風(fēng)險(xiǎn)項(xiàng)(就是后臺(tái)系統(tǒng)里用戶的一些隱私數(shù)據(jù)直接明文顯示了),其實(shí)指的就是要做數(shù)據(jù)脫敏,本文給大家介紹了SpringBoot利用自定義注解實(shí)現(xiàn)隱私數(shù)據(jù)脫敏(加密顯示)的解決方案,需要的朋友可以參考下
    2023-11-11
  • spring data jpa使用詳解(推薦)

    spring data jpa使用詳解(推薦)

    這篇文章主要介紹了spring data jpa使用詳解(推薦),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-04-04

最新評(píng)論