Spring Boot & Cloud 輕量替代框架 Solon 1.4.1 發布


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 替代

附:項目地址

附:入門示例


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM