2018-03-13 23:45:55 +09:00
|
|
|
/*
|
2020-01-02 07:24:59 -05:00
|
|
|
* Copyright (C) 2018-2020 Lightbend Inc. <https://www.lightbend.com>
|
2018-03-13 23:45:55 +09:00
|
|
|
*/
|
|
|
|
|
|
2017-03-16 09:30:00 +01:00
|
|
|
package jdocs.cluster;
|
2017-02-14 13:10:23 +02:00
|
|
|
|
2017-03-16 09:30:00 +01:00
|
|
|
import static jdocs.cluster.TransformationMessages.BACKEND_REGISTRATION;
|
|
|
|
|
import jdocs.cluster.TransformationMessages.TransformationJob;
|
|
|
|
|
import jdocs.cluster.TransformationMessages.TransformationResult;
|
2017-02-23 00:50:07 +05:00
|
|
|
import akka.actor.AbstractActor;
|
2017-02-14 13:10:23 +02:00
|
|
|
import akka.cluster.Cluster;
|
|
|
|
|
import akka.cluster.ClusterEvent.CurrentClusterState;
|
|
|
|
|
import akka.cluster.ClusterEvent.MemberUp;
|
|
|
|
|
import akka.cluster.Member;
|
|
|
|
|
import akka.cluster.MemberStatus;
|
|
|
|
|
|
2019-01-12 04:00:53 +08:00
|
|
|
// #backend
|
2017-02-23 00:50:07 +05:00
|
|
|
public class TransformationBackend extends AbstractActor {
|
2017-02-14 13:10:23 +02:00
|
|
|
|
2017-03-16 09:30:00 +01:00
|
|
|
Cluster cluster = Cluster.get(getContext().getSystem());
|
2017-02-14 13:10:23 +02:00
|
|
|
|
2019-01-12 04:00:53 +08:00
|
|
|
// subscribe to cluster changes, MemberUp
|
2017-02-14 13:10:23 +02:00
|
|
|
@Override
|
|
|
|
|
public void preStart() {
|
2017-03-17 10:18:15 +01:00
|
|
|
cluster.subscribe(getSelf(), MemberUp.class);
|
2017-02-14 13:10:23 +02:00
|
|
|
}
|
|
|
|
|
|
2019-01-12 04:00:53 +08:00
|
|
|
// re-subscribe when restart
|
2017-02-14 13:10:23 +02:00
|
|
|
@Override
|
|
|
|
|
public void postStop() {
|
2017-03-17 10:18:15 +01:00
|
|
|
cluster.unsubscribe(getSelf());
|
2017-02-14 13:10:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
2017-02-23 00:50:07 +05:00
|
|
|
public Receive createReceive() {
|
|
|
|
|
return receiveBuilder()
|
2019-01-12 04:00:53 +08:00
|
|
|
.match(
|
|
|
|
|
TransformationJob.class,
|
|
|
|
|
job -> {
|
|
|
|
|
getSender().tell(new TransformationResult(job.getText().toUpperCase()), getSelf());
|
|
|
|
|
})
|
|
|
|
|
.match(
|
|
|
|
|
CurrentClusterState.class,
|
|
|
|
|
state -> {
|
|
|
|
|
for (Member member : state.getMembers()) {
|
|
|
|
|
if (member.status().equals(MemberStatus.up())) {
|
|
|
|
|
register(member);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
.match(
|
|
|
|
|
MemberUp.class,
|
|
|
|
|
mUp -> {
|
|
|
|
|
register(mUp.member());
|
|
|
|
|
})
|
|
|
|
|
.build();
|
2017-02-14 13:10:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void register(Member member) {
|
|
|
|
|
if (member.hasRole("frontend"))
|
2019-01-12 04:00:53 +08:00
|
|
|
getContext()
|
|
|
|
|
.actorSelection(member.address() + "/user/frontend")
|
|
|
|
|
.tell(BACKEND_REGISTRATION, getSelf());
|
2017-02-14 13:10:23 +02:00
|
|
|
}
|
|
|
|
|
}
|
2019-01-12 04:00:53 +08:00
|
|
|
// #backend
|