Solon 是一個微型的Java開發架構。強調,克制 + 簡潔 + 開放的原則;力求,更小、更快、更***的體驗。支援:RPC、REST API、MVC、Micro service、WebSocket、Socket 等多種開發模式。
Solon Cloud 是一系列的接口标準和配置規範,算是 Solon 的分布式開發套件方案。
快速了解Solon的材料:
《Solon 特性簡集,相較于 Springboot 有什麼差別?》
《Solon Cloud 分布式服務開發套件清單,感覺受與 Spring Cloud 的不同》
《Solon 的想法與架構筆記》
《Solon 生态插件清單》
《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、釋出新的家簇成員圖譜
2、強化 Solon Remoting 概念 [ 增加 @Remoting 注解,替代舊的 @Component(remoting=true) ]
//服務端代碼1 - 使用tpc通信
@Socket
@Mapping("/demo/socket")
@Remoting
public class DemoRemoting1 implements HelloService{
public String hello(String name){
return "Hello " + name;
}
}
//服務端代碼2 - 使用http通信
@Http
@Mapping("/demo/http")
@Remoting
public class DemoRemoting2 implements HelloService{
public String hello(String name){
return "Hello " + name;
}
}
//用戶端代碼1
@NamiClient(name="demo", path="/demo/socket")
HelloService helloService;
String tmp = helloService.hello("noear");
3、增加 @ClientEndpoint autoReconnect 屬性
//autoReconnect 預設為 true
@ClientEndpoint(uri = "tcp://localhost:28080", heartbeatRate = 5, autoReconnect = false)
public class ClientListener implements Listener {
@Override
public void onMessage(Session session, Message message) throws IOException {
System.out.println(message.bodyAsString());
}
}
相關資料可百度:solon socketd
4、增強 solon-springboot-starter,可将 solon 注入器應用到 springboot bean
當 spring boot 項目遷移到 solon 時,過渡期可以使用這個元件進行混合開發,示例:
//Spring bean
@RestController
public class DemoController{
//Solon inject
@CloudConfig("user.name")
String userName;
//Solon inject
@NamiClient
HelloService helloService;
}
5、取消 nami-springboot-starter 元件
因 solon-springboot-starter 的增強,這個元件沒必要了。
6、取消 @EnabelNamiClients
、 @EnableSolonCloud
、 @EnableSolon
注解
@EnabelNamiClients
@EnableSolonCloud
@EnableSolon
因 solon-springboot-starter 的增強,這三個注解也沒怵要了;所有 Solon 相關的能力,直接可用。
7、取消 @Component remoting 屬性
由新
@Remoting
替代
附:項目位址
- Gitee:https://gitee.com/noear/solon
- Github:https://github.com/noear/solon
附:入門示例
- Solon 入門教程示例:https://gitee.com/noear/solon_demo
- Solon Rpc 入門教程示例:https://gitee.com/noear/solon_rpc_demo
- Solon Cloud 入門教程示例:https://gitee.com/noear/solon_cloud_demo
- Solon 進階教程示例:https://gitee.com/noear/solon_advance_demo