学习目标: 掌握DockerMaven插件的使用 掌握持续集成工具Jenkins的安装与使用 掌握容器管理工具Rancher的安装与使用 掌握时间序列数据库influxDB的安装与使用 掌握容器监控工具cAdvisor的安装与使用 掌握图表工具Grafana的使用

1 DockerMaven插件

微服务部署有两种方法
(1)手动部署:首先基于源码打包生成jar包(或war包),将jar包(或war包)上传至虚拟机并拷贝至JDK容器。
(2)通过Maven插件自动部署
对于数量众多的微服务,手动部署无疑是非常麻烦的做法,并且容易出错。所以我们这里学习如何自动部署,这也
是企业实际开发中经常使用的方法。
Maven插件自动部署步骤:
(1)修改宿主机的docker配置,让其可以远程访问

vi /lib/systemd/system/docker.service

其中ExecStart=后添加配置-H tcp://0.0.0.0:2375 -H unix:///var/run/docker.sock
修改后如下:

在这里插入图片描述
2)刷新配置,重启服务

systemctl daemon-reload
systemctl restart docker
docker start registry

(3)在工程pom.xml 增加配置

 <build>
        <finalName>app</finalName>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
            <!-- docker的maven插件,官网:https://github.com/spotify/docker-maven-plugin
            -->
            <plugin>
                <groupId>com.spotify</groupId>
                <artifactId>docker-maven-plugin</artifactId>
                <version>0.4.13</version>
                <configuration>
                    <imageName>192.168.233.129:5000/${project.artifactId}:${project.version}
                    </imageName>
                    <baseImage>jdk1.8</baseImage>
                    <entryPoint>["java", "-jar", "/${project.build.finalName}.jar"]
                    </entryPoint>
                    <resources>
                        <resource>
                            <targetPath>/</targetPath>
                            <directory>${project.build.directory}</directory>
                            <include>${project.build.finalName}.jar</include>
                        </resource>
                    </resources>
                    <dockerHost>http://192.168.233.129:2375</dockerHost>
                </configuration>
            </plugin>
        </plugins>
    </build>

以上配置会自动生成Dockerfile

FROM jdk1.8
ADD app.jar /
ENTRYPOINT ["java","-jar","/app.jar"]

(5)在windows的命令提示符下,进入工程tensquare_parent所在的目录

mvn install

进入tensquare_base 所在的目录,输入以下命令,进行打包和上传镜像

mvn docker:build -DpushImage

执行后,会有如下输出,代码正在上传
在这里插入图片描述
(6)进入宿主机 , 查看镜像
在这里插入图片描述
输出如上内容,表示微服务已经做成镜像
浏览器访问 http://192.168.184.141:5000/v2/_catalog ,输出
在这里插入图片描述
(7) 启动容器:

docker run -di --name=base -p 9001:9001 192.168.184.141:5000/tensquare_base:1.0-
SNAPSHOT

在这里插入图片描述

2 持续集成工具-Jenkins

2.1 什么是持续集成

