Akka actor resizer没有创建实例

时间:2017-08-05 08:09:36

标签: java akka actor akka-actor

我尝试在循环池的akka​​路由中使用 resizer 。但它不是创建实例。它正在处理我在下限中提到的实例。我正在关注akka 版本2.5.3 的文档。

我的配置:

akka.actor.deployment {
/round-robin-resizer {
router = round-robin-pool
resizer {
  lower-bound = 4
  upper-bound = 30
  pressure-threshold = 0
  rampup-rate = 0.5
  messages-per-resize = 1
}

}

演员班:

return receiveBuilder()
    .match(Integer.class, msg -> {
        System.out.println("Message :  " + msg + " Thread id : " + Thread.currentThread().getId());
        Thread.sleep(5000);
    })
    .matchAny(msg -> {
         System.out.println("Error Message :  " + msg + " Thread id : " + Thread.currentThread().getId());
    }).build();

}

创建演员:

ActorRef roundRobin = system.actorOf(FromConfig.getInstance().props(Props.create(RoutingActor.class)), "round-robin-resizer");
    for (int i = 0; i < 15; i++) {
        roundRobin.tell(i, ActorRef.noSender());
    }

输出

Message : 2  Thread id : 18
Message : 1  Thread id : 16
Message : 0  Thread id : 15
Message : 3  Thread id : 17
Message : 7  Thread id : 17
Message : 4  Thread id : 15
Message : 6  Thread id : 18
Message : 5  Thread id : 16
Message : 11  Thread id : 17
Message : 9  Thread id : 16
Message : 10  Thread id : 18
Message : 8  Thread id : 15
Message : 13  Thread id : 16
Message : 14  Thread id : 18
Message : 12  Thread id : 15

每4个结果后,它等待5秒钟才能完成前一个实例的工作。

查看主题ID 。对于演员实例的每次创建,我都会让我的线程休息一段时间。在新实例应该在不同的线程上分配。但这个过程一直持续到前三个实例。之后,它不会根据缩放器创建新实例。它按照循环池的正常流程附加消息。

1 个答案:

答案 0 :(得分:0)

你对thread-id和实际的actor实例感到困惑。 actors实例的数量与线程数不匹配。请在其他类似问题中参考此答案:Akka ConsistentHashingRoutingLogic not routing to the same dispatcher thread consistently