03_学习springdoc与微服务结合_简述

2023-10-10 13:04

本文主要是介绍03_学习springdoc与微服务结合_简述,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 1 前言
  • 2 基本结构
  • 3 网关的配置
    • 3.1 ✍️ pom.xml 引入依赖
    • 3.2 🌿 application.yml 的配置
      • 3.2.1 Gateway 的配置
      • 3.2.2 Eureka Client 的配置
      • 3.2.3 Springdoc 的配置
    • 3.3 Springdoc 配置类
  • 4 影片服务 backend-film 的配置
    • 4.1 ✍️ pom.xml 引入依赖
    • 4.2 🌿 application.yml 的配置
      • 4.2.1 Eureka Client 的配置
      • 4.2.2 Springdoc 的配置
    • 4.3 Springdoc 配置类
  • 5 结语

1 前言

  最近尝试了下 在微服务中使用 springdoc,感觉还蛮有意思的😁,现在把关键步骤记录下来。

  做为一个平时学习的小项目,我使用的是比较新的 Spring Boot 3.x 和 Java 17。

  springdoc 的官网是 https://springdoc.org/ 。本文主要简述了一些配置,至于 swagger 的注解如何使用,请参考我的另一篇文章 《01_学习springdoc的基本使用》

2 基本结构

  微服务这边,用到了 Spring Cloud Gateway 、Eureka Server、Eureka Client,如下图:

在这里插入图片描述

  上图的 backend-film 和 backend-cinema 分别是 影片服务 和 影院服务。结构很简洁,另外,图中我也简述了每个模块,在结合 springdoc 的时候,需要引入的依赖和相应的配置。

3 网关的配置

3.1 ✍️ pom.xml 引入依赖

<dependency><groupId>org.springdoc</groupId><artifactId>springdoc-openapi-starter-webflux-ui</artifactId><!-- version 交给父 pom.xml 管理了,目前最新的版本是 2.2.0 -->
</dependency>

  如上,引入 webflux-ui 的依赖。至于为什么是 webflux-ui 而不是 webmvc-ui 呢❔🤪 原因是 spring-cloud-starter-gateway 它自带 spring-boot-starter-webflux 的依赖,也就是说,Gateway 本身用的是 webflux,那 springdoc 咱也就用 webflux-ui 呗🤣。

3.2 🌿 application.yml 的配置

3.2.1 Gateway 的配置

spring:application:name: api-gatewaycloud:gateway:discovery:locator:enabled: trueroutes:# 影院: 所有 /cateye/backend-cinema/** 的请求 都去影院服务- id: backend-cinema-serviceuri: lb://backend-cinemapredicates:- Path=/cateye/backend-cinema/**filters:- name: CircuitBreakerargs:name: movieHallCircuitBreakerfallbackUri: forward:/fallback/cinema# 跳过 2 个前缀, 也就是 /cateye/backend-cinema/- StripPrefix=2# 影片: 所有 /cateye/backend-film/** 的请求 都去影片服务- id: backend-film-serviceuri: lb://backend-filmpredicates:- Path=/cateye/backend-film/**filters:- name: CircuitBreakerargs:name: filmCircuitBreakerfallbackUri: forward:/fallback/film# 跳过 2 个前缀, 也就是 /cateye/backend-film/- StripPrefix=2

3.2.2 Eureka Client 的配置

eureka:client:serviceUrl:# eureka server 集群defaultZone: http://peer1:8100/eureka/,http://peer2:8101/eureka/,http://peer3:8102/eureka/instance:prefer-ip-address: true

3.2.3 Springdoc 的配置

server:# 网关的端口是 8080port: 8080# server.forward-headers-strategy=framework 和 后面的 springdoc.cache.disabled=true# 有很大的用处, 它们会影响到 swagger ui 页面的 generated server urlforward-headers-strategy: frameworkspringdoc:swagger-ui:urls:# 指定影院服务 OpenAPI 3.0 json 结构的 api 描述 所在的 url 路径# 这个 name 就是类 org.springdoc.core.models.GroupedOpenApi 的 group 名称# 此 name 和后面的 springdoc 配置类有很大的关系- name: backend-cinemaurl: /cateye/backend-cinema/v3/api-docs# 指定影片服务 OpenAPI 3.0 json 结构的 api 描述 所在的 url 路径- name: backend-film# swagger 的 api-doc.json 默认是在 /v3/api-docs 接口下# 由于前面 gateway 的 route 配置,去掉了 2 个前缀, 所以下面的 url 是对的url: /cateye/backend-film/v3/api-docscache:disabled: true

  百闻不如一见,server.forward-headers-strategy=frameworkspringdoc.cache.disabled=true 的效果如下图:

在这里插入图片描述

3.3 Springdoc 配置类

