天天看點

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、釋出新的家簇成員圖譜

Spring Boot & Cloud 輕量替代架構 Solon 1.4.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

替代

附:項目位址

  • 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