SpringCloud 中如何使微服务只能被指定的程序调用

2021-05-08 22:28

阅读:553

标签:生效   限制   应用   调用   https   bsp   conf   strong   生成   

我们在做微服务时,有时候需要将微服务做一些限制,比如只能我们自己的服务调用,不能通过浏览器直接调用等。

 

具体的逻辑如下:

 

我们就可以使用spring cloud sleuth,在应用调用微服务时通过Tracer产生一个traceId,并通过request设置到header里面,

然后sleuth会将该traceId在整个链路传递,我们在微服务中定义一个拦截器,取到header里面的traceId并和链路中的traceId比较,

如果相等,则表明是我们自己的应用调用,拦截器通过,否则这次请求被拦截

 

代码详见github 

https://github.com/devinzhang0209/interview_springcloud.git

 

一. 应用调用微服务,产生traceId

 

1. feign调用微服务,指定配置

 技术图片

 

 

2. FeignReqeustConfig中实例化拦截器用于生成traceId

 技术图片

 

 

3. 拦截器生成traceId并放到header里面

 

 技术图片

 

 

 二 . 拦截器拦截到traceId并和链路中比较

  1. 拦截器判断traceId

  技术图片

 

  

 2. 拦截器生效,只拦截微服务的请求(定义时定义微服务都是cloud开头)

   技术图片

 

 

 

SpringCloud 中如何使微服务只能被指定的程序调用

标签:生效   限制   应用   调用   https   bsp   conf   strong   生成   

原文地址:https://www.cnblogs.com/DevinZhang1990/p/13169960.html


评论


亲,登录后才可以留言!