GOSSIP-17 Add metrics (Chandresh Pancholi via egc)

This commit is contained in:
Edward Capriolo
2017-01-14 22:18:33 -05:00
parent bc96cf6d34
commit 9487b8c223
14 changed files with 82 additions and 37 deletions

View File

@ -39,6 +39,7 @@
<!-- dependecy versions --> <!-- dependecy versions -->
<jackson.version>2.8.5</jackson.version> <jackson.version>2.8.5</jackson.version>
<metrics.version>3.1.2</metrics.version>
<commons-math.version>1.2</commons-math.version> <commons-math.version>1.2</commons-math.version>
<junit.jupiter.version>5.0.0-M2</junit.jupiter.version> <junit.jupiter.version>5.0.0-M2</junit.jupiter.version>
<junit.platform.version>1.0.0-M2</junit.platform.version> <junit.platform.version>1.0.0-M2</junit.platform.version>
@ -90,6 +91,10 @@
<artifactId>jackson-databind</artifactId> <artifactId>jackson-databind</artifactId>
<version>${jackson.version}</version> <version>${jackson.version}</version>
</dependency> </dependency>
<dependency>
<groupId>io.dropwizard.metrics</groupId>
<artifactId>metrics-core</artifactId>
<version>${metrics.version}</version></dependency>
<dependency> <dependency>
<groupId>org.junit.jupiter</groupId> <groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter-api</artifactId> <artifactId>junit-jupiter-api</artifactId>

View File

