Spring Cloud Alibaba Sidecar 多语言微服务异构
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
> 项目推荐: Spring Cloud 、Spring Security OAuth2的RBAC权限管理系统 欢迎关注
原文地址:https://my.oschina.net/giegie/blog/3130830
相关推荐
-
spring-core组件详解——PropertyResolver属性解决器 Java框架
2020-7-4
-
SpringBoot教程——检视阅读 Java框架
2020-6-11
-
spring boot + jpa + thymeleaf 增删改查示例 Java框架
2020-6-8
-
Spring Cloud 服务端注册与客户端调用 Java框架
2019-7-26
-
SpringBoot开发案例之微信小程序文件上传 Java框架
2019-3-13
-
SpringCloud入门(十一):Sleuth 与 Zipkin分布式链路跟踪 Java框架
2020-6-11
-
【Spring Boot】关于上传文件例子的剖析 Java框架
2019-3-22
-
实用技巧:Hystrix传播ThreadLocal对象(两种方案) Java框架
2020-6-1
-
白话SpringCloud | 第五章:服务容错保护(Hystrix) Java框架
2020-6-1
-
SpringMvc接口中转设计(策略+模板方法) Java框架
2019-5-13