Solon rpc 之 SocketD 协议系列

Solon rpc 之 SocketD 协议 - 概述

Solon rpc 之 SocketD 协议 - 消息上报模式

Solon rpc 之 SocketD 协议 - 消息应答模式

Solon rpc 之 SocketD 协议 - 消息订阅模式

Solon rpc 之 SocketD 协议 - RPC调用模式

Solon rpc 之 SocketD 协议 - 单链接双向RPC模式

Solon rpc 之 SocketD 协议 - 消息加密模式

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

本案以单链接双向RPC模式为例演示:(在RPC调用模式基础上,增加服务端反向接口调用)

接口定义

Rpc 模式借用了 Nami 做客户端定义(Nami 是 Solon 伴生框架,定位为 Rpc 通用客户端)

@NamiClient("demo:/demoe/rpc")
public interface HelloService {
String hello(String name);
} @NamiClient("demo:/demoe/rpc/name")
public interface NameService {
String name(String name);
}

服务端

//启动服务端
public class ServerApp {
public static void main(String[] args) {
//启动Solon容器(SocketD bean&plugin 由solon容器管理)
Solon.start(ServerApp.class, args, app -> app.enableSocketD(true));
}
} //定义远程服务组件(供客户端调用)
@Mapping(value = "/demoe/rpc", method = MethodType.SOCKET)
@Component(remoting = true)
public class HelloServiceImpl implements HelloService {
public String hello(String name) {
//[服务端] 反向调用 [客户端] 的远程服务组件***
NameService rpc = SocketD.create(Context.current(), NameService.class);
name = rpc.name(name); return "name=" + name;
}
}

客户端

//启动客户端
public class ClientApp {
public static void main(String[] args) throws Throwable {
//启动Solon容器(SocketD bean&plugin 由solon容器管理)
Solon.start(ClientApp.class, args); //[客户端] 调用 [服务端] 的 rpc
//
HelloService rpc = SocketD.create("tcp://localhost:28080", HelloService.class); System.out.println("RPC result: " + rpc.hello("noear"));
}
} //定义远程服务组件(供服务端调用)
@Mapping(value = "/demoe/rpc/name", method = MethodType.SOCKET)
@Component(remoting = true)
public class NameServiceImpl implements NameService {
@Override
public String name(String name) {
return name + "2";
}
}

附:示例源码

最新文章

  1. [No000023]为何没有更多人从事程序员的工作?程序员常有,优秀程序员不常有!
  2. VS2010编译Qt4.8.2的64版本库
  3. 第八篇 SQL Server安全数据加密
  4. 【原文】前端程序员必须知道的高性能Javascript知识
  5. c#写入Mysql中文显示乱码 解决方法
  6. C# 结构体保存自定义文件 实例部分代码(转)
  7. 统计建模与R软件习题二答案
  8. PKU 3667 Hotel(线段树)
  9. folat i = 0.1; 警告
  10. hdu Text Reverse
  11. .Net轻量级ORM-NPoco的使用方法-摘自NPoco国外官方Wiki
  12. How To Use Linux epoll with Python
  13. Android Jetpack 组建介绍(一)——Lifecycler
  14. Java-Servlet--《12-WEB应用中的普通Java程序如何读取资源文件.mp4》 有疑问
  15. 【数位dp】Beautiful Numbers @2018acm上海大都会赛J
  16. Laravel: 基础篇
  17. 个人博客作业-Week2 (代码规范, 代码复审)
  18. Expm 2_2 查找中项问题
  19. Python code 提取UML
  20. 多个so中模板单例的多次实例化

热门文章

  1. mock.js 和easy-mock使用
  2. 【题解】AcWing 389. 直径
  3. Dwango Programming Contest 6th E 题解
  4. 题解 CF1426E - Rock, Paper, Scissors
  5. CentOS 6.8内核版本升级
  6. 精尽Spring MVC源码分析 - 文章导读
  7. B树——插入和删除
  8. md5 的基本使用
  9. Unity 操作快捷键
  10. K8S安装Kubesphere