AkkaTypedActor无法获取UDP发送方
创始人
2024-08-05 13:00:12
0

当使用 Akka Typed Actor 发送 UDP 消息时,无法直接从消息中获取发送方的地址和端口。但可以通过重写 UntypedActorContext 中的消息处理方法,并从消息的底层 Java API 中获取发送方地址和端口来解决该问题。

下面是一个示例代码段:

import akka.actor.typed.ActorRef;
import akka.actor.typed.Behavior;
import akka.actor.typed.javadsl.ActorContext;
import akka.actor.typed.javadsl.Behaviors;
import akka.actor.UntypedActorContext;
import akka.io.AbstractDatagramChannelAdapter;
import akka.io.Inet.SocketOption;
import akka.io.Udp;

import java.net.InetSocketAddress;
import java.nio.ByteBuffer;
import java.util.Arrays;
import java.util.Collections;

public class UdpSender {
    private static final InetSocketAddress udpAddress = new InetSocketAddress("localhost", 5465);

    public static Behavior create() {
        return Behaviors.setup(context -> {
            ActorRef udp = context.spawn(UdpSend.create(), "udp-sender");
            return Behaviors.receive(String.class)
                .onMessage(String.class, msg -> {
                    String data = "Hello, " + msg;
                    ByteBuffer buffer = ByteBuffer.wrap(data.getBytes());
                    udp.tell(UdpSend.Send.create(buffer, udpAddress), context.getSelf());
                    return Behaviors.same();
                })
                .build();
        });
    }

    // UntypedActorContext 中的消息处理方法
    public static class UdpSend extends AbstractDatagramChannelAdapter {

        static final InetSocketAddress local = new InetSocketAddress("localhost", 5466);

        public UdpSend(UntypedActorContext context) {
            super(Udp.get(context.getSystem()).getManager());
            getDatagramChannel().configureBlocking(false);
            getDatagramChannel().socket().bind(local);
            register(getInput());
        }

        public static Behavior create() {
            return Behaviors.setup(ctx ->
                    Behaviors.receivePacket(Udp.Command.class)
                            .onMessage(UdpSend.Send.class, (udp, send) -> {
                                InetSocketAddress remote = send.getRemoteAddress();
                                ByteBuffer data = send.getPayload();
                                udp.tell(UdpMessage.send(data, Collections

相关内容

热门资讯

安装apache-beam==... 出现此错误可能是因为用户的Python版本太低,而apache-beam==2.34.0需要更高的P...
避免在粘贴双引号时向VS 20... 在粘贴双引号时向VS 2022添加反斜杠的问题通常是由于编辑器的自动转义功能引起的。为了避免这个问题...
Android Recycle... 要在Android RecyclerView中实现滑动卡片效果,可以按照以下步骤进行操作:首先,在项...
omi系统和安卓系统哪个好,揭... OMI系统和安卓系统哪个好?这个问题就像是在问“苹果和橘子哪个更甜”,每个人都有自己的答案。今天,我...
原生ios和安卓系统,原生对比... 亲爱的读者们,你是否曾好奇过,为什么你的iPhone和安卓手机在操作体验上有着天壤之别?今天,就让我...
Android - 无法确定任... 这个错误通常发生在Android项目中,表示编译Debug版本的Java代码时出现了依赖关系问题。下...
Android - NDK 预... 在Android NDK的构建过程中,LOCAL_SRC_FILES只能包含一个项目。如果需要在ND...
Akka生成Actor问题 在Akka框架中,可以使用ActorSystem对象生成Actor。但是,当我们在Actor类中尝试...
Agora-RTC-React... 出现这个错误原因是因为在 React 组件中使用,import AgoraRTC from “ago...
Alertmanager在pr... 首先,在Prometheus配置文件中,确保Alertmanager URL已正确配置。例如:ale...