我們一起聊聊微服務聚合 API 文檔
今天這篇文章介紹一下微服務如何聚合Swagger實現(xiàn)接口文檔管理。
文章目錄如下:
圖片
為什么需要聚合?
微服務模塊眾多,如果不聚合文檔,則訪問每個服務的API文檔都需要單獨訪問一個Swagger UI界面,這么做客戶端能否接受?
反正作為強迫癥的我是接受不了.......
既然使用了微服務,就應該有統(tǒng)一的API文檔入口。
如何聚合?
統(tǒng)一的文檔入口顯然應該聚合到網(wǎng)關(guān)中,通過網(wǎng)關(guān)的入口統(tǒng)一映射到各個模塊。
圖片
本文采用Spring Cloud Gateway 聚合 Swagger 的 方式 生成API文檔。
案例源碼結(jié)構(gòu)如下:
圖片
本文只介紹如何聚合Swagger,關(guān)于網(wǎng)關(guān)、注冊中心等內(nèi)容不再介紹,有不了解的看陳某前面文章。
單個服務如何聚合Swagger?
這里的單個服務不包括網(wǎng)關(guān),網(wǎng)關(guān)需要單獨配置。
單個服務聚合其實很簡單,就是普通的Spring Boot 整合 Swagger,但是微服務模塊眾多,不能每個微服都整合一番,因此可以自定義一個swagger-starter,之后每個微服務都依賴這個starter即可。
詳細的步驟如下:
1、創(chuàng)建swagger-starter
自定義starter這里就不再介紹了,都是基礎(chǔ)的知識;
目錄結(jié)構(gòu)如下:
圖片
1)添加依賴
對于Swagger原生的UI界面陳某不太喜歡,因此使用了一款看起來還不錯的UI界面,依賴如下:
<!--swagger-->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-boot-starter</artifactId>
</dependency>
<!--swagger-ui 這里是用了一個好看一點ui界面-->
<dependency>
<groupId>com.github.xiaoymin</groupId>
<artifactId>swagger-bootstrap-ui</artifactId>
</dependency>
對于UI界面,每個人審美不同,選擇自己喜歡的就好。
2)自動配置類配置Swagger
陳某是將每個服務的API信息抽離出一個屬性類SwaggerProperties,后續(xù)只需要在每個服務的配置文件中指定即可。
@Data
@ConfigurationProperties(prefix = SwaggerProperties.PREFIX)
@Component
@EnableConfigurationProperties
publicclass SwaggerProperties {
publicstaticfinal String PREFIX="spring.swagger";
//包
private String basePackage;
//作者相關(guān)信息
private Author author;
//API的相關(guān)信息
private ApiInfo apiInfo;
@Data
publicstaticclass ApiInfo{
String title;
String description;
String version;
String termsOfServiceUrl;
String license;
String licenseUrl;
}
@Data
publicstaticclass Author{
private String name;
private String email;
private String url;
}
}
對于Swagger的配置其實很簡單,分為如下部分:
- API文檔基本信息配置
- 授權(quán)信息配置(基于OAuth2的認證配置)
API文檔配置無非就是配置文檔的基本信息,比如文檔標題、作者、聯(lián)系方式.....
代碼如下:
圖片
授權(quán)信息配置也很簡單,就是在全局信息的請求頭中配置一個能夠放置令牌的地方,代碼如下:
圖片
此處對應UI界面的地方如下圖:
圖片
只需要將獲取token令牌設(shè)置到這里即可。
好了,swagger-starter關(guān)鍵代碼就介紹完了,詳細配置見源碼。
案例源碼已上傳GitHub,關(guān)注公眾號:碼猿技術(shù)專欄,回復關(guān)鍵:9528 獲??!
2、微服務引用swagger-starter
單個微服務引用就很簡單了,只需要添加如下依賴:
<dependency>
<groupId>cn.myjszl</groupId>
<artifactId>swagger-starter</artifactId>
</dependency>
接下來只需要在配置文件配置API相關(guān)的信息即可,比如訂單服務的配置如下:
圖片
好了,至此單個服務的配置完成了。
此時我們可以驗證一下,直接訪問:http://localhost:3002/swagger-order-boot/v2/api-docs,結(jié)果如下圖:
圖片
網(wǎng)關(guān)如何聚合Swagger?
網(wǎng)關(guān)聚合的思想很簡單,就是從路由中獲取微服務的訪問地址,然后拼接上 /v2/api-docs 即可。
同樣的還是要添加Swagger的兩個依賴,如下:
<!--swagger-->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-boot-starter</artifactId>
</dependency>
<!--swagger-ui 這里是用了一個好看一點ui界面-->
<dependency>
<groupId>com.github.xiaoymin</groupId>
<artifactId>swagger-bootstrap-ui</artifactId>
</dependency>
創(chuàng)建GatewaySwaggerResourcesProvider實現(xiàn)SwaggerResourcesProvider,重寫其中的get方法,代碼如下:
圖片
案例源碼已上傳GitHub,關(guān)注公眾號:碼猿技術(shù)專欄,回復關(guān)鍵:9528 獲?。?/span>
好了,網(wǎng)關(guān)的配置這里就完成了。
此時啟動網(wǎng)關(guān)、訂單、庫存服務,直接訪問網(wǎng)關(guān)的文檔:http://localhost:3001/doc.html,結(jié)果如下圖:
圖片
API文檔好用的功能介紹
不得不說這款Swagger UI 界面還是比較簡單易用的,個人用起來還不錯。
1、搜索功能
在右上角的搜索功能可以根據(jù)接口描述搜索相關(guān)的接口信息,如下圖:
圖片
2、離線文檔
可以直接拷貝文檔的MarkDown形式轉(zhuǎn)換成Html或者PDF生成離線文檔,如下圖:
圖片
3、令牌配置
在訪問需要認證的接口時,可以通過配置令牌,這樣令牌將會全局生效,不必每個請求都要配置一遍,如下:
圖片
4、配置緩存
該文檔的所有配置,包括請求參數(shù)、授權(quán)令牌等信息都是緩存的,也就是說配置一次,下次再打開的時候也是默認存在的。
5、全局參數(shù)配置
對于一些全局的參數(shù),比如請求頭中需要攜帶請求客戶端、版本號等信息,可以在全局參數(shù)中配置,如下:
圖片
總結(jié)
本篇文章介紹了微服務集成網(wǎng)關(guān)聚合Swagger文檔,開發(fā)中非常實用。