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🇼🇸//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🇼🇸//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🇼🇸//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 的接口去调用了:)

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
.NET 8 动态 PGO 简析
原文:.NET8动态PGO简析 作者:江湖评谈,公众号同名:江湖评谈(Jianghupt),欢迎关注。 前言 .NET8在性能方面的惊人飞跃,远超过去所取得成就,这在很大程度上归功于动态PGO。【 I dare say the improvements in .NET 8 in the JIT are an incredible leap beyond what was achieved in the past, in large part due to dynamic PGO…官方原话】 详细 在早期的.NET方法只编译一次,在第一次调用该方法的时候,JIT启动以生成该方法的代码。后续的调用以及当前的调用都会使用JIT生成的代码来运行程序,这是一个简单的无冲突的时代,但是也是一个原始的时代。 简单和原始在于,方法只编译一次,再无其它可能性。无冲突在于,尤其是.NET开源时代,分层,动态PGO,OSR等等都会破坏原有的代码逻辑,造成一定的复杂度,而早期的.NET不存在这种状况。 优化是编译器里面最耗时的操作,编译器可以花费超长的时间来优化一段代码或者一个指令集。但是程序使用者,或者软...
- 下一篇
百川智能发布超千亿大模型 Baichuan 3,中文评测超越 GPT-4
1月29日,百川智能发布超千亿参数的大语言模型 Baichuan 3。 链接:https://www.baichuan-ai.com/ 据称在多个权威通用能力评测如CMMLU、GAOKAO和AGI-Eval中,Baichuan 3都展现了出色的能力,尤其在中文任务上更是超越了GPT-4。而在数学和代码专项评测如MATH、HumanEval和MBPP中同样表现出色。 不仅如此,其在对逻辑推理能力及专业性要求极高的MCMLE、MedExam、CMExam等权威医疗评测上的中文效果同样超过了GPT-4,是中文医疗任务表现最佳的大模型。Baichuan 3还突破“迭代式强化学习”技术,进一步提升了语义理解和生成能力,在诗词创作的格式、韵律、表意等方面表现优异,领先于其他大模型。 在测试逻辑推理能力的 MCMLE、MedExam、CMExam 等医疗评测上,Baichuan 3 的中文效果同样号称超过了 GPT-4,是“中文医疗任务表现最佳的大模型”。 据介绍,百川智能在 Baichuan 3 训练过程中提出了“动态数据选择”、“重要度保持”以及“异步 CheckPoint 存储”等多种技术手段...
相关文章
文章评论
共有0条评论来说两句吧...