Solon 开源框架讲的“三源合一”是怎么回事?

2024-01-29 15:20

本文主要是介绍Solon 开源框架讲的“三源合一”是怎么回事?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、什么是“三源合一”?

“三源合一”,是 Solon 应用开发框架早期的一个架构想法。是指 Http、Socket、WebSocket 几个不同的通讯信号,进行统一架构处理…并且小巧。 对于 Socket 和 WebSocket,在原 消息+监听 的模式之外增加了 Mvc 模式(即 Handler + Context 接口处理)。

现在看来包括消息中间件的消息处理等等,都是可以转换成 Mvc 模式。怎么实现?这个太长了,这里只讲应用效果。

2、Http Mvc

public class DemoApp {public static void main(String[] args) {Solon.start(DemoApp.class, args);}
}@Controller
public class HelloController {@Mapping("/mvc/hello")public Result hello(long id, String name) { //{code:200,...}return Result.succeed();}
}

Http 怎么调用?就不细讲了。

3、Socket Mvc(使用 Socket.D 协议的请求答复接口)

Socket.D 通读协议,在设计之前就考虑了一个接口(sendAndRequest)用于兼容 Http 的请求模式,也称为应签模式。具体参考:《Socket.D 协议转为 Mvc 接口》

public class DemoApp {public static void main(String[] args) {Solon.start(DemoApp.class, args, app -> {app.enableSocketD(true);});}
}//ToHandlerListene 监听器,会把 Socket.D 消息包转换成 Handler + Context 接口
@ServerEndpoint("/mvc/")
public class SocketdAsMvc extends ToHandlerListener {
}@Controller
public class HelloController {@Mapping("/mvc/hello")public Result hello(long id, String name) { //{code:200,...}return Result.succeed();}
}

假如我们服务端启用的是sd:ws协议架构,客户端要怎么调用?三种方式:

  • 使用 java socket.d 原生接口调用
let clientSession = SocketD.createClient("sd:ws://localhost:28082/mvc/?u=a").open();let request = new StringEntity("{id:1,name:'noear'}").metaPut("Content-Type","text/json"),
let response = clientSession.sendAndRequest("/mvc/hello",  entity).await();
  • 使用 java rpc 代理模式调用
HelloService rpc = SocketdProxy.create("sd:ws://localhost:28082/mvc/?u=a", HelloService.class);System.out.println("MVC result:: " + mvc.hello("noear"));
  • 使用 js socket.d.js 调用(兼容:浏览器, uniapp(h5, android, ios), weixin, node.js)
const clientSession = await SocketD.createClient("sd:ws://127.0.0.1:28082/mvc/?u=a").open();//添加用户(加个内容类型,方便与 Mvc 对接)
const entity = SocketD.newEntity("{id:1,name:'noear'}").metaPut("Content-Type","text/json"),
clientSession.sendAndRequest("/mvc/hello",  entity, reply=>{alert(reply.dataAsString());
})

4、WebSocket Mvc(使用 Socket.D 的请求答复接口)

看起来是简单的,用起来还是要费点功夫的。具体参考:《WebSocket 协议转换为 Socket.D》

public class DemoApp {public static void main(String[] args) {Solon.start(DemoApp.class, args, app -> {app.enableWebSocket(true);});}
}//ToSocketdWebSocketListener 监听器,会把 WebSocket 转换成 Socket.D 协议;
//ToHandlerListene 监听器,会把 Socket.D 消息包转换成 Handler + Context 接口;(一共做了两次转换)
@ServerEndpoint("/mvc/")
public class WebSocketdAsMvc extends ToSocketdWebSocketListener {public WebSocketAsMvc() {super(new ConfigDefault(false), new ToHandlerListener());}
}@Controller
public class HelloController {@Mapping("/mvc/hello")public Result hello(long id, String name) { //{code:200,...}return Result.succeed();}
}

WebSocket 转换为 Socket.D 协议,就可以使用 Socket.D 的接口去调用了:)

这篇关于Solon 开源框架讲的“三源合一”是怎么回事?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/657336

相关文章

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

金融业开源技术 术语

金融业开源技术  术语 1  范围 本文件界定了金融业开源技术的常用术语。 本文件适用于金融业中涉及开源技术的相关标准及规范性文件制定和信息沟通等活动。

安全管理体系化的智慧油站开源了。

AI视频监控平台简介 AI视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。用户只需在界面上进行简单的操作,就可以实现全视频的接入及布控。摄像头管理模块用于多种终端设备、智能设备的接入及管理。平台支持包括摄像头等终端感知设备接入,为整个平台提

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

数据治理框架-ISO数据治理标准

引言 "数据治理"并不是一个新的概念,国内外有很多组织专注于数据治理理论和实践的研究。目前国际上,主要的数据治理框架有ISO数据治理标准、GDI数据治理框架、DAMA数据治理管理框架等。 ISO数据治理标准 改标准阐述了数据治理的标准、基本原则和数据治理模型,是一套完整的数据治理方法论。 ISO/IEC 38505标准的数据治理方法论的核心内容如下: 数据治理的目标:促进组织高效、合理地

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

ZooKeeper 中的 Curator 框架解析

Apache ZooKeeper 是一个为分布式应用提供一致性服务的软件。它提供了诸如配置管理、分布式同步、组服务等功能。在使用 ZooKeeper 时,Curator 是一个非常流行的客户端库,它简化了 ZooKeeper 的使用,提供了高级的抽象和丰富的工具。本文将详细介绍 Curator 框架,包括它的设计哲学、核心组件以及如何使用 Curator 来简化 ZooKeeper 的操作。 1

【Kubernetes】K8s 的安全框架和用户认证

K8s 的安全框架和用户认证 1.Kubernetes 的安全框架1.1 认证:Authentication1.2 鉴权:Authorization1.3 准入控制:Admission Control 2.Kubernetes 的用户认证2.1 Kubernetes 的用户认证方式2.2 配置 Kubernetes 集群使用密码认证 Kubernetes 作为一个分布式的虚拟