我目前正在使用播放框架(版本 2.0.1)。我的应用程序需要收听 udp 广播消息。所以我需要一个新线程来监视套接字并接收所需的字节。在查看 play 框架后,似乎 Akka 系统用于处理线程/作业。所以我实现了一个新的后台 akka 任务来读取我的套接字。见下文。一切都按我的预期工作,我能够在后台任务中接收我想要的数据。我遇到的问题是当我关闭服务器时。在开发中按下 Control D。它显示消息“[info] play - 关闭应用程序默认 Akka 系统。” 但随后挂起并且永远不会关闭我的后台线程。
public running = false;
public void onReceive(Object message) {
if (message instanceof SystemConfiguration) {
try {
InetAddress group = InetAddress.getByName("222.1.1.1");
MulticastSocket socket = new MulticastSocket(54321);
socket.joinGroup(group);
running = true;
while (running) {
Logger.info("MultiCastController - waiting to receive message");
byte[] buf = new byte[1000];
DatagramPacket recv = new DatagramPacket(buf, buf.length);
socket.setSoTimeout(30000);
try {
socket.receive(recv);
String msgString = new String(recv.getData()).trim();
Logger.info("retreived: " + msgString);
} catch (SocketTimeoutException e) {
Logger.info("MultiCastController - timed out"
+ recv.getData().toString());
}
}
} catch (Exception ex) {
Logger.info("Errror message caught: " + ex.toString());
}
} else {
Logger.info("Error starting multicast receiver incorrect value passed: ");
}
}
我试图覆盖 post stop,但它似乎从未被调用过。我也尝试过 akka.system().isTerminated() 但它没有用。
@Override
public void postStop()
{
Logger.info("MultiCastController - postStop() - stopping thread");
running = false;
}
我一直在寻找的另一个可能的选择是有什么方法可以获取 akka 状态吗?它正在关闭,所以我可以做类似的事情
同时(运行 && akka.system().alive())。我发现如果我收到一条消息,它会崩溃,因为 ebean 服务器已关闭。我什至可以做一个黑客并检查它是否以某种方式活着吗?
同时(运行 && ebean.server.isalive())