Solon 已有120個生態擴展插件,此次更新主要為細節打磨:
-
增加 solon.serialization,做為序列化的基礎插件
-
優化 所有Json序列化插件,使之可方便定制類型序列化
public class DemoApp { public static void main(String[] args){ Solon.start(DemoApp.class, args, app->{ initMvcJsonCustom(); }); } /** * 初始化json定制(需要在插件運行前定制) */ private static void initMvcJsonCustom() { //通過轉換器,做簡單類型的定制 SnackRenderFactory.global .addConvertor(Date.class, s -> s.getTime()); SnackRenderFactory.global .addConvertor(LocalDate.class, s -> s.format(DateTimeFormatter.ofPattern("yyyy-MM-dd"))); SnackRenderFactory.global .addConvertor(LocalDateTime.class, s -> s.format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm"))); //復雜的,可用原生編碼接口 //SnackRenderFactory.global.addEncoder(...) } } //每個適配插件都會有自己定制渲染工廠 //solon.serialization.snack3:: SnackRenderFactory //solon.serialization.jackson:: JacksonRenderFactory //solon.serialization.gson:: GsonRenderFactory //solon.serialization.fastjson:: FastjsonRenderFactory
-
調整 CloudLockService,lock 更名為 tryLock
public class DemoService{ public void demo(long userId, ...){ if(CloudCleint.lock().tryLock("user_id" + userId)){ //獲取分布式鎖成功 //..做業務 }else{ //提示... } } }
-
引入 redisx 框架做為 solon.cache.redis 和 solon.extend.sessionstate.redis 的客戶端
-
插件 aws-s3-solon-plugin,改為基於 rest api 適配
//大小從7MB 變成了 2KB:) CloudClient.file().put("user_1", new Media("{name:'noear'}"));
-
插件 weed3-solon-plugin,weed3 升級為 3.4.1
-
插件 mybatis-solon-plugin 增加 SqlSessionFactoryBuilder 可定制的能力
public class DemoApp { public static void main(String[] args) { new SolonBuilder() .onPluginLoadEnd(e -> { //重新定義 SqlSessionFactoryBuilder(沒有需要,最好別動它...) Aop.wrapAndPut(SqlSessionFactoryBuilder.class, new SqlSessionFactoryBuilderImpl()); }) .start(DemoApp.class, args); } }
關於 Solon
Solon 是一個輕量的Java基礎開發框架。強調,克制 + 簡潔 + 開放的原則;力求,更小、更快、更自由的體驗。支持:RPC、REST API、MVC、Job、Micro service、WebSocket、Socket 等多種開發模式。短小而精悍!
關於 Solon Cloud
Solon Cloud 是一系列的接口標准和配置規范,相當於DDD模式里的防腐層概念。是 Solon 的微服務架構模式開發解決方案。
快速了解 Solon 的材料:
《Solon 特性簡集,相較於 Springboot 有什么區別?》
《Solon Cloud 分布式服務開發套件清單,感覺受與 Spring Cloud 的不同》
所謂更小:
內核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);
Hello world:
//Handler 模式:
public class App{
public static void main(String[] args){
SolonApp app = Solon.start(App.class,args);
app.get("/",(c)->c.output("Hello world!"));
}
}
//Controller 模式:(mvc or rest-api)
@Controller
public class App{
public static void main(String[] args){
Solon.start(App.class,args);
}
//限定 put & post 方法類型
@Put
@Post
@Mapping("/")
public String hello(String name){
return "Hello " + name;
}
}
//Remoting 模式:(rpc)
@Mapping("/")
@Remoting
public class App implements HelloService{
public static void main(String[] args){
Solon.start(App.class,args);
}
@Override
public String hello(){
return "Hello world!";
}
}
附:項目地址
附:入門示例
- Solon 入門教程示例:https://gitee.com/noear/solon_demo
- Solon Api 入門教程示例:https://gitee.com/noear/solon_api_demo
- Solon Rpc 入門教程示例:https://gitee.com/noear/solon_rpc_demo
- Solon Auth 入門教程示例:https://gitee.com/noear/solon_auth_demo
- Solon Cloud 入門教程示例:https://gitee.com/noear/solon_cloud_demo
- Solon 進階教程示例:https://gitee.com/noear/solon_advance_demo