SpringBoot讀取ZooKeeper(ZK)屬性的方法實(shí)現(xiàn)
1. 在配置文件中定義 ZK 屬性
在 application.properties 或 application.yml 中添加 ZK 相關(guān)配置:
application.properties
# 單源配置示例 zookeeper.source.default.rootnode=/democonfig zookeeper.source.default.servers=192.168.124.1:2181,192.168.124.2:2181 zookeeper.source.default.acls=root:iiot!@#zk$ # 多源配置示例(可選) zookeeper.source.backup.rootnode=/backup-config zookeeper.source.backup.servers=192.168.124.3:2181
application.yml
zookeeper:
source:
default:
rootnode: /democonfig
servers: 192.168.124.1:2181,192.168.124.2:2181
acls: root:iiot!@#zk$
backup:
rootnode: /backup-config
servers: 192.168.124.3:2181
2. 創(chuàng)建配置類(lèi)綁定屬性
使用 @ConfigurationProperties 綁定 ZK 配置:
import lombok.Getter;
import lombok.Setter;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
import java.util.Map;
@Component
@ConfigurationProperties(prefix = "zookeeper")
@Getter
@Setter
public class ZookeeperConfig {
private Map<String, SourceProperties> source = new HashMap<>();
@Getter
@Setter
public static class SourceProperties {
private String rootnode;
private String servers;
private String acls;
}
}
3. 初始化 ZK 客戶端
在 Spring 容器中初始化 ZK 客戶端,確保配置已注入:
import org.apache.zookeeper.ZooKeeper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import java.io.IOException;
@Component
public class ZookeeperClient {
private static final int SESSION_TIMEOUT = 5000;
private final ZooKeeper zooKeeper;
@Autowired
public ZookeeperClient(ZookeeperConfig zookeeperConfig) {
try {
// 獲取默認(rèn)源配置
ZookeeperConfig.SourceProperties source = zookeeperConfig.getSource().get("default");
if (source == null) {
throw new IllegalArgumentException("ZooKeeper source 'default' not configured");
}
this.zooKeeper = new ZooKeeper(
source.getServers(),
SESSION_TIMEOUT,
null
);
} catch (IOException e) {
throw new RuntimeException("Failed to connect to ZooKeeper", e);
}
}
public ZooKeeper getZooKeeper() {
return zooKeeper;
}
}
4. 使用配置屬性
在任意 Spring Bean 中注入 ZookeeperConfig 或 ZookeeperClient,并讀取屬性:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class MyService {
@Autowired
private ZookeeperConfig zookeeperConfig;
@Autowired
private ZookeeperClient zookeeperClient;
public void printZkConfig() {
// 直接讀取配置
ZookeeperConfig.SourceProperties source = zookeeperConfig.getSource().get("default");
System.out.println("ZK Root Node: " + source.getRootnode());
System.out.println("ZK Servers: " + source.getServers());
// 通過(guò)客戶端使用 ZK 連接
ZooKeeper zk = zookeeperClient.getZooKeeper();
System.out.println("ZK Session ID: " + zk.getSessionId());
}
}
5. 多源配置支持
如果需要切換不同的 ZK 源(如 default 和 backup),可擴(kuò)展 ZookeeperClient:
@Component
public class ZookeeperClient {
private final Map<String, ZooKeeper> clients = new HashMap<>();
@Autowired
public ZookeeperClient(ZookeeperConfig zookeeperConfig) {
zookeeperConfig.getSource().forEach((name, config) -> {
try {
clients.put(name, new ZooKeeper(
config.getServers(),
SESSION_TIMEOUT,
null
));
} catch (IOException e) {
throw new RuntimeException("Failed to connect to ZooKeeper source: " + name, e);
}
});
}
public ZooKeeper getClient(String sourceName) {
return clients.getOrDefault(sourceName, clients.get("default"));
}
}
6. 注意事項(xiàng)
- 配置文件路徑:確保
application.properties或application.yml在類(lèi)路徑下(src/main/resources)。 - 屬性鍵命名規(guī)則:
- 使用
kebab-case(如zookeeper.source.default.servers)。 - 綁定到
@ConfigurationProperties時(shí),自動(dòng)轉(zhuǎn)換為駝峰命名(如source.default.servers→source.get("default").getServers())。
- 使用
- 優(yōu)先級(jí):
- 系統(tǒng)屬性(
-D參數(shù)) > 配置文件 > 代碼默認(rèn)值。
- 系統(tǒng)屬性(
- 異常處理:在 ZK 客戶端初始化時(shí)捕獲
IOException,并提供友好的錯(cuò)誤提示。 - 單例與依賴注入:避免在 Spring 容器初始化前手動(dòng)創(chuàng)建
ZookeeperClient(如在main方法中),應(yīng)通過(guò)@Autowired注入。
對(duì)比:傳統(tǒng)屬性讀取 vs Spring Boot 原生方式
| 方式 | 優(yōu)點(diǎn) | 缺點(diǎn) |
|---|---|---|
傳統(tǒng) PropertyConfig | 簡(jiǎn)單直接,無(wú)需 Spring 依賴 | 不支持自動(dòng)刷新、類(lèi)型安全、配置校驗(yàn) |
Spring Boot @ConfigurationProperties | 類(lèi)型安全、支持校驗(yàn)、自動(dòng)刷新(需配置) | 需要定義配置類(lèi),學(xué)習(xí)成本略高 |
通過(guò)以上步驟,你可以在 Spring Boot 中優(yōu)雅地讀取和管理 ZooKeeper 的配置屬性。
到此這篇關(guān)于SpringBoot讀取ZooKeeper(ZK)屬性的方法實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)SpringBoot讀取ZooKeeper內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 淺談Java(SpringBoot)基于zookeeper的分布式鎖實(shí)現(xiàn)
- 使用dubbo+zookeeper+spring boot構(gòu)建服務(wù)的方法詳解
- SpringBoot中dubbo+zookeeper實(shí)現(xiàn)分布式開(kāi)發(fā)的應(yīng)用詳解
- SpringBoot集成Curator實(shí)現(xiàn)Zookeeper基本操作的代碼示例
- SpringBoot系列教程之dubbo和Zookeeper集成方法
- SpringBoot整合Dubbo+Zookeeper實(shí)現(xiàn)RPC調(diào)用
- springboot應(yīng)用訪問(wèn)zookeeper的流程
- SpringBoot整合Zookeeper詳細(xì)教程
- Java Spring Boot 集成Zookeeper
相關(guān)文章
Spring之InitializingBean接口和DisposableBean接口的使用
這篇文章主要介紹了Spring之InitializingBean接口和DisposableBean接口的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
java實(shí)現(xiàn)驗(yàn)證碼類(lèi)生成中文驗(yàn)證碼
java實(shí)現(xiàn)的漢字輸入驗(yàn)證碼,主要包含兩個(gè)類(lèi),一個(gè)是生成驗(yàn)證碼,一個(gè)是判斷驗(yàn)證碼輸入是否正確,實(shí)現(xiàn)原理非常簡(jiǎn)單,將漢字和干擾線生成圖片并將漢字保存到session,前臺(tái)獲取每次生成驗(yàn)證碼圖片并用文本框值和session值比較,功能就怎么簡(jiǎn)單2014-01-01
mybatis插入數(shù)據(jù)后如何返回新增數(shù)據(jù)的id值
當(dāng)往mysql數(shù)據(jù)庫(kù)插入一條數(shù)據(jù)時(shí),有時(shí)候需要知道剛插入的信息,下面這篇文章主要給大家介紹了關(guān)于mybatis插入數(shù)據(jù)后如何返回新增數(shù)據(jù)id值的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06
java實(shí)現(xiàn)ATM取款項(xiàng)目
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)ATM取款項(xiàng)目的實(shí)現(xiàn)代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06
SpringBoot 編程式事務(wù)使用及兩種實(shí)現(xiàn)方式
編程式事務(wù)管理是通過(guò)編寫(xiě)代碼來(lái)管理事務(wù),相對(duì)于聲明式事務(wù)(@Transactional注解),它提供了更細(xì)粒度的事務(wù)控制,這篇文章主要介紹了SpringBoot 編程式事務(wù)使用及兩種實(shí)現(xiàn)方式,需要的朋友可以參考下2024-12-12
springboot?max-http-header-size最大長(zhǎng)度的那些事及JVM調(diào)優(yōu)方式
這篇文章主要介紹了springboot?max-http-header-size最大長(zhǎng)度的那些事及JVM調(diào)優(yōu)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09
Java中的可重入鎖ReentrantLock簡(jiǎn)析
這篇文章主要介紹了Java中的可重入鎖ReentrantLock簡(jiǎn)析,可重入是指同一個(gè)線程如果首次獲得了這把鎖,那么因?yàn)樗沁@把鎖的擁有者,因此有權(quán)利再次獲取這把鎖如果是不可重入鎖,那么第二次獲得鎖時(shí),自己也會(huì)被鎖擋住,需要的朋友可以參考下2023-12-12
Java Socket編程(五) 簡(jiǎn)單的WEB服務(wù)器
Java Socket編程(五) 簡(jiǎn)單的WEB服務(wù)器...2006-12-12

