Solon 是一个轻量的Java基础开发框架。强调,克制 + 简洁 + 开放的原则;力求,更小、更快、更自由的体验。支持:RPC、REST API、MVC、Job、Micro service、WebSocket、Socket 等多种开发模式。短小而精悍!

Solon Cloud 是一系列的接口标准和配置规范,算是 Solon 的分布式开发套件方案。

快速了解Solon的材料:

《Solon 特性简集,相较于 Springboot 有什么区别?》

《Solon Cloud 分布式服务开发套件清单,感觉受与 Spring Cloud 的不同》

《Solon 的想法与架构笔记》

《Solon 生态插件清单》,目前已有100多个生态插件

《Solon 框架入门》

所谓更小:

内核0.1m,最小的接口开发单位0.2m(相较于 Dubbo、Springboot 的依赖包,小到可以乎略不计)

所谓更快:

本机http helloworld测试,Qps可达12万之多。可参考:《helloworld_wrk_test

所谓更自由:(代码操控自由)

  1. // 除了注解模式之外,还可以按需手动
  2. //
  3. //手动获取配置(Props 为 Properties 增强版)
  4. Props db = Solon.cfg().getProp("db");
  5. //手动获取容器里的Bean
  6. UserService userService = Aop.get(UserService.class);
  7. //手动监听http post请求
  8. Solon.global().post("/user/update", x-> userService.updateById(x.paramMap()));
  9. //手动添加个RPC服务
  10. Solon.global().add("/rpc/", HelloService.class, true);
  11. //手动获取一个RPC服务消费端
  12. HelloService helloService = Nami.builder().create(HelloService.class);
  13. //手动为容器添加组件
  14. Aop.wrapAndPut(DemoService.class);

本次版本主要变化:

1、增加新的插件适配

  • 添加 opentracing-solon-plugin 插件。可快速对接所有支持 opentracing 的链路跟踪产品。下面以 Jaeger 对接为例:
  1. @Configuration
  2. public class Config {
  3. @Bean
  4. public Tracer tracer() throws TTransportException {
  5. Reporter reporter = new RemoteReporter.Builder()
  6. .withSender(new UdpSender(AGENT_HOST, AGENT_PORT, 0))
  7. .withFlushInterval(10)
  8. .build();
  9. return new JaegerTracer.Builder(Solon.cfg().appName())
  10. .withReporter(reporter)
  11. .withExpandExceptionLogs()
  12. .withSampler(new ConstSampler(true)).build();
  13. }
  14. }

2、优化 Nami 内部结构(不影响外部调用)

  • 优化 Nami Filter;改为链式过滤;并添加 Invocation 做为配套
  • 拆分 Nami.Builder 为独立的 NamiBuilder 类
  • 取消 Decoder, Encoder, Channel 对 Filter 的继承;改为更明确的 pretreatment 预处理接口
  • 移动 Result 到 nami 一级包目录
  • 简化 Naimi 的附件模式。改由 NamiAttachment 直接操控

总体来说,是简化和增强了 Nami 的过滤及附件能力。例:

  1. //过滤能力
  2. @Component
  3. public class NamiFilterAdapter implements Filter { //这是Nami的过滤器接口
  4. @Override
  5. public Result doFilter(Invocation inv) throws Throwable {
  6. inv.headers.put("token","1");
  7. System.out.println("我给 Nami 加了个头信息!");
  8. return inv.invoke();
  9. }
  10. }
  11. //附件能力
  12. @Controller
  13. public class Demo {
  14. @NamiClient
  15. HelloService helloService;
  16. @Mapping("/")
  17. public void test() {
  18. //添加附件:token=aaa (最终会做为 header 传给 server)
  19. NamiAttachment.put("Token","5643c10c-87c3-4b7e-bd26-30cf2456aad8");
  20. //helloService 的 remoting server ,需要有 token 认证
  21. helloService.hello("noear");
  22. }
  23. }

3、增强部分接口及相关配置能力

  • 增加 Solon Filter 序号位支持
  • 增加 Solon Props::getByParse 接口,可应对组合配置需要。例:Hello ${user.name} 这样的配置需求
  • 增加 CloudJobHandler 接口,让 Job Handler 更清晰些
  • 增加 Solon Auth 新注解:@AuthIp, @AuthPath 支持
  • 增加 CloudConfig 的注解内容,支持 ${xx}yyy 风格配置
  • 增加 CloudEvent 的注解内容,支持 ${xx}yyy 风格配置
  • 增加 CloudJob 的注解内容,支持 ${xx}yyy 风格配置
  • 增加 CloudBreaker 的注解内容,支持 ${xx}yyy 风格配置
  • 增加 @Component 单例组件通过 EventBus 扩展的机制
  • 增加 env 启动参数切换配置文件;例:java -jar xxx.jar -env=test
  • 标注 Utils::throwableWrap 函数为弃用,并调整内部异常包装处理
  • 限制 DataThrowable 被最终渲染
  • 取消 WarnThrowable

4、日志对接进一步增加

Solon 的日志体系,除自有 slf4j 实现之后;还适配有 Logback 的添加器;现增加 Log4j 添加器的适配。

附:项目地址

附:入门示例

