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