Spring Cloud Alibaba Sidecar 多語言微服務異構

  • 2019 年 11 月 21 日
  • 筆記

Spring Cloud Alibaba Sidecar 介紹

Spring Cloud Alibaba 2.1.1 版本後增加了 spring-cloud-alibaba-sidecar 模組作為作為一個代理的服務來間接性的讓其他語言可以使用spring cloud alibaba等相關組件。通過與網關的來進行路由的映射,從而可以做到服務的獲取,然後可以使用Ribbon間接性調用。

如上圖, Spring Cloud 應用 請求 sidercar 然後轉發給其他語言的模組,優勢是對於異構服務程式碼 零侵入,不需要直接根據 nacos 或其他註冊中心 api 註冊等

使用入門

構建其他語言介面服務

  • 基於go 寫個簡單的服務介面

http://127.0.0.1:8089/sidecar

package main    import (  	"encoding/json"  	"fmt"  	"log"  	"net/http"  )    func main() {  	http.HandleFunc("/sidecar", sidecar)  	http.HandleFunc("/heath", health)  	log.Fatal(http.ListenAndServe(":8089", nil))  }  func sidecar(w http.ResponseWriter, r *http.Request) {  	_, _ = fmt.Fprintf(w, "hello spring cloud alibaba sidecar")  }    func health(w http.ResponseWriter, r *http.Request) {  	w.Header().Set("Content-Type", "application/json")  	actuator := make(map[string]string)  	actuator["status"] = "UP"  	_ = json.NewEncoder(w).Encode(actuator)  }

構建 sidercar 應用

  • 增加 sidecar 依賴
<dependency>  	<groupid>com.alibaba.cloud</groupid>  	<artifactid>spring-cloud-starter-alibaba-sidecar</artifactid>  	<version>2.1.1.RELEASE</version>  </dependency>
  • 配置 application.yml
server:    port: 8088  spring:    cloud:      nacos:        discovery:          server-addr: localhost:8848    application:      name: go-provider    # 配置異構服務  sidecar:    ip: localhost    port: 8089    health-check-url: http://localhost:8089/health

構建 nacos consumer應用

  • application.yml
server:    port: 8087  spring:    cloud:      nacos:        discovery:          server-addr: localhost:8848    application:      name: nacos-consumer
  • consumer 邏輯
@RestController  @EnableDiscoveryClient  @SpringBootApplication  public class NacosConsumerApplication {        public static void main(String[] args) {          SpringApplication.run(NacosConsumerApplication.class, args);      }        @Bean      @LoadBalanced      public RestTemplate restTemplate() {          return new RestTemplate();      }        @Autowired      private RestTemplate restTemplate;        @GetMapping("/test")      public String test() {          return restTemplate.getForObject("http://go-provider/sidecar", String.class);      }    }

測試使用

  • 訪問spring cloud consumer 應用
curl http://localhost:8087/test   
  • 輸出 go-provider應用
hello spring cloud alibaba sidecar