Spring Boot & Cloud 輕量替代框架 Solon 1.4.1 釋出

劉之西東發表於2021-05-19

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 註解

因 solon-springboot-starter 的增強,這三個註解也沒怵要了;所有 Solon 相關的能力,直接可用。

7、取消 @Component remoting 屬性

由新 @Remoting 替代

附:專案地址

附:入門示例

相關文章