Spring Cloud 学习笔记十四:搭建微服务工程之使用 Zuul 聚合多个微服务的 Swagger 文档

本文档介绍如何使用Zuul作为网关来聚合多个微服务的Swagger文档,以便于统一管理和访问。首先,在网关服务中引入Springfox的依赖,然后自定义配置,利用Eureka发现服务,动态添加每个服务的Swagger资源。这样,就可以避免逐个访问单独服务的文档,提高了开发者效率。
摘要由CSDN通过智能技术生成

目录

使用 Zuul 聚合多个微服务的 Swagger 文档


使用 Zuul 聚合多个微服务的 Swagger 文档

不想每次都去访问独立服务的文档可以通过网关统一整合这些服务的文档,这里使用 Zuul 中进行聚合操作。

在网关服务中加入 Swagger 的依赖,代码如下所示:

<!-- swagger -->
<dependency>
    <groupId>io.springfox</groupId>
    <artifactId>springfox-boot-starter</artifactId>
    <version>3.0.0</version>
</dependency>

自定义配置进行整合,直接去读取 Eureka 中的服务信息,代码如下所示:

@EnableOpenApi
@Component
@Primary
public class DocumentationConfig implements SwaggerResourcesProvider {

    @Autowired
    private DiscoveryClient discoveryClient;

    @Value("${spring.application.name}")
    private String applicationName;
    
    @Override
    public List<SwaggerResource> get() {
        List<SwaggerResource> resources = new ArrayList<>();
        // 排除自身, 将其他的服务添加进去
        discoveryClient.getServices().stream().filter(s -> !s.equals(applicationName)).forEach(name -> {
            resources.add(swaggerResource(name, "/" + name + "/v3/api-docs", "3.0"));
        });
        return resources;
    }
    private SwaggerResource swaggerResource(String name, String location, String version) {
        SwaggerResource swaggerResource = new SwaggerResource();
        swaggerResource.setName(name);
        swaggerResource.setLocation(location);
        swaggerResource.setSwaggerVersion(version);
        return swaggerResource;
    }
}

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

stary1993

你的鼓励是我创作的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值