@ -22,8 +22,6 @@ import java.io.FileNotFoundException;
import java.io.IOException; import java.io.IOException;
import java.net.URISyntaxException; import java.net.URISyntaxException;
public class GossipRunner { public class GossipRunner {
public static void main(String[] args) throws URISyntaxException { public static void main(String[] args) throws URISyntaxException {

View File

@ -17,10 +17,12 @@
*/ */
package org.apache.gossip; package org.apache.gossip;
import com.codahale.metrics.MetricRegistry;
import java.net.URI; import java.net.URI;
import java.net.UnknownHostException; import java.net.UnknownHostException;
import java.util.List; import java.util.List;
import com.codahale.metrics.JmxReporter;
import org.apache.gossip.event.GossipListener; import org.apache.gossip.event.GossipListener;
import org.apache.gossip.manager.GossipManager; import org.apache.gossip.manager.GossipManager;
import org.apache.gossip.manager.random.RandomGossipManager; import org.apache.gossip.manager.random.RandomGossipManager;
@ -35,6 +37,7 @@ import org.apache.log4j.Logger;
public class GossipService { public class GossipService {
public static final Logger LOGGER = Logger.getLogger(GossipService.class); public static final Logger LOGGER = Logger.getLogger(GossipService.class);
private final JmxReporter jmxReporter;
private final GossipManager gossipManager; private final GossipManager gossipManager;
@ -48,7 +51,7 @@ public class GossipService {
UnknownHostException { UnknownHostException {
this(startupSettings.getCluster(), startupSettings.getUri() this(startupSettings.getCluster(), startupSettings.getUri()
, startupSettings.getId(), startupSettings.getGossipMembers(), , startupSettings.getId(), startupSettings.getGossipMembers(),
startupSettings.getGossipSettings(), null); startupSettings.getGossipSettings(), null, new MetricRegistry());
} }
/** /**
@ -58,8 +61,10 @@ public class GossipService {
* @throws UnknownHostException * @throws UnknownHostException
*/ */
public GossipService(String cluster, URI uri, String id, public GossipService(String cluster, URI uri, String id,
List<GossipMember> gossipMembers, GossipSettings settings, GossipListener listener) List<GossipMember> gossipMembers, GossipSettings settings, GossipListener listener, MetricRegistry registry)
throws InterruptedException, UnknownHostException { throws InterruptedException, UnknownHostException {
jmxReporter = JmxReporter.forRegistry(registry).build();
jmxReporter.start();
gossipManager = RandomGossipManager.newBuilder() gossipManager = RandomGossipManager.newBuilder()
.withId(id) .withId(id)
.cluster(cluster) .cluster(cluster)
@ -67,11 +72,11 @@ public class GossipService {
.settings(settings) .settings(settings)
.gossipMembers(gossipMembers) .gossipMembers(gossipMembers)
.listener(listener) .listener(listener)
.registry(registry)
.build(); .build();
} }
public void start() { public void start() {
LOGGER.debug("Starting: " + getGossipManager().getMyself().getUri());
gossipManager.init(); gossipManager.init();
} }

View File

@ -17,6 +17,7 @@
*/ */
package org.apache.gossip.examples; package org.apache.gossip.examples;
import com.codahale.metrics.MetricRegistry;
import java.net.InetAddress; import java.net.InetAddress;
import java.net.URI; import java.net.URI;
import java.net.URISyntaxException; import java.net.URISyntaxException;
@ -81,7 +82,7 @@ public class GossipExample extends Thread {
// dead list handling. // dead list handling.
for (GossipMember member : startupMembers) { for (GossipMember member : startupMembers) {
GossipService gossipService = new GossipService(cluster, member.getUri(), "", GossipService gossipService = new GossipService(cluster, member.getUri(), "",
startupMembers, settings, null); startupMembers, settings, null, new MetricRegistry());
clients.add(gossipService); clients.add(gossipService);
gossipService.start(); gossipService.start();
sleep(settings.getCleanupInterval() + 1000); sleep(settings.getCleanupInterval() + 1000);

View File

@ -17,6 +17,7 @@
*/ */
package org.apache.gossip.examples; package org.apache.gossip.examples;
import com.codahale.metrics.MetricRegistry;
import java.net.URI; import java.net.URI;
import java.net.UnknownHostException; import java.net.UnknownHostException;
import java.util.Arrays; import java.util.Arrays;
@ -32,7 +33,7 @@ public class StandAloneNode {
s.setConvictThreshold(1.0); s.setConvictThreshold(1.0);
s.setGossipInterval(10); s.setGossipInterval(10);
GossipService gossipService = new GossipService("mycluster", URI.create(args[0]), args[1], GossipService gossipService = new GossipService("mycluster", URI.create(args[0]), args[1],
Arrays.asList( new RemoteGossipMember("mycluster", URI.create(args[2]), args[3])), s, (a,b) -> {} ); Arrays.asList( new RemoteGossipMember("mycluster", URI.create(args[2]), args[3])), s, (a,b) -> {}, new MetricRegistry());
gossipService.start(); gossipService.start();
while (true){ while (true){
System.out.println( "Live: " + gossipService.getGossipManager().getLiveMembers()); System.out.println( "Live: " + gossipService.getGossipManager().getLiveMembers());

View File

@ -32,6 +32,8 @@ import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.ThreadPoolExecutor; import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
import com.codahale.metrics.Histogram;
import com.codahale.metrics.MetricRegistry;
import org.apache.gossip.LocalGossipMember; import org.apache.gossip.LocalGossipMember;
import org.apache.gossip.model.ActiveGossipOk; import org.apache.gossip.model.ActiveGossipOk;
import org.apache.gossip.model.GossipDataMessage; import org.apache.gossip.model.GossipDataMessage;
@ -45,11 +47,10 @@ import org.apache.log4j.Logger;
import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.ObjectMapper;
import static com.codahale.metrics.MetricRegistry.name;
/** /**
* [The active thread: periodically send gossip request.] The class handles gossiping the membership * The ActiveGossipThread is sends information. Pick a random partner and send the membership list to that partner
* list. This information is important to maintaining a common state among all the nodes, and is
* important for detecting failures.
*/ */
public class ActiveGossipThread { public class ActiveGossipThread {
@ -63,15 +64,23 @@ public class ActiveGossipThread {
private ThreadPoolExecutor threadService; private ThreadPoolExecutor threadService;
private ObjectMapper MAPPER = new ObjectMapper(); private ObjectMapper MAPPER = new ObjectMapper();
public ActiveGossipThread(GossipManager gossipManager, GossipCore gossipCore) { private final Histogram sharedDataHistogram;
private final Histogram sendPerNodeDataHistogram;
private final Histogram sendMembershipHistorgram;
public ActiveGossipThread(GossipManager gossipManager, GossipCore gossipCore, MetricRegistry registry) {
this.gossipManager = gossipManager; this.gossipManager = gossipManager;
random = new Random(); random = new Random();
this.gossipCore = gossipCore; this.gossipCore = gossipCore;
this.scheduledExecutorService = Executors.newScheduledThreadPool(2); scheduledExecutorService = Executors.newScheduledThreadPool(2);
workQueue = new ArrayBlockingQueue<Runnable>(1024); workQueue = new ArrayBlockingQueue<Runnable>(1024);
threadService = new ThreadPoolExecutor(1, 30, 1, TimeUnit.SECONDS, workQueue, new ThreadPoolExecutor.DiscardOldestPolicy()); threadService = new ThreadPoolExecutor(1, 30, 1, TimeUnit.SECONDS, workQueue, new ThreadPoolExecutor.DiscardOldestPolicy());
sharedDataHistogram = registry.histogram(name(ActiveGossipThread.class, "sharedDataHistogram-time"));
sendPerNodeDataHistogram = registry.histogram(name(ActiveGossipThread.class, "sendPerNodeDataHistogram-time"));
sendMembershipHistorgram = registry.histogram(name(ActiveGossipThread.class, "sendMembershipHistorgram-time"));
} }
public void init() { public void init() {
scheduledExecutorService.scheduleAtFixedRate( scheduledExecutorService.scheduleAtFixedRate(
() -> { () -> {
@ -99,9 +108,12 @@ public class ActiveGossipThread {
} }
public void sendSharedData(LocalGossipMember me, List<LocalGossipMember> memberList){ public void sendSharedData(LocalGossipMember me, List<LocalGossipMember> memberList){
long startTime = System.currentTimeMillis();
LocalGossipMember member = selectPartner(memberList); LocalGossipMember member = selectPartner(memberList);
if (member == null) { if (member == null) {
LOGGER.debug("Send sendMembershipList() is called without action"); LOGGER.debug("Send sendMembershipList() is called without action");
sharedDataHistogram.update(System.currentTimeMillis() - startTime);
return; return;
} }
try (DatagramSocket socket = new DatagramSocket()) { try (DatagramSocket socket = new DatagramSocket()) {
@ -128,12 +140,16 @@ public class ActiveGossipThread {
} catch (IOException e1) { } catch (IOException e1) {
LOGGER.warn(e1); LOGGER.warn(e1);
} }
sharedDataHistogram.update(System.currentTimeMillis() - startTime);
} }
public void sendPerNodeData(LocalGossipMember me, List<LocalGossipMember> memberList){ public void sendPerNodeData(LocalGossipMember me, List<LocalGossipMember> memberList){
long startTime = System.currentTimeMillis();
LocalGossipMember member = selectPartner(memberList); LocalGossipMember member = selectPartner(memberList);
if (member == null) { if (member == null) {
LOGGER.debug("Send sendMembershipList() is called without action"); LOGGER.debug("Send sendMembershipList() is called without action");
sendPerNodeDataHistogram.update(System.currentTimeMillis() - startTime);
return; return;
} }
try (DatagramSocket socket = new DatagramSocket()) { try (DatagramSocket socket = new DatagramSocket()) {
@ -162,6 +178,7 @@ public class ActiveGossipThread {
} catch (IOException e1) { } catch (IOException e1) {
LOGGER.warn(e1); LOGGER.warn(e1);
} }
sendPerNodeDataHistogram.update(System.currentTimeMillis() - startTime);
} }
protected void sendToALiveMember(){ protected void sendToALiveMember(){
@ -177,9 +194,12 @@ public class ActiveGossipThread {
* Performs the sending of the membership list, after we have incremented our own heartbeat. * Performs the sending of the membership list, after we have incremented our own heartbeat.
*/ */
protected void sendMembershipList(LocalGossipMember me, LocalGossipMember member) { protected void sendMembershipList(LocalGossipMember me, LocalGossipMember member) {
long startTime = System.currentTimeMillis();
me.setHeartbeat(System.nanoTime()); me.setHeartbeat(System.nanoTime());
if (member == null) { if (member == null) {
LOGGER.debug("Send sendMembershipList() is called without action"); LOGGER.debug("Send sendMembershipList() is called without action");
sendMembershipHistorgram.update(System.currentTimeMillis() - startTime);
return; return;
} else { } else {
LOGGER.debug("Send sendMembershipList() is called to " + member.toString()); LOGGER.debug("Send sendMembershipList() is called to " + member.toString());
@ -209,6 +229,7 @@ public class ActiveGossipThread {
} catch (IOException e1) { } catch (IOException e1) {
LOGGER.warn(e1); LOGGER.warn(e1);
} }
sendMembershipHistorgram.update(System.currentTimeMillis() - startTime);
} }
/** /**

View File

@ -17,6 +17,7 @@
*/ */
package org.apache.gossip.manager; package org.apache.gossip.manager;
import com.codahale.metrics.MetricRegistry;
import java.net.URI; import java.net.URI;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections; import java.util.Collections;
@ -74,9 +75,11 @@ public abstract class GossipManager {
private final ScheduledExecutorService scheduledServiced; private final ScheduledExecutorService scheduledServiced;
private MetricRegistry registry;
public GossipManager(String cluster, public GossipManager(String cluster,
URI uri, String id, GossipSettings settings, URI uri, String id, GossipSettings settings,
List<GossipMember> gossipMembers, GossipListener listener) { List<GossipMember> gossipMembers, GossipListener listener, MetricRegistry registry) {
this.settings = settings; this.settings = settings;
gossipCore = new GossipCore(this); gossipCore = new GossipCore(this);
@ -98,6 +101,7 @@ public abstract class GossipManager {
gossipServiceRunning = new AtomicBoolean(true); gossipServiceRunning = new AtomicBoolean(true);
this.listener = listener; this.listener = listener;
this.scheduledServiced = Executors.newScheduledThreadPool(1); this.scheduledServiced = Executors.newScheduledThreadPool(1);
this.registry = registry;
} }
public ConcurrentSkipListMap<LocalGossipMember, GossipState> getMembers() { public ConcurrentSkipListMap<LocalGossipMember, GossipState> getMembers() {
@ -148,7 +152,7 @@ public abstract class GossipManager {
public void init() { public void init() {
passiveGossipThread = new OnlyProcessReceivedPassiveGossipThread(this, gossipCore); passiveGossipThread = new OnlyProcessReceivedPassiveGossipThread(this, gossipCore);
gossipThreadExecutor.execute(passiveGossipThread); gossipThreadExecutor.execute(passiveGossipThread);
activeGossipThread = new ActiveGossipThread(this, this.gossipCore); activeGossipThread = new ActiveGossipThread(this, this.gossipCore, registry);
activeGossipThread.init(); activeGossipThread.init();
dataReaper.init(); dataReaper.init();
scheduledServiced.scheduleAtFixedRate(() -> { scheduledServiced.scheduleAtFixedRate(() -> {

View File

@ -17,6 +17,7 @@
*/ */
package org.apache.gossip.manager.random; package org.apache.gossip.manager.random;
import com.codahale.metrics.MetricRegistry;
import org.apache.gossip.GossipMember; import org.apache.gossip.GossipMember;
import org.apache.gossip.GossipSettings; import org.apache.gossip.GossipSettings;
import org.apache.gossip.event.GossipListener; import org.apache.gossip.event.GossipListener;
@ -40,6 +41,7 @@ public class RandomGossipManager extends GossipManager {
private GossipSettings settings; private GossipSettings settings;
private List<GossipMember> gossipMembers; private List<GossipMember> gossipMembers;
private GossipListener listener; private GossipListener listener;
private MetricRegistry registry;
private ManagerBuilder() {} private ManagerBuilder() {}
@ -73,6 +75,10 @@ public class RandomGossipManager extends GossipManager {
this.listener = listener; this.listener = listener;
return this; return this;
} }
public ManagerBuilder registry(MetricRegistry registry) {
this.registry = registry;
return this;
}
public ManagerBuilder uri(URI uri){ public ManagerBuilder uri(URI uri){
this.uri = uri; this.uri = uri;
@ -84,15 +90,19 @@ public class RandomGossipManager extends GossipManager {
checkArgument(cluster != null, "You must specify a cluster name"); checkArgument(cluster != null, "You must specify a cluster name");
checkArgument(settings != null, "You must specify gossip settings"); checkArgument(settings != null, "You must specify gossip settings");
checkArgument(uri != null, "You must specify a uri"); checkArgument(uri != null, "You must specify a uri");
checkArgument(registry != null, "You must specify a MetricRegistry");
if (listener == null){
listener((a,b) -> {});
}
if (gossipMembers == null) { if (gossipMembers == null) {
gossipMembers = new ArrayList<>(); gossipMembers = new ArrayList<>();
} }
return new RandomGossipManager(cluster, uri, id, settings, gossipMembers, listener); return new RandomGossipManager(cluster, uri, id, settings, gossipMembers, listener, registry);
} }
} }
private RandomGossipManager(String cluster, URI uri, String id, GossipSettings settings, private RandomGossipManager(String cluster, URI uri, String id, GossipSettings settings,
List<GossipMember> gossipMembers, GossipListener listener) { List<GossipMember> gossipMembers, GossipListener listener, MetricRegistry registry) {
super(cluster, uri, id, settings, gossipMembers, listener); super(cluster, uri, id, settings, gossipMembers, listener, registry);
} }
} }

View File

@ -17,6 +17,7 @@
*/ */
package org.apache.gossip; package org.apache.gossip;
import com.codahale.metrics.MetricRegistry;
import java.net.URI; import java.net.URI;
import java.net.URISyntaxException; import java.net.URISyntaxException;
import java.net.UnknownHostException; import java.net.UnknownHostException;
@ -26,8 +27,6 @@ import java.util.UUID;
import java.util.concurrent.Callable; import java.util.concurrent.Callable;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
import org.apache.gossip.event.GossipListener;
import org.apache.gossip.event.GossipState;
import org.apache.gossip.model.GossipDataMessage; import org.apache.gossip.model.GossipDataMessage;
import org.apache.gossip.model.SharedGossipDataMessage; import org.apache.gossip.model.SharedGossipDataMessage;
import org.junit.Test; import org.junit.Test;
@ -52,11 +51,7 @@ public class DataTest {
URI uri = new URI("udp://" + "127.0.0.1" + ":" + (50000 + i)); URI uri = new URI("udp://" + "127.0.0.1" + ":" + (50000 + i));
GossipService gossipService = new GossipService(cluster, uri, i + "", GossipService gossipService = new GossipService(cluster, uri, i + "",
startupMembers, settings, startupMembers, settings,
new GossipListener(){ (a,b) -> {}, new MetricRegistry());
public void gossipEvent(GossipMember member, GossipState state) {
}
});
clients.add(gossipService); clients.add(gossipService);
gossipService.start(); gossipService.start();
} }

View File

@ -17,6 +17,7 @@
*/ */
package org.apache.gossip; package org.apache.gossip;
import com.codahale.metrics.MetricRegistry;
import io.teknek.tunit.TUnit; import io.teknek.tunit.TUnit;
import java.net.URI; import java.net.URI;
@ -58,7 +59,7 @@ public class ShutdownDeadtimeTest {
for (int i = 1; i < clusterMembers + 1; ++i) { for (int i = 1; i < clusterMembers + 1; ++i) {
URI uri = new URI("udp://" + "127.0.0.1" + ":" + (30300 + i)); URI uri = new URI("udp://" + "127.0.0.1" + ":" + (30300 + i));
GossipService gossipService = new GossipService(cluster, uri, i + "", startupMembers, GossipService gossipService = new GossipService(cluster, uri, i + "", startupMembers,
settings, (a,b) -> {}); settings, (a,b) -> {}, new MetricRegistry());
clients.add(gossipService); clients.add(gossipService);
gossipService.start(); gossipService.start();
} }
@ -104,7 +105,7 @@ public class ShutdownDeadtimeTest {
URI uri = new URI("udp://" + "127.0.0.1" + ":" + shutdownPort); URI uri = new URI("udp://" + "127.0.0.1" + ":" + shutdownPort);
// start client again // start client again
GossipService gossipService = new GossipService(cluster, uri, shutdownId + "", startupMembers, GossipService gossipService = new GossipService(cluster, uri, shutdownId + "", startupMembers,
settings, (a,b) -> {}); settings, (a,b) -> {}, new MetricRegistry());
clients.add(gossipService); clients.add(gossipService);
gossipService.start(); gossipService.start();

View File

@ -17,6 +17,7 @@
*/ */
package org.apache.gossip; package org.apache.gossip;
import com.codahale.metrics.MetricRegistry;
import org.apache.log4j.Logger; import org.apache.log4j.Logger;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
@ -40,7 +41,6 @@ public class StartupSettingsTest {
private static final Logger log = Logger.getLogger( StartupSettingsTest.class ); private static final Logger log = Logger.getLogger( StartupSettingsTest.class );
private static final String CLUSTER = UUID.randomUUID().toString(); private static final String CLUSTER = UUID.randomUUID().toString();
@Test @Test
public void testUsingSettingsFile() throws IOException, InterruptedException, URISyntaxException { public void testUsingSettingsFile() throws IOException, InterruptedException, URISyntaxException {
File settingsFile = File.createTempFile("gossipTest",".json"); File settingsFile = File.createTempFile("gossipTest",".json");
@ -49,7 +49,7 @@ public class StartupSettingsTest {
URI uri = new URI("udp://" + "127.0.0.1" + ":" + 50000); URI uri = new URI("udp://" + "127.0.0.1" + ":" + 50000);
final GossipService firstService = new GossipService( final GossipService firstService = new GossipService(
CLUSTER, uri, "1", CLUSTER, uri, "1",
new ArrayList<GossipMember>(), new GossipSettings(), null); new ArrayList<GossipMember>(), new GossipSettings(), null, new MetricRegistry());
firstService.start(); firstService.start();
final GossipService serviceUnderTest = new GossipService( final GossipService serviceUnderTest = new GossipService(
StartupSettings.fromJSONFile(settingsFile)); StartupSettings.fromJSONFile(settingsFile));

View File

@ -17,6 +17,7 @@
*/ */
package org.apache.gossip; package org.apache.gossip;
import com.codahale.metrics.MetricRegistry;
import io.teknek.tunit.TUnit; import io.teknek.tunit.TUnit;
import java.net.URI; import java.net.URI;
@ -58,7 +59,7 @@ public class TenNodeThreeSeedTest {
for (int i = 1; i < clusterMembers+1; ++i) { for (int i = 1; i < clusterMembers+1; ++i) {
URI uri = new URI("udp://" + "127.0.0.1" + ":" + (base + i)); URI uri = new URI("udp://" + "127.0.0.1" + ":" + (base + i));
GossipService gossipService = new GossipService(cluster, uri, i + "", GossipService gossipService = new GossipService(cluster, uri, i + "",
startupMembers, settings, (a,b) -> {}); startupMembers, settings, (a,b) -> {}, new MetricRegistry());
clients.add(gossipService); clients.add(gossipService);
gossipService.start(); gossipService.start();
} }

View File

@ -17,6 +17,7 @@
*/ */
package org.apache.gossip.manager; package org.apache.gossip.manager;
import com.codahale.metrics.MetricRegistry;
import java.net.URI; import java.net.URI;
import org.apache.gossip.GossipSettings; import org.apache.gossip.GossipSettings;
@ -30,6 +31,8 @@ import io.teknek.tunit.TUnit;
public class DataReaperTest { public class DataReaperTest {
private final MetricRegistry registry = new MetricRegistry();
@Test @Test
public void testReaperOneShot() { public void testReaperOneShot() {
String myId = "4"; String myId = "4";
@ -37,7 +40,7 @@ public class DataReaperTest {
String value = "a"; String value = "a";
GossipSettings settings = new GossipSettings(); GossipSettings settings = new GossipSettings();
GossipManager gm = RandomGossipManager.newBuilder().cluster("abc").settings(settings) GossipManager gm = RandomGossipManager.newBuilder().cluster("abc").settings(settings)
.withId(myId).uri(URI.create("udp://localhost:6000")).build(); .withId(myId).uri(URI.create("udp://localhost:6000")).registry(registry).build();
gm.init(); gm.init();
gm.gossipPerNodeData(perNodeDatum(key, value)); gm.gossipPerNodeData(perNodeDatum(key, value));
gm.gossipSharedData(sharedDatum(key, value)); gm.gossipSharedData(sharedDatum(key, value));
@ -68,7 +71,6 @@ public class DataReaperTest {
return m; return m;
} }
@Test @Test
public void testHigherTimestampWins() { public void testHigherTimestampWins() {
String myId = "4"; String myId = "4";
@ -76,7 +78,7 @@ public class DataReaperTest {
String value = "a"; String value = "a";
GossipSettings settings = new GossipSettings(); GossipSettings settings = new GossipSettings();
GossipManager gm = RandomGossipManager.newBuilder().cluster("abc").settings(settings) GossipManager gm = RandomGossipManager.newBuilder().cluster("abc").settings(settings)
.withId(myId).uri(URI.create("udp://localhost:7000")).build(); .withId(myId).uri(URI.create("udp://localhost:7000")).registry(registry).build();
gm.init(); gm.init();
GossipDataMessage before = perNodeDatum(key, value); GossipDataMessage before = perNodeDatum(key, value);
GossipDataMessage after = perNodeDatum(key, "b"); GossipDataMessage after = perNodeDatum(key, "b");

View File

@ -17,6 +17,7 @@
*/ */
package org.apache.gossip.manager; package org.apache.gossip.manager;
import com.codahale.metrics.MetricRegistry;
import org.apache.gossip.GossipMember; import org.apache.gossip.GossipMember;
import org.apache.gossip.GossipSettings; import org.apache.gossip.GossipSettings;
import org.apache.gossip.LocalGossipMember; import org.apache.gossip.LocalGossipMember;
@ -82,7 +83,7 @@ public class RandomGossipManagerBuilderTest {
.cluster("aCluster") .cluster("aCluster")
.uri(new URI("udp://localhost:2000")) .uri(new URI("udp://localhost:2000"))
.settings(new GossipSettings()) .settings(new GossipSettings())
.gossipMembers(null).build(); .gossipMembers(null).registry(new MetricRegistry()).build();
assertNotNull(gossipManager.getLiveMembers()); assertNotNull(gossipManager.getLiveMembers());
} }
@ -98,7 +99,7 @@ public class RandomGossipManagerBuilderTest {
.cluster("aCluster") .cluster("aCluster")
.settings(new GossipSettings()) .settings(new GossipSettings())
.uri(new URI("udp://localhost:8000")) .uri(new URI("udp://localhost:8000"))
.gossipMembers(memberList).build(); .gossipMembers(memberList).registry(new MetricRegistry()).build();
assertEquals(1, gossipManager.getDeadMembers().size()); assertEquals(1, gossipManager.getDeadMembers().size());
assertEquals(member.getId(), gossipManager.getDeadMembers().get(0).getId()); assertEquals(member.getId(), gossipManager.getDeadMembers().get(0).getId());
} }