import org.springdoc.core.models.GroupedOpenApi;
import org.springframework.cloud.gateway.route.RouteDefinition;
import org.springframework.cloud.gateway.route.RouteDefinitionLocator;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Lazy;import java.util.ArrayList;
import java.util.List;@Configuration
public class MySpringdocConfig {@Bean@Lazy(false)public List<GroupedOpenApi> apis(RouteDefinitionLocator locator) {List<GroupedOpenApi> groups = new ArrayList<>();List<RouteDefinition> definitions = locator.getRouteDefinitions().collectList().block();definitions.stream().filter(routeDefinition -> routeDefinition.getId().matches(".*-service")).forEach(routeDefinition -> {// 这个 -service 对应于前面 application.yml 网关的配置String name = routeDefinition.getId().replaceAll("-service", "");// 下面这个 pathsToMatch 其实没有什么用, 随便写个 /abc/** , 不拼接 name 都可以// 但是 group(name) 这句,是和 application.yml 的 springdoc 的配置相关联的GroupedOpenApi.builder().pathsToMatch("/cateye/" + name + "/**").group(name).build();});return groups;}
}

  效果如下图:

在这里插入图片描述

4 影片服务 backend-film 的配置

4.1 ✍️ pom.xml 引入依赖

<dependency><groupId>org.springdoc</groupId><artifactId>springdoc-openapi-starter-webmvc-ui</artifactId><!-- version 交给父 pom.xml 管理了,目前最新的版本是 2.2.0 -->
</dependency>

  因为习惯了 Spring MVC,并且 Webflux 的性能好像也不比 MVC 强很多,所以继续用 MVC 吧,等后续有时间,好好琢磨下 Webflux。

4.2 🌿 application.yml 的配置

4.2.1 Eureka Client 的配置

  和前面网关的一样😊

4.2.2 Springdoc 的配置

server:# 影片服务的端口是 8300port: 8300forward-headers-strategy: framework# springdoc 禁用缓存
springdoc:cache:disabled: true

4.3 Springdoc 配置类

  除了写代码,我们还可以使用注解来配置 OpenAPI ,springdoc 的 github demo 已有展示,我这里就不赘述了,我还是喜欢代码形式的配置。springdoc 的 github demo 详见文末链接。

import io.swagger.v3.oas.models.OpenAPI;
import io.swagger.v3.oas.models.info.Info;
import io.swagger.v3.oas.models.info.License;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
public class MySpringdocConfig {@Beanpublic OpenAPI api() {return new OpenAPI()// 设置一些标题什么的.info(new Info().title("电影APP后台-影片模块 API").version("1.0.0").description("包含了影片和演员相关的 API").license(new License().name("Apache 2.0").url("https://www.apache.org/licenses/LICENSE-2.0")));}
}

5 结语

  完事儿了😁,其实也不难,就是些配置。访问接口也可以访问通,如下图:

在这里插入图片描述

  本文参考了 springdoc 官方 github 上的 demo 项目,链接是 https://github.com/springdoc/springdoc-openapi-demos/tree/2.x/demo-microservices 。除了 demo-microservices,官方还有很多 demo 可以参考。

  等后续再研究下 springdoc 与 oauth 的结合。

  感谢阅读~

这篇关于03_学习springdoc与微服务结合_简述的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/180627

相关文章

Spring Boot项目中结合MyBatis实现MySQL的自动主从切换功能

《SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能》:本文主要介绍SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能,本文分步骤给大家介绍的... 目录原理解析1. mysql主从复制(Master-Slave Replication)2. 读写分离3.

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

SpringCloud之LoadBalancer负载均衡服务调用过程

《SpringCloud之LoadBalancer负载均衡服务调用过程》:本文主要介绍SpringCloud之LoadBalancer负载均衡服务调用过程,具有很好的参考价值,希望对大家有所帮助,... 目录前言一、LoadBalancer是什么?二、使用步骤1、启动consul2、客户端加入依赖3、以服务

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

Python结合Flask框架构建一个简易的远程控制系统

《Python结合Flask框架构建一个简易的远程控制系统》这篇文章主要为大家详细介绍了如何使用Python与Flask框架构建一个简易的远程控制系统,能够远程执行操作命令(如关机、重启、锁屏等),还... 目录1.概述2.功能使用系统命令执行实时屏幕监控3. BUG修复过程1. Authorization

Nginx配置系统服务&设置环境变量方式

《Nginx配置系统服务&设置环境变量方式》本文介绍了如何将Nginx配置为系统服务并设置环境变量,以便更方便地对Nginx进行操作,通过配置系统服务,可以使用系统命令来启动、停止或重新加载Nginx... 目录1.Nginx操作问题2.配置系统服android务3.设置环境变量总结1.Nginx操作问题

springboot的调度服务与异步服务使用详解

《springboot的调度服务与异步服务使用详解》本文主要介绍了Java的ScheduledExecutorService接口和SpringBoot中如何使用调度线程池,包括核心参数、创建方式、自定... 目录1.调度服务1.1.JDK之ScheduledExecutorService1.2.spring

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

TP-Link PDDNS服将于务6月30日正式停运:用户需转向第三方DDNS服务

《TP-LinkPDDNS服将于务6月30日正式停运:用户需转向第三方DDNS服务》近期,路由器制造巨头普联(TP-Link)在用户群体中引发了一系列重要变动,上个月,公司发出了一则通知,明确要求所... 路由器厂商普联(TP-Link)上个月发布公告要求所有用户必须完成实名认证后才能继续使用普联提供的 D

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操