Solon 已有120個生態擴充套件外掛,此次更新主要為細節打磨:
- 新增 solon.extend.graalvm 外掛,用於適配 graalvm native image 模式
從此,solon 進入 graalvm native image 的世界。
感謝開發者:@饅頭蟲/瓢蟲,近1個月時間的實驗和適配。
- 新增 detector-solon-plugin 外掛,用於為健康檢測,增加一批預設的探測器(可選:cpu,disk,jvm,memory,os,qps)
#提供了一批健康探測器(多個以,隔開)
#solon.health.detector: "cpu,os,qps"
solon.health.detector: "cpu"
輸出示例:
#curl http://localhost:8080/healthz
{
"status": "UP",
"details": {
"cpu": {
"status": "UP",
"details": {
"ratio": 53.8
}
}
}
}
- 新增 solon.extend.hotdev 外掛
為開發過程,修改java代自動重新載入,進行嘗試。
- 外掛 solon.data 的快取註解 tags 值,支援返回資料做為模板引數
public class UserService{
/**
* 獲取使用者資訊
*/
@Cache(tags = "user_${userId},company_bind_${.company_id}") //使用返回結果的欄位:company_id
public UserDo getUser(Long userId) throws SQLException {
return userMapper.getUser(userId);
}
/**
* 根據companyId批量解綁,同時清除與個企業相關的使用者快取
* @return
* @throws SQLException
*/
@CacheRemove(tags = "company_bind_${companyId}")
public int batchUnbindCompany(Long companyId) throws SQLException {
return userMapper.batchUnbindByCompanyId(companyId);
}
}
- 外掛 solon.i18n 國際化配置支援 key 級別的 預設配置(之前基於檔案)
例:一個 key 在 message_cn_ZH 找不到配置,會到 message_cn 找,再沒有 到 message 打
- 外掛 solon.i18n 增加過濾器,自動為上下文解析地區
- 外掛 water-solon-plugin 升級 water 2.3.2
- 核心 @Bean 增加 index;@Component 增加 index。為特定型別增加位置支援
//例:為應用過濾器增加位置
//
@Component(index = 1)
public class AppFilterImpl implements Filter {
@Override
public void doFilter(Context ctx, FilterChain chain) throws Throwable {
chain.doFilter(ctx);
}
}
- 核心 增加 solon.locale 配置,為系統提供預設地區配置
關於 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);
附:專案地址
附:入門示例
- 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 Socketd 入門教程示例:https://gitee.com/noear/solon_socketd_demo
- Solon 進階教程示例:https://gitee.com/noear/solon_advance_demo