akka actor
在这里,我演示了使用Akka发送电子邮件并以Java实现的示例应用程序。
我决定使用并发以外的其他Akka框架的原因。
- 内置的可配置管理程序策略可监视童工并确定在发生异常时适用的策略。
- 当应用程序抛出某些特定异常时,可以重新安排交付时间。
- 使用actor路由器,并允许他们使用actor连接池。
这是创建监督策略的方法。
class EmailServiceActor extends UntypedActor {
private static SupervisorStrategy strategy =
new OneForOneStrategy(10, Duration.create("1 minute"),
new Function<Throwable, Directive>() {
@Override
public Directive apply(Throwable t) {
if (t instanceof MessagingException) {
return resume();
} else if (t instanceof Exception) {
return stop();
} else {
return escalate();
}
}
});
@Override
public void onReceive(Object message) {
getContext().actorOf(new Props(EmailServiceWorker.class)).tell(message, self());
}
@Override
public SupervisorStrategy supervisorStrategy() {
return strategy;
}
}
这是童工的创造方式
class EmailServiceWorker extends UntypedActor {
@Override
public void onReceive(Object message) {
try {
EmailService emailService = new EmailService();
emailService.sendEmail();
} catch (IOException e) {
e.printStackTrace(); //To change body of catch statement use File | Settings | File Templates.
} catch (MessagingException e) {
e.printStackTrace(); //To change body of catch statement use File | Settings | File Templates.
}
}
@Override
public void preStart() {
// getContext().system().scheduler().scheduleOnce(Duration.create(5, TimeUnit.SECONDS), self(), "emailWorker", getContext().system().dispatcher(), null);
}
@Override
public void postStop() {
}
}
示例应用程序– https://github.com/rajithd/email-service-akka
翻译自: https://www.javacodegeeks.com/2013/10/sending-email-with-java-and-akka-actors.html
akka actor