Socket.D 开源输传协议的集群转发特性

news/2024/7/10 21:21:56 标签: 开源, java, 传输协议, 网络协议

1、简介

Socket.D 是基于"事件"和"语义消息""流"的网络应用层协议。底层可以依赖 TCP、UDP、KCP、WebSocket 等传输层协议。其开发背后的动机是用开销更少的协议取代超文本传输协议(HTTP),HTTP 协议对于许多任务(如微服务通信)来说效率低下。

2、Socket.D 的集群应用

在 Socket.D 的集群故事里,会有三个角色:

  • 请求者
  • 经理人(或者中间人)
  • 响应者

客户端通过 url 连接经理人后,就会成为集群的一部分。它可以是请求者,也可以是响应者。

sd:tcp://127.0.0.1:8602?@=demoapp

url 会包括:

  • 协议头(sd 表示 socket.d 协议,tcp 表示传输方案)
  • 地址与端口
  • 路径
  • 还有@参数,这个参数会申明自己的应用名字。连接经理人时,也相当于完成身份注册了。

在集群内部,相互间通过 At 进行发起向“响应者”的请求。就像:

java">session.send("test", new StringEntity("hello").at("demoapp"));

3、集群的四种转发

在集群的活动中,请求者会发消息给经理人,经理人根据 at name 再转发给相应的响应者。

  • 四种转发方式(单播,单播!,组播,广播):
at描述备注
demoapp单播给叫这个名的其中一个会话发(使用 平均轮询 “负载均衡”策略)
demoapp!单播!给叫这个名的其中一个会话发(使用 ip_hash “负载均衡”策略)
demoapp*组播给叫这个名的整组会话发(如果自己也叫这个名,则自己除外)
*广播给集群里的全部会话发(自己除外)
  • 通过at方式进行转发,示例:
java">session.send("test", new StringEntity("hello").at("demoapp"));
session.send("test", new StringEntity("hello").at("demoapp!"));
session.send("test", new StringEntity("hello").at("demoapp*"));
session.send("test", new StringEntity("hello").at("*"));

4、演示

假设经理人(或者中间人) 的服务地址为:127.0.0.1:8602。下面以 Java 语言展示效果:

  • 创建经理人
java">public class BrokerDemo {
    public static void main(String[] args) throws Exception {
        SocketD.createServer("sd:tcp")
                .config(c -> c.port(8602).fragmentHandler(new BrokerFragmentHandler()))
                .listen(new BrokerListener())
                .start();
    }
}
  • 创建响应者(自己不需要端口启动,连接经理人后即可提供服务)
java">public class ResponderDemo {
    public static void main(String[] args) throws Exception {
        //连接到 broker ,并给自己命名为:demoapp
        ClientSession session = SocketD.createClient("sd:tcp://127.0.0.1:8602?@=demoapp")
                .listen(new EventListener().doOn("/hello", (s,m)->{
                    //监听 "/hello" 事件,如果是请求则答复
                    if(m.isRequest()){
                        s.reply(m, new StringEntity("me too!"));
                    }
                }))
                .open();
    }
}
  • 创建请求者
java">public class RequesterDemo {
    public static void main(String[] args) throws Exception {
        //连接到 broker ,并给自己命名为:demotester
        ClientSession session = SocketD.createClient("sd:tcp://127.0.0.1:8602?@=demotester")
                .open();

        //发送消息,并要求转发给 "demoapp"
        session.sendAndRequest("/hello", new StringEntity("").at("demoapp")).thenReply(r->{
            //收到答复后,打印结果
            print(r.dataAsString());
        });
    }
}

http://www.niftyadmin.cn/n/5376614.html

相关文章

018_配置测试微服务基本的CRUD功能

文章目录 整合mybatis plus01 - 导入依赖02 - 配置2.1 - 配置数据源2.1.1 - 导入数据库驱动插曲:调整一下common module当中的异常报错2.1.2 - 配置数据源application.yaml2.2 - 配置mybatis-plus信息配置主键自增单元测试测试过程我们想要测试一下逆向工程生成的代码。 整合m…

[数学建模] 计算差分方程的收敛点

[数学建模] 计算差分方程的收敛点 差分方程:差分方程描述的是在离散时间下系统状态之间的关系。与微分方程不同,差分方程处理的是在不同时间点上系统状态的变化。通常用来模拟动态系统,如在离散时间点上更新状态并预测未来状态。 收敛点&…

前端秘法基础式(HTML)(第一卷)

目录 一.img标签 1.src属性 2.alt/title/width/height/border属性 二.a标签 1.href属性 2.target属性 三.表格/列表标签 1.表格标签 ​编辑 2.列表标签 2.1无序列表 2.2有序列表 一.img标签 1.src属性 img标签必须搭配src来使用,src用来指定路径 注意这里的src不…

上位机图像处理和嵌入式模块部署(上位机主要功能)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing 163.com】 目前关于机器视觉方面,相关的软件很多。比如说商业化的halcon、vision pro、vision master,当然也可以用opencv、pytorch自…

steam游戏搬砖项目靠谱吗?有没有风险?

作为一款fps射击游戏,csgo在近几年可谓是火出圈,作为一款全球竞技游戏,深受玩家喜爱追捧,玩家追求的就是公平公正,各凭本事,像其他游戏可能还会有皮肤等装备属性加成,在csgo里面是不存在的。 纯…

GPT-4影响高度创新思维的领域(一)

GPT-4的应用范围不再局限于对现有信息的检索、整理和复述,而是进一步拓展到了诸如文学创作、科学假设生成、教育辅导、商业策略建议等需要高度创新思维的领域。这种独立思考和创新能力赋予了GPT-4作为虚拟助手时更加丰富多元的角色定位,使其成为一种强大…

SpringCloud之Eureka注册中心和负载均衡

SpringCloud之Eureka注册中心和负载均衡 微服务技术栈认识微服务单体架构分布式架构微服务 微服务拆分及远程调用微服务拆分注意事项 Eureka注册中心提供者与消费者原理分析服务调用出现的问题Eureka的作用 使用流程1、搭建EurekaServer2、注册user-service3、在order-service完…

步步深入 k8s 使用 pv pvc sc 在 nfs 基础上共享存储

博客原文 文章目录 前言集群环境nfs 环境搭建pod 挂载 nfs架构图 pvc 方式挂载 nfs架构图 storageclass 方式动态申请 pv架构图 参考 前言 持久化卷(Persistent Volume, PV)允许用户将外部存储映射到集群,而持久化卷申请(Persist…