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

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

Solon 是一個微型的Java開發框架。強調,剋制 + 簡潔 + 開放的原則;力求,更小、更快、更自由的體驗。支援:RPC、REST API、MVC、Micro service、WebSocket、Socket 等多種開發模式。

Solon Cloud 是一系列的介面標準和配置規範。是 Solon 的微服務模式開發套件方案。

替代?還能說些什麼異同之處嗎?

《Solon 特性簡集,相較於 Springboot 有什麼區別?》

《Solon Cloud 分散式服務開發套件清單與快速概覽》

《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、Solon logging 增加記錄器級別控制

solon.logging.logger:
  "org.aaa.*":
    level: INFO
  "org.xxx.xxx.yyy":
    level: INFO

2、Solon cloud 增加 zookeeper-solon-plugin 元件,提供配置與註冊服務

配置好後,使用標準的 Solon cloud 註解與介面即可使用。配置示例:

solon.cloud.zookeeper:
  server: "localhost:2181"
  config:
    load: "test.properties"

#zk日誌太猛了,限制一下
solon.logging.logger:
  "org.apache.zookeeper.*":
    level: "WARN"

程式碼使用:

@Configuration
public class Config {
    @Bean
    public DataSource ds(@CloudConfig("${demo.db1}") HikariDataSource ds){
        System.out.println(ds.getUsername() + ":" + ds.getJdbcUrl());
        return ds;
    }
}

//手動獲取配置:Config cfg = CloudClient.config().pull(Solon.cfg().appGroup(), "demo.db1");

3、Solon cloud 增加 snowflake-id-solon-plugin 元件,提供雪花演算法ID生成服務

此元件使用應用資訊做為 dataId,使用ip:port做為workId。引入包後,可直接通過介面使用

long logId = CloudClient.id().generate();

附:專案地址

附:入門示例

相關文章