Nepxion-Thunder(QQ 群 471164539)发布在https://github.com/Nepxion/
- 1 ServerExecutor.java - 服务端运行器接口
interfaze :接口名(例如com.nepxion.thunder.test.service.UserService)
applicationEntity包含四个参数:application(应用名),group(组名),host(服务地址),port(端口)。应用名和组名的作用,一是为了管理方便,二是防止同名接口的出现
ServerExecutor.java作用是根据接口名+应用名+组名+服务地址+端口发布一个服务 - 2 AbstractServerExecutor.java - ServerExecutor.java的抽象实现,具体逻辑到各个通信中间件的去实现
- 3 ServerExecutorAdapter.java - 继承AbstractDominationExecutor.java,服务端处理逻辑的封装适配,分为三部分:处理结果(安全访问的拦截),处理异常,处理监控。服务端的处理是异步多线程
- 4 ClientExecutor.java - 调用端运行器接口
ClientExecutor.java作用是根据接口名+应用名+组名+服务地址+端口获取一个服务,对服务上下线后的回调 - 5 AbstractClientExecutor.java - ClientExecutor.java的抽象实现,具体逻辑到各个通信中间件的去实现
- 6 ClientExecutorAdapter.java - 继承AbstractDominationExecutor.java,调用端处理逻辑的封装适配,分为四部分:处理同步/异步返回结果(异步心跳和广播忽略),处理异常,处理监控。同步模式下,用CyclicBarrier做异步模拟同步等待
-
7 ClientInterceptor.java - 调用端代理拦截器
ClientInterceptor.java作用是提供异步调用,同步调用,广播调用三种方式接口 - 8 AbstractClientInterceptor.java - 调用端代理拦截器的抽象实现,具体逻辑到各个通信中间件的去实现
- 9 ClientInterceptorAdapter.java - 调用端代理拦截器的处理逻辑封装适应。主要是同步的处理逻辑,异步不同通信中间件方式不一样,不做封装
- 10 DominationExecutor.java - 服务治理器接口
- 11 AbstractDominationExecutor.java - DominationExecutor.java的抽象实现,主要处理监控和事件输出
-
12 ProtocolException - 协议异常类
Thunder在通信过程中,以序列化的对象为消息载体,基础消息类是ProtocolMessage,派生类ProtocolRequest为请求载体,派生类ProtocolResponse为响应载体 -
13 ProtocolMessage.java - 序列化类
private String messageId; // UUID.randomUUID()的随机字符串,作为消息的唯一ID private String traceId; // 全局跟踪ID private String interfaze; // 接口名 private String metho; // 方法名 protected Class<?>[] parameterTypes; // 参数类型 protected Object[] parameters; // 参数值 private boolean async; // 异步或者同步请求 private String callback; // 回调接口名(只用于异步方法) private long timeout; // 超时时间(只用于同步方法) private boolean broadcast; // 广播模式(广播模式前提必须是异步请求) private boolean heartbeat; // 心跳模式 private boolean feedback; // 是否需要服务端反馈结果(只用于异步方法,有一种调用方式,客户端只把请求发送出去,不需要服务端返回) private long processStartTime; // 调用的业务处理起始时间 private long processEndTime; // 调用的业务处理结束时间 private long deliverStartTime; // 调用的网络传输起始时间 private long deliverEndTime; // 调用的网络传输结束时间 private String fromCluster; // 消息从哪个集群发出 private String fromUrl; // 消息从哪个Url发出 private String toCluster; // 消息发往哪个集群 private String toUrl; // 消息发往哪个Url private Object requestSource; // 请求Source(一般是IP:Port格式的字符串),只作为消息队列MQ Selector用 private Object responseSource; // 响应Source(一般是(IP:Port格式的字符串),只作为消息队列MQ Selector用
-
14 ProtocolRequest.java - 调用端发送到服务端的请求类,继承于ProtocolMessage.java,序列化类
private ReferenceConfig referenceConfig; // 包含secretKey(密钥),version(版本)等,发送到服务端,用于匹配
-
15 ProtocolResponse.java - 服务端返回到调用端的响应类,继承于ProtocolMessage.java,序列化类
private Object result; // 调用的结果
相关推荐
Coroutine是基于Kilim/Promise JDeferred的协程式驱动框架,基于Apache Zookeeper的分布式规则存储和动态规则变更通知。 主要特性: 1. 基于微服务框架理念设计 2. 支持同步/异步调用 3. 支持串行/并行调用 4....
Nepxion Thunder是一款基于Netty + Hessian + Kafka + ActiveMQ + Tibco + Zookeeper(Curator Framework) + Redis + FST + Spring + Spring Web MVC + Spring Boot + Docker分布式RPC调用框架。架构思想主要是来自...
yinheli/docker-thunder-xware:latest 镜像打包下载 群晖 NAS DSM 系统,只要三步使用 Docker 安装迅雷远程下载
Thunder ⚡️ 一个Go框架用于快速构建强大的graphql服务
wine-thunder_0.6-2_all.deb用于在linux系统下,使用wine直接按装的迅雷软件,实现高速下载,在ubunut,fedora等linux版本中,实现直接点击安装
开源项目-omeid-thunder.zip,Thunder Bolt = High Productivity
A10-Thunder_930方案白皮书.pdf
A10-Thunder_1030S方案白皮书.pdf
开源项目-muesli-thunder.zip,thunder, an interactive shell for BoltDB
A10-Thunder_5430S方案白皮书
A10-Thunder_6430S方案白皮书.pdf
系统工具-文件下载-Thunderbird91.0b4.zip
系统工具-文件下载-thunder_3.4.0.4338.zip
A10-Thunder_5430S方案白皮书.pdf
3D-Thunder-Lightning.zip,受航母指令启发的开源未来动作飞行模拟器游戏,3D建模使用专门的软件来创建物理对象的数字模型。它是3D计算机图形的一个方面,用于视频游戏,3D打印和VR,以及其他应用程序。
Thunder Android OkHttp util package let response callback at MainThread(UIThread), also it‘s lifecycle safety. ⚠️ Thunder‘s code is based on SugarTask(Very nice code
please update the test cases that cannot compile any more
实时过境雷湾 ... 运行npm install live-transit-thunder-bay --save 使用 API: var liveTransit = require ( 'live-transit-thunder-bay' ) ; liveTransit . start ( ) ; 运行node index.js 。 Expres
docker pull yinheli/docker-thunder-xware:latest 创建一个下载目录. 用于挂载卷 mkdir data 运行 docker run -d \ --name=xware \ --net=host \ -v $(pwd)/data:/app/TDDOWNLOAD \ yinheli/docker-thunder-...
【批量下载】Thunder-Download-Extension-for-Chrome_v3.1