springboot+cloud 学习(四)Zuul整合Swagger2
前言
在微服务架构下,服务是分散的,怎么把所有服务接口整合到一起是我们需要关注的。
下面举例用zuul作为分布式系统的网关,同时使用swagger生成文档,想把整个系统的文档整合在同一个页面上来说明。
项目结构
eureka-server:eureka服务注册中心,端口8761,
eureka-server2:eureka服务注册中心,端口8762,
eureka-server3:eureka服务注册中心,端口8763,
zuul-swagger2:zuul网关,端口8090,
management-device:外接设备系统,端口8083,
management-equip:设备管理系统,端口8082,
Zuul整合Swagger2
eureka注册中心的搭建这里不再讲述,直接来看zuul-swagger2项目里怎么集成swagger
pom.xml文件中引入依赖:
- <!-- 必须要引入 springboot parent ,帮我们实现了很多jar包的依赖管理 -->
- <parent>
- <groupId>org.springframework.boot</groupId>
- <artifactId>spring-boot-starter-parent</artifactId>
- <version>2.0..RELEASE</version>
- <relativePath /> <!-- lookup parent from repository -->
- </parent>
- <dependencyManagement>
- <dependencies>
- <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-dependencies -->
- <dependency>
- <groupId>org.springframework.cloud</groupId>
- <artifactId>spring-cloud-dependencies</artifactId>
- <version>Finchley.RELEASE</version>
- <type>pom</type>
- <scope>import</scope>
- </dependency>
- </dependencies>
- </dependencyManagement>
- <!-- 版本集中配置 -->
- <properties>
- <swagger2.version>2.9.</swagger2.version>
- </properties>
- <dependencies>
- <!-- eureka client -->
- <dependency>
- <groupId>org.springframework.cloud</groupId>
- <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
- </dependency>
- <!-- zuul -->
- <dependency>
- <groupId>org.springframework.cloud</groupId>
- <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
- </dependency>
- <!-- swagger2 依赖 -->
- <dependency>
- <groupId>io.springfox</groupId>
- <artifactId>springfox-swagger2</artifactId>
- <version>${swagger2.version}</version>
- </dependency>
- <dependency>
- <groupId>io.springfox</groupId>
- <artifactId>springfox-swagger-ui</artifactId>
- <version>${swagger2.version}</version>
- </dependency>
- </dependencies>
在配置文件application.yml中添加配置(这里只做了eureka注册,没有做路由映射):
- #端口
- server:
- port:
- #应用名称
- spring:
- application:
- name: zuul-swagger2
- #服务注册
- eureka:
- instance:
- hostname: zuul-swagger2
- client:
- serviceUrl:
- defaultZone: http://skyworth:skyworth1@eureka-server:8761/eureka/,http://skyworth:skyworth2@eureka-server2:8762/eureka/,http://skyworth:skyworth3@eureka-server3:8763/eureka/
- # 路由配置方式一
- #zuul:
- # routes:
- #所有请求management-equip的请求,都会被拦截,并且转发到equip上
- # management-equip: /equip/**
- # 路由配置方式二
- #zuul:
- # routes:
- # # 其中equip是路由名称,可以随便定义,但是path和service-id需要一一对应
- # equip:
- # path: /equip/**
- # # management-equip为注册到Eureka上的服务名
- # service-id: management-equip
Swagger2配置类:
这里比较重要的是2个配置类。第一个:SwaggerConfig.class是swagger的配置类,DocumentationConfig,用于整合配置接口文档
SwaggerConfig.class
- @Configuration
- @EnableSwagger2
- public class SwaggerConfig {
- @Bean
- public Docket buildDocket() {
- return new Docket(DocumentationType.SWAGGER_2)
- .apiInfo(buildApiInf()) // .apiInfo(apiInfo())
- .select()
- .apis(RequestHandlerSelectors.basePackage(""))// 需要生成文档的包的位置
- .paths(PathSelectors.any())
- .build();
- }
- private ApiInfo buildApiInf() {
- return new ApiInfoBuilder()
- .title("海外智能云平台系统接口详情")
- .description("Zuul+Swagger2构建RESTful APIs")
- .termsOfServiceUrl("http://www.skyworth.com")
- .contact(new Contact("skyworth", "http://www.skyworth.com", ""))
- .version("1.0")
- .build();
- }
- }
DocumentationConfig.class(注意红色部分,通过遍历eureka路由方式自动添加所有微服务 API 文档,SwaggerResourcesProvider 是资源提供者,我们重写他,把各个微服务的API文档资源路径返回,注释部分为手动添加的方式)
- @Component
- @Primary
- public class DocumentationConfig implements SwaggerResourcesProvider {
- private final RouteLocator routeLocator;
- public DocumentationConfig(RouteLocator routeLocator) {
- this.routeLocator = routeLocator;
- }
- @Override
- public List<SwaggerResource> get() {
- List<SwaggerResource> resources = new ArrayList<>();
- List<Route> routes = routeLocator.getRoutes();
- routes.forEach(route -> {
- resources.add(swaggerResource(route.getId(), route.getFullPath().replace("**", "v2/api-docs"), "1.0"));
- });
- return resources;
- }
- // @Override
- // public List<SwaggerResource> get() {
- // List resources = new ArrayList<>();
- // resources.add(swaggerResource("外接设备系统", "/management-device/v2/api-docs", "1.0"));
- // resources.add(swaggerResource("设备管理系统", "/management-equip/v2/api-docs", "1.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;
- }
- }
最后是启动类Application
- @SpringBootApplication
- @EnableZuulProxy
- public class Application {
- public static void main(String[] args) {
- SpringApplication.run(Application.class, args);
- }
- }
运行相关服务和zuul-swagger网关,输入:http://localhost:8090/swagger-ui.html
另外谈谈遇到的一个坑,之前没有加eureka.instance.prefer-ip-address=true,导致zuul一直访问不到其他服务(可能是eureka.instance.prefer-ip-address = true
就可以将IP注册到Eureka Server上,而如果不配置就是机器的主机名,而主机名没有做ip映射导致访问不大,具体原因需要探究)。
- #服务注册
- eureka:
- instance:
- hostname: device
- prefer-ip-address: true
springboot+cloud 学习(四)Zuul整合Swagger2的更多相关文章
- SpringBoot(十四)-- 整合Swagger2
1.pom依赖 <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-s ...
- spring cloud 学习(6) - zuul 微服务网关
微服务架构体系中,通常一个业务系统会有很多的微服务,比如:OrderService.ProductService.UserService...,为了让调用更简单,一般会在这些服务前端再封装一层,类似下 ...
- springboot学习四:整合mybatis
在application.properties加入配置 ## Mybatis 配置 mybatis.typeAliasesPackage=org.spring.springboot.domain my ...
- spring cloud学习(四) 动态路由
Zuul的主要功能是路由和过滤器.路由功能是微服务的一部分,zuul实现了负载均衡. 1.1 新建模块zuul pom.xml <?xml version="1.0" enc ...
- springboot+cloud 学习(五)统一配置中心 spring cloud config + cloud bus + WebHooks +RibbitMQ
前言 微服务要实现集中管理微服务配置.不同环境不同配置.运行期间也可动态调整.配置修改后可以自动更新的需求,Spring Cloud Config同时满足了以上要求.Spring Cloud Conf ...
- springboot+cloud 学习(三)消息中间件 RibbitMQ+Stream
安装RabbitMQ window下安装: (1):下载erlang,原因在于RabbitMQ服务端代码是使用并发式语言erlang编写的,下载地址:http://www.erlang.org/dow ...
- springboot+cloud 学习(二)应用间通信Feign(伪RPC,实则HTTP)
在微服务中,使用什么协议来构建服务体系,一直是个热门话题. 争论的焦点集中在两个候选技术: RPC or Restful Restful架构是基于Http应用层协议的产物,RPC架构是基于TCP传输 ...
- SpringBoot实战(十四)之整合KafKa
本人今天上午参考了不少博文,发现不少博文不是特别好,不是因为依赖冲突问题就是因为版本问题. 于是我结合相关的博文和案例,自己改写了下并参考了下,于是就有了这篇文章.希望能够给大家帮助,少走一些弯路. ...
- springboot深入学习(四)-----tomcat配置、websocket
一.更改servlet服务器 springboot中默认可以集成多种servlet容器,当引入如下依赖时: springboot默认以tomcat作为项目的servlet容器,如果用户想要替换tomc ...
随机推荐
- 关于双重for循环封装数据问题
1.问题描述 在使用双重for循环进行封装数据时出现一个问题,就是有的数据封装上了,有的数据未封装上,找了很久原因: for (A a:ListA) { for (B b: ListB) { if(a ...
- trinitycore 魔兽服务器源码分析(三) 多线程相关
先看LockedQueue.h template <class T, typename StorageType = std::deque<T> >class LockedQue ...
- STM32 + RC522(SPI2 和 模拟SPI)
STM32 + RC522(SPI2 和 模拟SPI) 一. STM32 + RC522(SPI2 模式) 1. 头文件: rc522.h #include "stm32f10x.h&quo ...
- qhfl-1 跨域
CORS跨域请求 CORS即Cross Origin Resource Sharing 跨域资源共享,那么跨域请求还分为两种,一种叫简单请求,一种是复杂请求 简单请求 HTTP方法是下列方法之一 HE ...
- UnionFind问题总结
UnionFind就是acm中常用的并查集... 并查集常用操作 另外补充一下STL常用操作 相关问题: 547. Friend Circles 纯裸题噢... class Solution { pu ...
- Tarjan算法(图论)(转)
有点烦人的算法 贴个算法解析合辑先:https://blog.csdn.net/hurmishine/article/details/75248876
- 1119 Pre- and Post-order Traversals
Suppose that all the keys in a binary tree are distinct positive integers. A unique binary tree can ...
- Linux(以centos7为例)下自动挂载NTFS硬盘
Linux(以centos7为例)下自动挂载NTFS硬盘 作者:子敬叔叔 编写时间:2017年5月3日星期三 需求: 为了熟悉Linux的使用,在自己的笔记本上新安装一个centos7, 但我 ...
- mevan中GroupId和ArtifactId到底怎么填?
groupid和artifactId被统称为“坐标”是为了保证项目唯一性而提出的,如果你要把你项目弄到maven本地仓库去,你想要找到你的项目就必须根据这两个id去查找. groupId一般分为多个段 ...
- attempt to open datawindow failed@安装两个PB软件
attempt to open datawindow failed@安装两个PB软件 安装了不同版本的PB软件后,默认打开方式为后一个安装的版本. 如果想改为第一个安装版本,在“右键”——>”打 ...