SocketD协议消息订阅模式怎么实现

发布时间:2021-12-21 14:14:18 作者:iii
来源:亿速云 阅读:160

这篇文章主要介绍“SocketD协议消息订阅模式怎么实现”,在日常操作中,相信很多人在SocketD协议消息订阅模式怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”SocketD协议消息订阅模式怎么实现”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

SocketD 是一种二进制的点对点通信协议,是一种新的网络通信第七层协议。旨在用于分布式应用程序中。从这个意义上讲,SocketD可以是RSocket等其他类似协议的替代方案。它的消息协议规范具有异步,背压的双向,多路复用,断线重连,基于消息等特性。暂时只提供Java实现,目前做为Solon rpc的sockte通道协议。

本案以简单的消息订阅模式为例演示:(即等着你给我来信,例如配置服务的变更通知)

服务端

//启动服务端
public class ServerApp {
    public static void main(String[] args) {
        //启动Solon容器(SocketD bean&plugin 由solon容器管理)
        Solon.start(ServerApp.class, args, app -> app.enableSocketD(true));
    }
}

//定义一个给所有会话广播的工具
public class SessionUtil {
    public static void broadcast(Message message){
        for(Session session : SessionManager.socket().getOpenSessions()){
            session.send(message);
        }
    }

    public static void broadcast(String message){
        for(Session session : SessionManager.socket().getOpenSessions()){
            session.send(message);
        }
    }
}

//在需要的地方,进行广播(例如:配置服务的更新通知)
SessionUtil.broadcast("Hello client!");

客户端

//启动客户端
public class ClientApp {
    public static void main(String[] args) throws Throwable {
        //启动Solon容器(SocketD bean&plugin 由solon容器管理)
        Solon.start(ClientApp.class, args);
    }
}

@ClientEndpoint(uri = "tcp://localhost:28080")
public class ClientListener implements Listener {
    @Override
    public void onMessage(Session session, Message message) {
        //收到消息,业务处理
        System.out.println("客户端:我收到了:" + message);
    }
}

到此,关于“SocketD协议消息订阅模式怎么实现”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

推荐阅读:
  1. 如何用MQTT协议实现消息的订阅接收?
  2. JMS消息队列ActiveMQ(发布/订阅模式)

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

socketd

上一篇:Kali Linux中WPScan2.9.3增加了什么新功能

下一篇:怎么在Kubernetes上大规模运行CI/CD

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》