对标 Spring Boot & Cloud ,轻量框架 Solon 1.4.12 发布的更多相关文章

  1. 对标 Spring Boot & Cloud ,轻量框架 Solon 1.4.8 发布

    Solon 是一个轻量的Java基础开发框架.强调,克制 + 简洁 + 开放的原则:力求,更小.更快.更自由的体验.支持:RPC.REST API.MVC.Job.Micro service.WebS ...

  2. 对标 Spring Boot & Cloud ,轻量框架 Solon 1.4.14 发布

    Solon 是一个轻量的Java基础开发框架.强调,克制 + 简洁 + 开放的原则:力求,更小.更快.更自由的体验.支持:RPC.REST API.MVC.Job.Micro service.WebS ...

  3. 对标 Spring Boot & Cloud ,轻量框架 Solon 1.5.8 发布

    Solon 是一个轻量的Java基础开发框架.强调,克制 + 简洁 + 开放的原则:力求,更小.更快.更自由的体验.支持:RPC.REST API.MVC.Job.Micro service.WebS ...

  4. Spring Boot & Cloud 轻量替代框架 Solon 1.3.37 发布

    Solon 是一个微型的Java开发框架.强调,克制 + 简洁 + 开放的原则:力求,更小.更快.更自由的体验.支持:RPC.REST API.MVC.Micro service.WebSocket. ...

  5. Spring Boot & Cloud 轻量替代框架 Solon 1.4.1 发布

    Solon 是一个微型的Java开发框架.强调,克制 + 简洁 + 开放的原则:力求,更小.更快.更自由的体验.支持:RPC.REST API.MVC.Micro service.WebSocket. ...

  6. Spring Boot & Cloud 轻量替代框架 Solon 1.3.33 发布

    Solon 是一个微型的Java开发框架.强调,克制 + 简洁 + 开放的原则:力求,更小.更快.更自由的体验.支持:RPC.REST API.MVC.Micro service.WebSocket. ...

  7. Spring Boot & Cloud 轻量替代框架 Solon 1.3.35 发布

    Solon 是一个微型的Java开发框架.强调,克制 + 简洁 + 开放的原则:力求,更小.更快.更自由的体验.支持:RPC.REST API.MVC.Micro service.WebSocket. ...

  8. 对标 Spring Boot & Cloud ,轻量框架 Solon 1.5.2 重要发布

    Solon 是一个轻量的Java基础开发框架.强调,克制 + 简洁 + 开放的原则:力求,更小.更快.更自由的体验.支持:RPC.REST API.MVC.Job.Micro service.WebS ...

  9. spring boot / cloud (三) 集成springfox-swagger2构建在线API文档

    spring boot / cloud (三) 集成springfox-swagger2构建在线API文档 前言 不能同步更新API文档会有什么问题? 理想情况下,为所开发的服务编写接口文档,能提高与 ...

随机推荐

  1. python 爬取王者荣耀英雄皮肤代码

    import os, time, requests, json, re, sys from retrying import retry from urllib import parse "& ...

  2. Spring Security极简入门三部曲(中篇)

    目录 Spring Security极简入门三部曲(中篇) 验证流程 Authentication接口 过滤器链 AuthenticationProvider接口: demo时刻 代码讲解 小结 Sp ...

  3. POJ2391 Floyd+离散化+二分+DINIC

    题意:       有n个猪圈,每个猪圈里面都有一定数量的猪(可能大于当前猪圈的数量),每个猪圈都有自己的容量,猪圈与猪圈之间给出了距离,然后突然下雨了,问多久之后所有的猪都能进圈. 思路:     ...

  4. 寻找OEP

    1.使用ESP定律 OD载入后,F8一次,在寄存器窗口的ESP的内容上(如0012FFA4)右键:"在数据窗口中跟随",到内存数据窗口,将内存数据窗口以HEX数据形式显示,在刚才的 ...

  5. ListView 加载数据时 触摸报错

    问题起因: 在做一个从sd卡中加载数据显示在ListView中,由于数据可能比较多,考虑到用户体验,就使用AsyncTask来异步加载,数据一条一条的添加至ListView中. 开始数据比较少的时候, ...

  6. XCTF-FlatScience

    FlatScience 题目描述 啥描述也没有 解题过程 页面有好多链接,除了论文pdf之外,还有子目录下的index.html, 比如:/1/index.html,/1/3/index.html 扫 ...

  7. 开源囧事4:你们这些卖代码的能不能留自己的QQ号?留我QQ号干嘛?

    缘起于开源项目 从 2017 年开始,陆陆续续写了一些开源项目放到开源网站里,都是一些实战项目,给大家练练手.有基础整合的demo,有 Spring Boot 博客项目,有 Spring Boot 商 ...

  8. 【dependencyManagement版本管理】dependencies.dependency.version is missing

    maven 的gav的v(版本问题) 报错dependencies.dependency.version is missing 出现的场景 一个项目中有多个模块 父模块中出现dependencies. ...

  9. ERROR: Failed to Setup IP tables: Unable to enable SKIP DNAT rule

    解释:执行docker-compose up -d时出现ERROR: Failed to Setup IP tables: Unable to enable SKIP DNAT rule 原因:防火墙 ...

  10. 面试侃集合 | ArrayBlockingQueue篇

    面试官:平常在工作中你都用过什么什么集合? Hydra:用过 ArrayList.HashMap,呃-没有了 面试官:好的,回家等通知吧- 不知道大家在面试中是否也有过这样的经历,工作中仅仅用过的那么 ...