use of com.linkedin.d2.discovery.stores.PropertyStringMerger in project rest.li by linkedin.
the class ZooKeeperEphemeralStoreStrawMan method main.
public static void main(String[] args) throws IOException, InterruptedException, PropertyStoreException {
ZKConnection zkClient = new ZKConnection("localhost:2181", 30000);
PropertyStringMerger merger = new PropertyStringMerger();
Set<String> listenTos = new HashSet<>();
ZooKeeperEphemeralStore<String> zk = new ZooKeeperEphemeralStore<>(zkClient, new PropertyStringSerializer(), merger, "/test/lb/test-property-ephemeral", false, true);
listenTos.add("foo12");
ScheduledExecutorService executorService = Executors.newSingleThreadScheduledExecutor();
PropertyEventBus<String> bus = new PropertyEventBusImpl<>(executorService, zk);
bus.register(listenTos, new PropertyEventSubscriber<String>() {
@Override
public void onAdd(String propertyName, String propertyValue) {
System.err.println("onAdd: " + propertyName + "\t" + propertyValue);
}
@Override
public void onInitialize(String propertyName, String propertyValue) {
System.err.println("onInitialize: " + propertyName + "\t" + propertyValue);
}
@Override
public void onRemove(String propertyName) {
System.err.println("onRemove: " + propertyName);
}
});
zk.put("foo12", "TEST1");
zk.put("foo12", "TEST2");
zk.put("foo12", "TEST3");
zk.put("foo12", "TEST4");
zk.put("foo12", "TEST5");
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
zk.remove("foo12");
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
zkClient.getZooKeeper().close();
executorService.shutdown();
}
use of com.linkedin.d2.discovery.stores.PropertyStringMerger in project rest.li by linkedin.
the class ZooKeeperEphemeralStoreTest method getStore.
public ZooKeeperEphemeralStore<String> getStore() throws IOException, PropertyStoreException, InterruptedException, ExecutionException {
ZKConnection client = new ZKConnection("localhost:" + _port, 5000);
client.start();
ZooKeeperEphemeralStore<String> store = new ZooKeeperEphemeralStore<>(client, new PropertyStringSerializer(), new PropertyStringMerger(), "/test-path", false, true);
FutureCallback<None> callback = new FutureCallback<>();
store.start(callback);
callback.get();
return store;
}
Aggregations