2018-10-29 17:19:37 +08:00
|
|
|
/*
|
2019-01-02 18:55:26 +08:00
|
|
|
* Copyright (C) 2015-2019 Lightbend Inc. <https://www.lightbend.com>
|
2015-09-04 08:53:36 +02:00
|
|
|
*/
|
2018-03-13 23:45:55 +09:00
|
|
|
|
2017-03-16 09:30:00 +01:00
|
|
|
package jdocs.cluster;
|
2015-09-04 08:53:36 +02:00
|
|
|
|
2017-03-17 03:02:47 +08:00
|
|
|
import akka.testkit.javadsl.TestKit;
|
2015-09-04 08:53:36 +02:00
|
|
|
import com.typesafe.config.ConfigFactory;
|
2018-04-30 17:21:35 +09:00
|
|
|
|
|
|
|
|
import java.util.LinkedList;
|
|
|
|
|
import java.util.List;
|
2017-06-29 16:58:19 +02:00
|
|
|
import java.util.Set;
|
2017-03-16 09:30:00 +01:00
|
|
|
import jdocs.AbstractJavaTest;
|
2015-09-04 08:53:36 +02:00
|
|
|
import org.junit.AfterClass;
|
|
|
|
|
import org.junit.BeforeClass;
|
|
|
|
|
import org.junit.Test;
|
|
|
|
|
|
2018-04-30 17:21:35 +09:00
|
|
|
//#join-seed-nodes-imports
|
|
|
|
|
import akka.actor.Address;
|
2015-09-04 08:53:36 +02:00
|
|
|
import akka.cluster.Cluster;
|
2018-04-30 17:21:35 +09:00
|
|
|
|
|
|
|
|
//#join-seed-nodes-imports
|
|
|
|
|
import akka.actor.ActorSystem;
|
2017-06-29 16:58:19 +02:00
|
|
|
import akka.cluster.Member;
|
2015-09-04 08:53:36 +02:00
|
|
|
|
|
|
|
|
|
2016-02-11 16:39:25 +01:00
|
|
|
public class ClusterDocTest extends AbstractJavaTest {
|
2015-09-04 08:53:36 +02:00
|
|
|
|
|
|
|
|
static ActorSystem system;
|
|
|
|
|
|
|
|
|
|
@BeforeClass
|
|
|
|
|
public static void setup() {
|
|
|
|
|
system = ActorSystem.create("ClusterDocTest",
|
2017-02-14 13:10:23 +02:00
|
|
|
ConfigFactory.parseString(scala.docs.cluster.ClusterDocSpec.config()));
|
2015-09-04 08:53:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@AfterClass
|
|
|
|
|
public static void tearDown() {
|
2017-03-17 03:02:47 +08:00
|
|
|
TestKit.shutdownActorSystem(system);
|
2015-09-04 08:53:36 +02:00
|
|
|
system = null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
public void demonstrateLeave() {
|
|
|
|
|
//#leave
|
|
|
|
|
final Cluster cluster = Cluster.get(system);
|
|
|
|
|
cluster.leave(cluster.selfAddress());
|
|
|
|
|
//#leave
|
|
|
|
|
|
|
|
|
|
}
|
2017-06-29 16:58:19 +02:00
|
|
|
|
|
|
|
|
// compile only
|
|
|
|
|
@SuppressWarnings("unused")
|
|
|
|
|
public void demonstrateDataCenter() {
|
|
|
|
|
//#dcAccess
|
|
|
|
|
final Cluster cluster = Cluster.get(system);
|
|
|
|
|
// this node's data center
|
|
|
|
|
String dc = cluster.selfDataCenter();
|
|
|
|
|
// all known data centers
|
|
|
|
|
Set<String> allDc = cluster.state().getAllDataCenters();
|
|
|
|
|
// a specific member's data center
|
|
|
|
|
Member aMember = cluster.state().getMembers().iterator().next();
|
|
|
|
|
String aDc = aMember.dataCenter();
|
|
|
|
|
//#dcAccess
|
|
|
|
|
}
|
2015-09-04 08:53:36 +02:00
|
|
|
|
2018-04-30 17:21:35 +09:00
|
|
|
// compile only
|
|
|
|
|
@SuppressWarnings("unused")
|
|
|
|
|
public void demonstrateJoinSeedNodes() {
|
|
|
|
|
//#join-seed-nodes
|
|
|
|
|
final Cluster cluster = Cluster.get(system);
|
|
|
|
|
List<Address> list = new LinkedList<>(); //replace this with your method to dynamically get seed nodes
|
|
|
|
|
cluster.joinSeedNodes(list);
|
|
|
|
|
//#join-seed-nodes
|
|
|
|
|
}
|
2015-09-04 08:53:36 +02:00
|
|
|
}
|