持续集成 Continuous integration ,简称CI
随着软件开发复杂度的不断提高,团队开发成员间如何更好地协同工作以确保软件开发的质量已经慢慢成为开发过程中不可回避的问题。尤其是近些年来,敏捷(Agile) 在软件工程领域越来越红火,如何能再不断变化的需求中快速适应和保证软件的质量也显得尤其的重要。
持续集成正是针对这一类问题的一种软件开发实践。它倡导团队开发成员必须经常集成他们的工作,甚至每天都可能发生多次集成。而每次的集成都是通过自动化的构建来验证,包括自动编译、发布和测试,从而尽快地发现集成错误,让团队能够更快的开发内聚的软件。
持续集成具有的特点:

  1. 它是一个自动化的周期性的集成测试过程,从检出代码、编译构建、运行测试、结果记录、测试统计等都是自动完成的,无需人工干预;
  2. 需要有专门的集成服务器来执行集成构建;
  3. 需要有代码托管工具支持,我们下一小节将介绍Git以及可视化界面Gogs的使用
    持续集成的作用:`
  4. 保证团队开发人员提交代码的质量,减轻了软件发布时的压力;
  5. 持续集成中的任何一个环节都是自动完成的,无需太多的人工干预,有利于减少重复过程以节省时间、费用和工作量;

2.2 Jenkins简介

Jenkins,原名Hudson,2011年改为现在的名字,它 是一个开源的实现持续集成的软件工具。官方网站:
http://jenkins-ci.org/。
Jenkins 能实施监控集成中存在的错误,提供详细的日志文件和提醒功能,还能用图表的形式形象地展示项目构建的趋势和稳定性。
特点:

  1. 易安装:仅仅一个 java -jar jenkins.war,从官网下载该文件后,直接运行,无需额外的安装,更无需安装数据库;
  2. 易配置:提供友好的GUI配置界面;
    变更支持:Jenkins能从代码仓库(Subversion/CVS)中获取并产生代码更新列表并输出到编译输出信息中;
  3. 支持永久链接:用户是通过web来访问Jenkins的,而这些web页面的链接地址都是永久链接地址,因此,你可以在各种文档中直接使用该链接;
  4. 集成E-Mail/RSS/IM:当完成一次集成时,可通过这些工具实时告诉你集成结果(据我所知,构建一次集成需要花费一定时间,有了这个功能,你就可以在等待结果过程中,干别的事情);
  5. JUnit/TestNG测试报告:也就是用以图表等形式提供详细的测试报表功能;
  6. 支持分布式构建:Jenkins可以把集成构建等工作分发到多台计算机中完成;
  7. 文件指纹信息:Jenkins会保存哪次集成构建产生了哪些jars文件,哪一次集成构建使用了哪个版本的jars文件等构建记录;
  8. 支持第三方插件:使得 Jenkins 变得越来越强大

2.3 Jenkins安装

2.3.1 JDK安装

(1)将jdk-8u171-linux-x64.rpm上传至服务器(虚拟机)
(2)执行安装命令

rpm -ivh jdk-8u171-linux-x64.rpm

PM方式安装JDK,其根目录为:/usr/java/jdk1.8.0_171-amd64

2.3.2 Jenkins安装与启动

(1)下载jenkins

wget https://pkg.jenkins.io/redhat/jenkins-2.83-1.1.noarch.rpm

或将jenkins-2.83-1.1.noarch.rpm上传至服务器

(2)安装jenkins

rpm -ivh jenkins-2.83-1.1.noarch.rpm

(3)配置jenkins

vi /etc/sysconfig/jenkins

修改用户和端口

JENKINS_USER="root"
JENKINS_PORT="8888"

(4)启动服务

systemctl start jenkins

(5)访问链接 http://192.168.184.135:8888
从/var/lib/jenkins/secrets/initialAdminPassword中获取初始密码串

在这里插入图片描述
(6)安装插件

在这里插入图片描述

初次访问会要求安装插件, 安装插件时间较长, 需耐心等待
在这里插入图片描述
(7)新建用户
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.4 Jenkins插件安装

我们以安装maven插件为例,演示插件的安装
(1)点击左侧的“系统管理”菜单 ,然后点击
在这里插入图片描述
(2)选择“可选插件”选项卡,搜索maven,在列表中选择Maven Integration ,点击“直接安装”按钮
在这里插入图片描述

2.5 全局工具配置

2.5.1 安装Maven与本地仓库

(1)将Maven压缩包上传至服务器(虚拟机)
(2)解压

tar zxvf apache-maven-3.5.4-bin.tar.gz

(3)移动目录

mv apache-maven-3.5.4 /usr/local/maven

(4)编辑setting.xml配置文件vi /usr/local/maven/conf/settings.xml ,配置本地仓库目录,内容如下

<localRepository>/usr/local/repository</localRepository>

(5)将开发环境的本地仓库上传至服务器(虚拟机)并移动到/usr/local/repository 。

mv reponsitory_boot /usr/local/repository

执行此步是为了以后在打包的时候不必重新下载,缩短打包的时间。
在这里插入图片描述

2.5.2 全局工具配置

选择系统管理,全局工具配置
(1)JDK配置设
在这里插入图片描述
去除自动安装, 设置javahome为 /usr/java/jdk1.8.0_171-amd64
(2)Git配置 (本地已经安装了Git软件)
在这里插入图片描述
(3)Maven配置
在这里插入图片描述
配置完后, 点击保存

2.6 代码上传至Git服务器

2.6.1 Gogs搭建与配置

Gogs 是一款极易搭建的自助 Git 服务。
Gogs 的目标是打造一个最简单、最快速和最轻松的方式搭建自助 Git 服务。使用 Go 语言开发使得 Gogs 能够通过
独立的二进制分发,并且支持 Go 语言支持的 所有平台,包括 Linux、Mac OS X、Windows 以及 ARM 平台。
地址:https://gitee.com/Unknown/gogs
(1)下载镜像

docker pull gogs/gogs

如果镜像下载速度过慢, 进行以下操作

vi /etc/docker/daemon.json

在该文件中输入如下内容:

{
"registry-mirrors":["https://almtd3fa.mirror.aliyuncs.com"]
}

在这里插入图片描述

(2)创建容器

docker run -di --name=gogs -p 10022:22 -p 3000:3000 -v /var/gogsdata:/data gogs/gogs

(3)假设我的centos虚拟机IP为192.168.184.141 在地址栏输入http://192.168.184.141:3000 会进入首次运行安
装程序页面,我们可以选择一种数据库作为gogs数据的存储,最简单的是选择SQLite3。如果对于规模较大的公
司,可以选择MySQL
在这里插入图片描述

在这里插入图片描述
点击“立即安装”
这里的域名要设置为centos的IP地址,安装后显示主界面

在这里插入图片描述
(4)注册
在这里插入图片描述
(5)登录
在这里插入图片描述

(6)创建仓库

在这里插入图片描述
在这里插入图片描述

2.6.2 提交代码

步骤:
(1)在本地安装git(Windows版本)
(2)在IDEA中选择菜单 : File – settings , 在窗口中选择Version Control – Git
在这里插入图片描述

(3)选择菜单VCS --> Enable Version Control Integration…
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
(5)右键点击工程选择菜单 Git --> Add
(6)右键点击工程选择菜单 Git --> Commit Directory…
(7)右键点击工程选择菜单 Git --> Repository --> Push …
在这里插入图片描述

2.7 任务的创建与执行

(1)回到首页,点击新建按钮 .如下图,输入名称,选择创建一个Maven项目,点击OK

在这里插入图片描述
(2)源码管理,选择Git
在这里插入图片描述
在这里插入图片描述
(3)Build
在这里插入图片描述
在这里插入图片描述
用于清除、打包,构建docker镜像
最后点击“保存”按钮
在这里插入图片描述
(4)执行任务
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3 容器管理工具Rancher

3.1 什么是Rancher

Rancher是一个开源的企业级全栈化容器部署及管理平台。Rancher为容器提供一揽子基础架构服务:CNI兼容的
网络服务、存储服务、主机管理、负载均衡、防护墙……Rancher让上述服务跨越公有云、私有云、虚拟机、物理
机环境运行,真正实现一键式应用部署和管理。
https://www.cnrancher.com/

3.2 Rancher安装

(1)下载Rancher 镜像

docker pull rancher/server

(2)创建Rancher容器

docker run -di --name=rancher -p 9090:8080 rancher/server

(3)在浏览器输入地址:http://192.168.233.130:9090 即可看到高端大气的欢迎页
在这里插入图片描述
点击Got It 进入主界面
在这里插入图片描述
切换后我们就可以看到亲切的中文界面啦~
在这里插入图片描述

3.3 Rancher初始化

3.3.1 添加环境

Rancher 支持将资源分组归属到多个环境。 每个环境具有自己独立的基础架构资源及服务,并由一个或多个用
户、团队或组织所管理。
例如,您可以创建独立的“开发”、“测试”及“生产”环境以确保环境之间的安全隔离,将“开发”环境的访问权限赋予全
部人员,但限制“生产”环境的访问权限给一个小的团队。
(1)选择“Default -->环境管理” 菜单
在这里插入图片描述
在这里插入图片描述
(2)填写名称,点击“创建”按钮

在这里插入图片描述
(3)按照上述步骤,添加十次方测试环境和生产环境
(4)你可以通过点击logo右侧的菜单在各种环境下切换
在这里插入图片描述

3.3.2 添加主机

(1)选择基础架构-->主机 菜单,点击添加主机

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
(2)拷贝脚本
在这里插入图片描述
(3)在服务器(虚拟机)上运行脚本
在这里插入图片描述
在这里插入图片描述
如果网速慢, 一直下不来, 可以等晚点再试
(4)点击关闭按钮后,会看到界面中显示此主机。我们可以很方便地管理主机的每个容器的开启和关闭

在这里插入图片描述
在这里插入图片描述

3.3.3 添加应用

点击应用-->全部(或用户) ,点击“添加应用”按钮
在这里插入图片描述
在这里插入图片描述
点击创建

3.4 应用部署

3.4.1 MySQL部署

镜像:centos/mysql-57-centos7 增加数据库服务
点击添加服务,
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
点击创建
在这里插入图片描述
可以看到已经创建成功,
点击创建按钮,完成创建 上述操作相当于以下docker命令

docker run -di --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 centos/mysql-57-
centos7

3.4.2 RabbitMQ部署

镜像:rabbitmq:management
端口映射5671 5672 4369 15671 15672 25672
在这里插入图片描述
这里可以看到目前并无rabbitMq的镜像
在这里插入图片描述

在这里插入图片描述
这次事件会长一些, 因为docker中并无该镜像, 这里需要先下载镜像,
在这里插入图片描述
浏览器访问 http://192.168.233.132:15672/

在这里插入图片描述

3.4.3 Redis部署

进入应用,点击添加服务,名称redis ,镜像redis ,端口映射6379
在这里插入图片描述
在这里插入图片描述

测试连接

在这里插入图片描述
测试成功

3.4.4 微服务部署

(1)搭建私有仓库
启动私有仓库容器

docker run -di --name=registry -p 5000:5000 registry

在这里插入图片描述

打开浏览器 输入地址http://192.168.233.132:5000/v2/_catalog看到{“repositories”:[]} 表示私有仓库搭建
成功并且内容为空
在这里插入图片描述
修改daemon.json

vi /etc/docker/daemon.json

添加以下内容,保存退出。

{"insecure-registries":["192.168.233.132:5000"]}

(2)修改docker配置,允许远程访问

vi /lib/systemd/system/docker.service

其中ExecStart=后添加配置-H tcp://0.0.0.0:2375 -H unix:///var/run/docker.sock
其中0.0.0.0表示任何ip都可以访问, 如果想指定ip访问, 可以替换
修改后刷新配置,重启服务

systemctl daemon-reload
systemctl restart docker
docker start registry

在这里插入图片描述
(3)修改微服务工程,添加DockerMaven插件

<build>
        <finalName>app</finalName>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
            <!-- docker的maven插件,官网:https://github.com/spotify/docker-maven-plugin
            -->
            <plugin>
                <groupId>com.spotify</groupId>
                <artifactId>docker-maven-plugin</artifactId>
                <version>0.4.13</version>
                <configuration>
                    <imageName>192.168.233.132:5000/${project.artifactId}:${project.version}
                    </imageName>
                    <baseImage>jdk1.8</baseImage>
                    <entryPoint>["java", "-jar", "/${project.build.finalName}.jar"]
                    </entryPoint>
                    <resources>
                        <resource>
                            <targetPath>/</targetPath>
                            <directory>${project.build.directory}</directory>
                            <include>${project.build.finalName}.jar</include>
                        </resource>
                    </resources>
                    <dockerHost>http://192.168.233.132:2375</dockerHost>
                </configuration>
            </plugin>
        </plugins>
    </build>

在这里插入图片描述
这里如果没有配置docker的jdk1.8镜像, 会报错误

详情配置参考


步骤:
(1)创建目录

mkdir –p /usr/local/dockerjdk8

(2)下载jdk-8u171-linux-x64.tar.gz并上传到服务器(虚拟机)中 的/usr/local/dockerjdk8目录

(3)创建文件Dockerfile vi Dockerfile

#依赖镜像名称和ID
FROM centos:7
#指定镜像创建者信息
MAINTAINER chen
#切换工作目录
WORKDIR /usr
RUN mkdir /usr/local/java
#ADD 是相对路径jar,把java添加到容器中
ADD jdk‐8u171‐linux‐x64.tar.gz /usr/local/java/
#配置java环境变量
ENV JAVA_HOME /usr/local/java/jdk1.8.0_171
ENV JRE_HOME $JAVA_HOME/jre
ENV CLASSPATH
$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib:$CLASSPATH
ENV PATH $JAVA_HOME/bin:$PATH

(4)执行命令构建镜像

docker build ‐t='jdk1.8' .

注意后边的空格和点,不要省略


在这里插入图片描述
在这里插入图片描述

上传完成
(4)连接mysql数据库,执行建库脚本
(5)添加服务base-service 镜像192.168.233.132:5000/tensquare_base:1.0-SNAPSHOT 端口映射9001
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
微服务部署成功, 访问成功
在这里插入图片描述

3.6 扩容与缩容

3.6.1 扩容

(1)在Rancher将创建的base-service-test(基础信息微服务)删除
(2)重新创建base-service ,不设置端口映射

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
(3)在选择菜单API -->WebHooks ,点击“添加接收器”按钮
在这里插入图片描述
(4)填写名称等信息,选择要扩容的服务,点击创建按钮
在这里插入图片描述

(5)接收器列表中新增了一条记录 ,点击触发地址将地址复制到剪切板
在这里插入图片描述
(6)使用postman测试:
在这里插入图片描述
测试后,发现容器由原来的1个变为了3个
在这里插入图片描述

3.6.2 缩容

刚才我们实现了扩容,那么如何减少容器数量呢?我们来试试如何缩容
(1)添加接收器 ,选择缩容,步长为1表示每次递减1个 ,点击创建按钮
在这里插入图片描述

(2)创建成功后,复制触发地址
在这里插入图片描述

在这里插入图片描述
发送请求, base-service从三个容器变成了两个容器
在这里插入图片描述
如果想要访问base-service这两个容器中的服务, 则需要用到rancher中的负载均衡器, 服务会轮询访问
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
值得注意的是: 如果只有两个容器, 有可能会创建失败, 所以我又再次扩容了一下, 使得base-service中有三个容器
测试一下:
在这里插入图片描述
访问成功

4 influxDB

4.1 什么是influxDB

influxDB是一个分布式时间序列数据库。cAdvisor仅仅显示实时信息,但是不存储监视数据。因此,我们需要提供时序数据库用于存储cAdvisor组件所提供的监控信息,以便显示除实时信息之外的时序数据。

4.2 influxDB安装

(1)下载镜像

docker pull tutum/influxdb

(2)创建容器

docker run -di \
-p 8083:8083 \
-p 8086:8086 \
--expose 8090 \
--expose 8099 \
--name influxsrv \
tutum/influxdb

端口概述: 8083端口:web访问端口 8086:数据写入端口
打开浏览器 http://192.168.233.133:8083
在这里插入图片描述

4.3 influxDB常用操作

4.3.1 创建数据库

在这里插入图片描述
回车创建数据库
在这里插入图片描述
在这里插入图片描述
查询有哪些数据库
在这里插入图片描述
在这里插入图片描述

4.3.2 创建用户并授权

创建用户

CREATE USER "cadvisor" WITH PASSWORD 'cadvisor' WITH ALL PRIVILEGES

在这里插入图片描述
查看用户

SHOW USRES

在这里插入图片描述
用户授权

grant all privileges on cadvisor to cadvisor //赋予这个用户所有权限
grant WRITE on cadvisor to cadvisor  //赋予这个用户写的权限
grant READ on cadvisor to cadvisor  //赋予这个用户读的权限

4.3.3 查看采集的数据

切换到cadvisor数据库,使用以下命令查看采集的数据

SHOW MEASUREMENTS

现在我们还没有数据,如果想采集系统的数据,我们需要使用Cadvisor软件来实现

5 cAdvisor

5.1 什么是cAdvisor

Google开源的用于监控基础设施应用的工具,它是一个强大的监控工具,不需要任何配置就可以通过运行在Docker主机上的容器来监控Docker容器,而且可以监控Docker主机。更多详细操作和配置选项可以查看Github上的cAdvisor项目文档。

5.2 cAdvisor安装

(1)下载镜像

docker pull google/cadvisor

(2)创建容器

docker run --volume=/:/rootfs:ro --volume=/var/run:/var/run:rw --volume=/sys:/sys:ro --volume=/var/lib/docker/:/var/lib/docker:ro --publish=8080:8080 --detach=true --link influxsrv:influxsrv --name=cadvisor google/cadvisor -storage_driver=influxdb -storage_driver_db=cadvisor -storage_driver_host=influxsrv:8086

在这里插入图片描述

WEB前端访问地址
http://192.168.233.133:8080/containers/
在这里插入图片描述

性能指标含义参照如下地址
https://blog.csdn.net/ZHANG_H_A/article/details/53097084
再次查看influxDB,发现已经有很多数据被采集进去了。

在这里插入图片描述
如果想查看具体数据
在这里插入图片描述

6 Grafana

6.1 什么是Grafana

Grafana是一个可视化面板(Dashboard),有着非常漂亮的图表和布局展示,功能齐全的度量仪表盘和图形编辑
器。支持Graphite、zabbix、InfluxDB、Prometheus和OpenTSDB作为数据源。 Grafana主要特性:灵活丰富的
图形化选项;可以混合多种风格;支持白天和夜间模式;多个数据源。

6.2 Grafana安装

(1)下载镜像

docker pull grafana/grafana

(2)创建容器

docker run -d -p 3001:3000 -e INFLUXDB_HOST=influxsrv -e INFLUXDB_PORT=8086 -e INFLUXDB_NAME=cadvisor -e INFLUXDB_USER=cadvisor -e INFLUXDB_PASS=cadvisor --link influxsrv:influxsrv --name grafana grafana/grafana

在这里插入图片描述
(3)访问

http://192.168.233.133:3001

用户名密码均为admin
在这里插入图片描述
(4)登录后提示你修改密码

在这里插入图片描述
这里设为123456
(5)之后进入主页面
在这里插入图片描述

6.3 Grafana的使用

6.3.1 添加数据源

(1)点击设置,DataSource

在这里插入图片描述
在这里插入图片描述

(3)为数据源起个名称,指定类型、地址、以及连接的数据库名、用户名和密码
在这里插入图片描述
在这里插入图片描述

6.3.2 添加仪表盘

(1)选择Dashboards --Manager

在这里插入图片描述
在这里插入图片描述
(2)点击“添加”按钮
(3)点击Graph 图标
在这里插入图片描述
(4)出现下面图表的界面 ,点击Panel Title 选择Edit (编辑)
在这里插入图片描述
(5)定义标题等基础信息
在这里插入图片描述
在这里插入图片描述
(6)设置查询的信息为内存,指定容器名称
这里可以设置监控数据库的时间间隔
在这里插入图片描述
设置查询的信息为内存
在这里插入图片描述
在这里插入图片描述
(7)指定y轴的单位 为M

在这里插入图片描述

(8)保存
在这里插入图片描述
填写名称
在这里插入图片描述
在这里插入图片描述

6.4.3 预警通知设置

(1)选择菜单 alerting--> Notification channels
在这里插入图片描述
(2)点击Add channel 按钮
在这里插入图片描述
(3)填写名称,选择类型为webhook ,填写钩子地址
在这里插入图片描述
这个钩子地址是之前对base微服务扩容的地址
在这里插入图片描述
(4)点击SendTest 测试 观察基础微服务是否增加容器

在这里插入图片描述

发现容器增加了两个, 测试成功
在这里插入图片描述
(5)点击save保存
(6)按照同样的方法添加缩容地址

6.4.4 仪表盘预警设置

(1)再次打开刚刚编辑的仪表盘
在这里插入图片描述
(2)点击 Create Alert
在这里插入图片描述
设置预警线
(3)选择通知

在这里插入图片描述
保存更改

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