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

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

快速了解Solon的材料:

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

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

《Solon 的想法与架构笔记》

所谓更小:

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

所谓更快:

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

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

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

本次版本主要变化:

1、插件 solon.extend.sessionstate.jwt,增加 prefix、allowAutoIssue、allowUseHeader 配置项

solon.extend.sessionstate.jwt 可以更简单的使用 JWT,像使用 sessionstate 一般。配置示例:

server.session:
timeout: 7200 #单位秒;(可不配,默认:7200)
state:
jwt:
name: TOKEN #变量名;(可不配,默认:TOKEN)
secret: "E3F9N2kRDQf55pnJPnFoo5+ylKmZQ7AXmWeOVPKbEd8=" #密钥(使用 JwtUtils.createKey() 生成);(可不配,默认:xxx)
prefix: Bearer #令牌前缀(可不配,默认:空)
allowExpire: true #充许超时;(可不配,默认:true);false,则token一直有效
allowAutoIssue: false #充许自动输出;(可不配,默认:true);flase,则不向header 或 cookie 设置值(由用户手动控制)
allowUseHeader: false #充许使用Header传递;(可不配,默认:使用 Cookie 传递);true,则使用 header 传递

可以通过,JwtUtils.createKey() 生成密钥,例:

public class JwtTest {
@Test
public void test(){
System.out.println(JwtUtils.createKey());
}
}

应用示例:

@Mapping("api")
@Controller
public class API_test_login extends ApiBase {
@Mapping("test.login")
public String exec(Context ctx) {
//设置session
ctx.sessionSet("user_id", "12");
ctx.sessionSet("name", "noear"); //将session值,手动生成token并做为接口的结果输出
return ctx.sessionState().sessionToken();
}
}

2、插件 beetlsql-solon-plugin,升级 beetlsql 为 3.4.3(SQLManagerBuilder 增强了构建能力)

这个更新,主要是增加 beetlsql 的 SQLManagerBuilder 能力。

EventBus.subscribe(SQLManagerBuilder.class, e->{
e.setDbStyle(new OracleStyle());
//e.addIdAutoGen();
});

3、插件 httputils-solon-plugin,添加 PreheatUtils 接口预热小工具

PreheatUtils 是一个方便请求自己接口的小工具,便于在程序内部编写预热代码。

public class DemoApp {
public static void main(String[] args) {
Solon.start(DemoApp.class, args); //请求自己的接口进行预热
PreheatUtils.preheat("/cfg/get/?tag=water");
PreheatUtils.preheat("/cfg/set/", h -> h.data("value", "test").post());
}
}

4、添加 SolonProps::loadEnv 加载环境变量接口

使用Docker 或 K8s 部署时,容器可以添加环境配置。为了方便,提供了loadEnv接口,从而使用环境变量如果属性变量。

public class DemoApp {
public static void main(String[] args) {
Solon.start(DemoApp.class, args, app->{
//加载环境变量(如果有则加载并替换profile的值)
app.cfg().loadEnv("water."); //通过属性能力,获取链接池实例
HikariDataSource ds =app.cfg().getBean("water.ds.",HikariDataSource.class);
}); //
// 此代码的效果:1.本地可配置profile; 2.容器部署时可通过环境变量修改
//
}
}

5、添加 SolonApp::signalGet 获取信号接口

这个功能用处好像不大。。。但可以做些日志。

public class DemoApp {
public static void main(String[] args) {
SolonApp app = Solon.start(DemoApp.class, args); //获取18080的端口信号信息,并打印
Signal signal = app.signalGet(18080);
System.out.println(signal);
}
}

6、solon.cloud CloudJob 增加 cron7x 可选属性

@CloudJob(name = "DemoJob", cron7x = "0 * * * * ?")
public class DemoJob implements CloudJobHandler {
static final Logger log = LoggerFactory.getLogger(DemoJob.class); @Override
public void handle(Context ctx) throws Throwable {
log.info("JobHandlerDemo1");
}
} //或者 @CloudJob(name = "DemoJob", cron7x = "1m")
public class DemoJob implements CloudJobHandler {
static final Logger log = LoggerFactory.getLogger(DemoJob.class); @Override
public void handle(Context ctx) throws Throwable {
log.info("JobHandlerDemo1");
}
}
7、solon.validation 增加更多注释
8、插件 mybatis-solon-plugin 升级 mybatis 为 3.5.7
9、插件 solon.serialization.protostuff 升级 protostuff 为 1.7.4
10、插件 solon.socketd.client.smartsocket 升级 smartsocket 1.5.10
11、插件 solon.serialization.hession 升级 hessian 4.0.65
12、插件 solon.auth AuthUtil 验证权限与角色前增加登录验证
13、增加 qiniu-kodo-solon-plugin 对象存储适配插件

附:项目地址

附:入门示例

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

  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.12 发布

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

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

    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多进程、多线程服务器和客户端的简单实现

    使用了多进程的服务器: from SocketServer import TCPServer, ForkingMixIn, ThreadingMixIn, StreamRequestHandler c ...

  2. 服务器开发基础-Tcp/Ip网络模型—完成端口(Completion Port)模型

    本文对于初学网络编程的极为友好,文中所有代码全部基于C语言实现,文中见解仅限于作者对于完成端口的初步认识,由于作者才疏学浅,出现的错误和纰漏,麻烦您一定要指出来,咱们共同进步.谢谢!!! 完成端口(c ...

  3. 2Spring对象创建小结

    Spring的对象创建 Spring学习笔记 周芋杉2021/5/15 原理:工厂设计模式,通过反射创建对象. Spring工厂分类 非web环境:ClassPathXmlApplicationCon ...

  4. Linux VMware Tools详解

    VMware Tools描述 VMware Tools 中包含一系列服务和模块,可在 VMware 产品中实现多种功能,从而使用户能够更好地管理客户机操作系统,以及与客户机系统进行无缝交互. 在Lin ...

  5. Linux PATH环境变量及作用(初学者必读)

    Linux PATH环境变量及作用(初学者必读) < 什么是环境变量,Linux环境变量有哪些?Linux打包(归档)和压缩 > <Linux就该这么学>是一本基于最新Linu ...

  6. Docker Swarm(五)Config 配置管理

    前言 在动态的.大规模的分布式集群上,管理和分发配置文件也是很重要的工作.传统的配置文件分发方式(如配置文件放入镜像中,设置环境变量,volume 动态挂载等)都降低了镜像的通用性. Docker 1 ...

  7. Linux C 文件IO

    文件IO 2021-05-31 12:46:14 星期一 目录 文件IO 基础IO open 错误 creat read 一个例子 write close lseek 文件空洞 unlink删除 io ...

  8. [leetcode] 68. 文本左右对齐(国区第240位AC的~)

    68. 文本左右对齐 国区第240位AC的~我还以为坑很多呢,一次过,嘿嘿,开心 其实很简单,注意题意:使用"贪心算法"来放置给定的单词:也就是说,尽可能多地往每行中放置单词. 也 ...

  9. nginx 的访问日志切割

    1. 高级用法–使用 nginx 本身来实现 当 nginx 在容器里,把 nginx 日志挂载出来的时候,我们发现就不适合再使用 kill -USR1 的方式去分割日志这时候当然就需要从 nginx ...

  10. Go语言网络通信---string与int互转,int64与[]byte互转,int直接互转,string与[]byte互转

    string与int互转 #string到int int,err:=strconv.Atoi(string) #string到int64 int64, err := strconv.ParseInt( ...