ETCD for java_etcd的java客户端

UTF-8

UTF-8

1.8

1.8

1.8

com.coreos

jetcd-core

0.0.2

org.slf4j

slf4j-log4j12

1.7.25

log4j

log4j

1.2.17

org.slf4j

slf4j-api

1.7.25

org.slf4j

slf4j-nop

1.7.25

org.slf4j

slf4j-simple

1.7.5

org.apache.maven.plugins

maven-assembly-plugin

2.5.5

com.xxg.Main

jar-with-dependencies

package com.gemdale.iot;

import com.coreos.jetcd.Client;

import com.coreos.jetcd.KV;

import com.coreos.jetcd.Watch;

import com.coreos.jetcd.data.ByteSequence;

import com.coreos.jetcd.data.KeyValue;

import java.util.List;

public class EtcdUtil1 {

// etcd客户端链接

private static Client client = null;

private static String IPPORT = null;

static {

IPPORT = System.getProperty("IPPORT", "http://127.0.0.1:11000");

getEtcdClient();

}

// 链接初始化

public static Client getEtcdClient() {

if (client == null) {

synchronized (EtcdUtil1.class) {

client = Client.builder().lazyInitialization(false).endpoints(IPPORT).build();

}

}

return client;

}

/**

* 根据指定的配置名称获取对应的value

*

* @param key

* 配置项

* @return

* @throws Exception

*/

public static String getEtcdValueByKey(String key) throws Exception {

KeyValue kv = getEtcdKeyValueByKey(key);

if (kv != null) {

return kv.getValue().toStringUtf8();

} else {

return null;

}

}

/**

* 根据指定的配置名称获取对应的keyvalue

*

* @param key

* 配置项

* @return

* @throws Exception

*/

public static KeyValue getEtcdKeyValueByKey(String key) throws Exception {

client.getKVClient().get(ByteSequence.fromString(key)).get().getKvs();

if (kvs.size() > 0) {

return kvs.get(0);

} else {

return null;

}

}

/**

* 新增或者修改指定的配置

*

* @param key

* @param value

* @return

*/

public static void putEtcdValueByKey(String key, String value) throws Exception {

client.getKVClient().put(ByteSequence.fromString(key), ByteSequence.fromBytes(value.getBytes("utf-8")));

}

/**

* 删除指定的配置

*

* @param key

* @return

*/

public static void deleteEtcdValueByKey(String key) {

client.getKVClient().delete(ByteSequence.fromString(key));

}

// V3 api配置初始化和监听

public void init() {

try {

// 加载配置

getConfig(client.getKVClient().get(ByteSequence.fromString("test")).get().getKvs());

// 启动监听线程

new Thread(() -> {

// 对某一个配置进行监听

Watch.Watcher watcher = client.getWatchClient().watch(ByteSequence.fromString("etcd_key"));

try {

while (true) {

watcher.listen().getEvents().stream().forEach(watchEvent -> {

KeyValue kv = watchEvent.getKeyValue();

// 获取事件变化类型

System.out.println(watchEvent.getEventType());

// 获取发生变化的key

System.out.println(kv.getKey().toStringUtf8());

// 获取变化后的value

String afterChangeValue = kv.getValue().toStringUtf8();

});

}

} catch (InterruptedException e) {

e.printStackTrace();

}

}).start();

} catch (Exception e) {

e.printStackTrace();

}

}

private String getConfig(List kvs) {

if (kvs.size() > 0) {

String config = kvs.get(0).getValue().toStringUtf8();

System.out.println("etcd 's config 's configValue is :" + config);

return config;

} else {

return null;

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值