2018-03-13 23:45:55 +09:00
|
|
|
/*
|
2019-01-02 18:55:26 +08:00
|
|
|
* Copyright (C) 2018-2019 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
|
|
|
|
|
|
|
|
import java.util.HashMap;
|
|
|
|
|
import java.util.Map;
|
|
|
|
|
|
2017-02-23 00:50:07 +05:00
|
|
|
import akka.actor.AbstractActor;
|
2017-02-14 13:10:23 +02:00
|
|
|
|
|
|
|
|
//#worker
|
2017-02-23 00:50:07 +05:00
|
|
|
public class StatsWorker extends AbstractActor {
|
2017-02-14 13:10:23 +02:00
|
|
|
|
|
|
|
|
Map<String, Integer> cache = new HashMap<String, Integer>();
|
|
|
|
|
|
|
|
|
|
@Override
|
2017-02-23 00:50:07 +05:00
|
|
|
public Receive createReceive() {
|
|
|
|
|
return receiveBuilder()
|
|
|
|
|
.match(String.class, word -> {
|
|
|
|
|
Integer length = cache.get(word);
|
|
|
|
|
if (length == null) {
|
|
|
|
|
length = word.length();
|
|
|
|
|
cache.put(word, length);
|
|
|
|
|
}
|
2017-03-16 09:30:00 +01:00
|
|
|
getSender().tell(length, getSelf());
|
2017-02-23 00:50:07 +05:00
|
|
|
})
|
|
|
|
|
.build();
|
2017-02-14 13:10:23 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
//#worker
|