YApi接口管理平台本地搭建方法介绍

news2025/1/4 1:03:02

YApi是一个免费开源的API管理平台,开发人员可用它来管理、调试接口,并且提供了API文档管理和测试功能,具有友好的UI页面,本文介绍Linux环境如何安装部署YApi接口管理平台。

目录

  • 1 环境准备
  • 2 安装部署
    • 2.1 安装nodejs
    • 2.2 安装 MongoDB
    • 2.3 启动MongoDB
    • 2.4 安装yapi
    • 2.5 启动yapi
      • 2.5.1 node命令启动
      • 2.5.2 pm2方式启动
    • 2.6 安装cross-request插件
  • 3 参考文档

1 环境准备

YApi离线安装部署主要包括以下安装包:

  • mongodb:https://www.mongodb.com/try/download/community
  • node:https://registry.npmmirror.com/binary.html?path=node/
  • yapi:https://github.com/YMFE/yapi
  • pm2:https://github.com/Unitech/pm2/releases
  • cross-request插件:https://github.com/YMFE/cross-request

可以直接到这里下载:yapi离线安装部署依赖包资源-CSDN文库

可以使用 yapi-cli 工具来部署 YApi 平台,具体教程可参考官方文档:https://hellosean1025.github.io/yapi/devops/index.html。

2 安装部署

2.1 安装nodejs

登录服务器,进行如下操作:

# 新建文件夹
$ mkdir -p /root/tools/nodejs
# 解压文件
$ tar xvf node-v12.13.0-linux-x64.tar.gz
# 移动文件
$ mv node-v12.13.0-linux-x64/* /root/tools/nodejs
# 添加 node 环境变量
$ vim /etc/profile
export PATH=$PATH:/root/tools/nodejs/bin
# 刷新环境变量
$ source /etc/profile
# 检测软链接是否生效
$ node -v
v12.13.0

# 如果报错,可添加一下软链接
$ ln -s /root/tools/nodejs/bin/npm /usr/local/bin
$ ln -s /root/tools/nodejs/bin/node /usr/local/bin

# 检测软链接是否生效
node -v npm

2.2 安装 MongoDB

安装MongoDB数据库:

# 新建文件夹
$ mkdir -p /root/tools/mongodb

# 解压文件
$ tar -zxvf mongodb-linux-x86_64-3.0.6.tgz
# 移动文件
$ mv mongodb-linux-x86_64-rhel70-7.0.14/* /root/tools/mongodb
# 添加 mongodb 环境变量
$ vim /etc/profile
export PATH=$PATH:/root/tools/mongodb/bin
# 刷新环境变量
$ source /etc/profile
# 检查 mongodb 环境变量是否生效
$ mongod --version
db version v7.0.14
Build Info: {
    "version": "7.0.14",
    "gitVersion": "ce59cfc6a3c5e5c067dca0d30697edd68d4f5188",
    "openSSLVersion": "OpenSSL 1.0.1e-fips 11 Feb 2013",
    "modules": [],
    "allocator": "tcmalloc",
    "environment": {
        "distmod": "rhel70",
        "distarch": "x86_64",
        "target_arch": "x86_64"
    }
}

# 如果报错,可添加软链接
$ ln -s /root/tools/mongodb/bin/mongod /usr/bin/mongod

2.3 启动MongoDB

# 切换到 mongodb 文件夹下
$ cd /root/tools/mongodb
# 创建多级文件夹 data/db
$ mkdir -p data/db
# 创建文件 data/mongo.log
$ touch data/mongo.log
# 创建 mongodb.conf 填写如下信息(路径修改为你自己的路径)
$ vim mongodb.conf
dbpath=/root/tools/mongodb/data/db
logpath=/root/tools/mongodb/data/mongo.log
logappend=true
journal=true
quiet=true
fork=true
port=27017

# 启动 mongodb
$ mongod -f /root/tools/mongodb/mongodb.conf
about to fork child process, waiting until server is ready for connections.
forked process: 17525
child process started successfully, parent exiting

创建用户名和密码:

# 连接本机的mongodb
$ mongo
>
# 当前所有的数据库
> show dbs
local  0.078GB
use yapi
# 创建用户名/密码
$ db.createUser({user:'admin',pwd:'admin', roles:[{role:'readWrite', db:'yapi'}]})
use admin
# 创建用户名/密码
$ db.createUser({user:'admin',pwd:'admin', roles:[{role:'readWrite', db:'admin'}]})

2.4 安装yapi

yapi安装:

# 新建文件夹
$ tar -xvf yapi.tar
$ cd /root/tools/yapi/
$ cp /root/tools/yapi/vendors/config_example.json ./config.json

# 配置config.json
{
  "port": "3000",
  "adminAccount": "admin@admin.com",
  "db": {
    "servername": "127.0.0.1",
    "DATABASE": "yapi",
    "port": 27017,
    "user": "admin",
    "pass": "admin",
    "authSource": "admin"
  },
  "mail": {
    "enable": false,
    "host": "smtp.exmail.qq.com",
    "port": 465,
    "from": "xxx@xxx.cn",
    "auth": {
      "user": "xxx@xxx.cn",
      "pass": "xxx"
    }
  }
}

2.5 启动yapi

介绍两种启动方式:

2.5.1 node命令启动

# 初始化数据库
$ cd /root/tools/yapi/vendors
$ npm run install-server

> yapi-vendor@1.10.2 install-server /root/tools/yapi/vendors
>  node server/install.js

log: mongodb load success...
初始化管理员账号成功,账号名:"admin@admin.com",密码:"ymfe.org"

# 启动yapi server
$ node server/app.js
log: -------------------------------------swaggerSyncUtils constructor-----------------------------------------------
log: 服务已启动,请打开下面链接访问:
http://127.0.0.1:3000/
log: mongodb load success...

2.5.2 pm2方式启动

要保证后台保持进程运行,首先需要安装 pm2:

$ npm root -g
/root/tools/nodejs/lib/node_modules
$ cd /root/tools/nodejs/lib/node_modules
# 解压 pm2 文件
$ tar -xvf pm2-5.4.2.tar.gz
$ cd pm2-5.4.2
$ npm install
# 添加 pm2 环境变量
$ vim /etc/profile
export PATH=$PATH:/root/tools/nodejs/lib/node_modules/pm2-5.4.2/bin
# 刷新环境变量
$ source /etc/profile
# 检查 pm2 环境变量是否生效
$ pm -v

# 切换到部署路径下启动
$ cd /root/tools/yapi/
$ pm2 start vendors/server/app.js
[PM2] Starting /root/tools/yapi/vendors/server/app.js in fork_mode (1 instance)
[PM2] Done.
┌────┬────────────────────┬──────────┬──────┬───────────┬──────────┬──────────┐
│ id │ name               │ mode     │ ↺    │ status    │ cpu      │ memory   │
├────┼────────────────────┼──────────┼──────┼───────────┼──────────┼──────────┤
│ 0  │ app                │ fork     │ 0    │ online    │ 0%       │ 13.3mb   │
└────┴────────────────────┴──────────┴──────┴───────────┴──────────┴──────────┘

浏览器访问http://127.0.0.1:3000/:

可使用生成的管理员账号名:“admin@admin.com”,密码:"ymfe.org"进行登录,点击注册可注册新用户。

2.6 安装cross-request插件

yapi提供了接口测试服务,需要安装cross-request插件,仅支持 chrome 浏览器,下载地址:https://github.com/YMFE/cross-request

  • 打开Chrome浏览器插件管理 chrome://extensions/
  • 打开开发者模式
  • 点击左边的加载已解压扩展程序,选择cross-request文件夹位置即可

安装成功后即可使用yapi进行接口测试:

3 参考文档

  1. https://github.com/yapi-pro/yapi
  2. https://url.nodejs.cn/download/
  3. YMFE/yapi: YApi 是一个可本地部署的、打通前后端及QA的、可视化的接口管理平台 (github.com)
  4. https://hellosean1025.github.io/yapi/devops/index.html#%e5%ae%89%e8%a3%85
  5. http://yapi.dapengjiaoyu.com/
  6. https://hub.docker.com/r/yapipro/yapi
--THE END--

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2269555.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

案例分析-采样率对模拟链路的带宽的影响

目录 问题来源: 情况分析: 总结 问题来源: 在进行模拟带宽调整时,发现设计值 与实测值,不一样,就这一问题,进行详细分析。 情况分析: 在本项目中,采用巴特沃兹四阶滤波器,设计带宽350M,改滤波器设计可以采用fiter solution工具进行设计,实测值仅仅260M,因此针…

Huggingface Trending!可控人物图像生成统一框架Leffa,可精确控制虚拟试穿和姿势转换!

今天给大家介绍一个Huggingface上虚拟试穿的热门项目Leffa,Leffa是一个可控人物图像生成的统一框架,可以精确操纵外观(即虚拟试穿)和姿势(即姿势转换)。从效果看生成效果很不错! 相关链接 论文&…

memcached的基本使用

memcached是一种基于键值对的内存数据库,一般应用于缓存数据,提高数据访问速度,减轻后端数据库压力。 安装 这里以Ubuntu为例,其他系统安装方法请看官方文档。 sudo apt-get update sudo apt-get install memcached启动 memca…

ROS话题通信

1 .理论模型 话题通信实现模型是比较复杂的,该模型如下图所示,该模型中涉及到三个角色: ROS Master (管理者)Talker (发布者)Listener (订阅者) ROS Master 负责保管 Talker 和 Listener 注册的信息,并匹配话题相同的 Talker 与 Listener,…

经验证:将数据从索尼传输到Android的 4 种方法

概括 像Android Galaxy S20 这样的新型Android智能手机很酷,但除了将数据从索尼传输到Android之外。众所周知,旧的索尼手机上存储着大量的文件,因此将数据从旧的索尼手机传输到新的Android手机非常重要。为了解决这个问题,我们做…

VITUREMEIG | AR眼镜 算力增程

根据IDC发布的《2024年第三季度美国AR/VR市场报告》显示,美国市场AR/VR总出货量增长10.3%。其中,成立于2021年的VITURE增长速度令人惊艳,同比暴涨452.6%,成为历史上增长最快的AR/VR品牌。并在美国AR领域占据了超过50%的市场份额&a…

JavaSpring AI与阿里云通义大模型的集成使用Java Data Science Library(JDSL)进行数据处理

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默, 忍不住分享一下给大家。点击跳转到网站 学习总结 1、掌握 JAVA入门到进阶知识(持续写作中……) 2、学会Oracle数据库入门到入土用法(创作中……) 3、手把…

git reset --hard(重置到当前提交,所有未提交的更改都会被永久丢弃)

git reset --hard 是一个强大的命令,它会将你的工作目录、暂存区和当前分支的 HEAD 指针重置到指定的提交状态,所有未提交的更改都会被永久丢弃。因此,使用这个命令时需要非常小心。 基本用法 重置到当前提交(丢弃所有未提交的更…

基于单片机智能水产养殖系统设计(论文+源码)

1 系统方案设计 根据系统设计需求,对智能水产养殖系统总体方案展开详细设计。如图2.1所示为系统设计总框架,系统以STM32单片机作为主控制器,通过DS18B20温度传感器、水位传感器、TSW-30浊度传感器、光照传感器实现水产养殖环境中水温、水位、…

基于微信小程序的校园点餐平台的设计与实现(源码+SQL+LW+部署讲解)

文章目录 摘 要1. 第1章 选题背景及研究意义1.1 选题背景1.2 研究意义1.3 论文结构安排 2. 第2章 相关开发技术2.1 前端技术2.2 后端技术2.3 数据库技术 3. 第3章 可行性及需求分析3.1 可行性分析3.2 系统需求分析 4. 第4章 系统概要设计4.1 系统功能模块设计4.2 数据库设计 5.…

Mysql学习笔记之约束

1.简介 MySQL中的约束用于定义表中数据的规则,以确保数据的准确性和完整性。以保证数据表中数据的有效性、正确性和完整性。 2.约束分类 在mysql中约束分类如下: 约束说明关键字主键约束每个表只能有一个主键;主键的值必须唯一&#xff0…

LabVIEW 实现自动对焦的开发

自动对焦(Autofocus, AF)技术是通过分析图像或传感器信号,动态调整焦点位置以实现清晰成像或高精度定位的过程。在LabVIEW中,可以通过集成信号采集、数据处理、控制算法和硬件接口模块,实现多种自动对焦方法&#xff0…

2024年第52周ETF周报

ETF 第52 周 ( 2024-12-23 至 2024-12-29 )周报 核心观点 ETF 业绩表现 股票型ETF周度收益率中位数为1.0731%宽基ETF中,科创创业50涨跌幅中位数为1.5625%,跌幅最小。按板块划分,金融涨跌幅中位数为1.9334%&#xff…

[Qt] 万字详解Qt入门~ Qt Creator | 对象树 | 控件布局

目录 1. Qt Creator 概览 2. 使用 Qt Creator 新建项目 3. 认识 Qt Creator 界面 4. Qt Hello World 程序 1. 使用 “按钮” 实现 2. 使用 “标签” 实现 3. 使用 “编辑框” 实现 5. 项目文件解析 1. 命名空间声明与作用 2. class Widget : public QWidget 6. Qt 编…

远程命令执行之基本介绍

一.远程命令执行漏洞 1.命令执行 命令执行是指计算机程序接受用户输入的命令,并按照命令的要求执行相应的操作。命令可以执行各种操作,例如读取文件、创建文件、修改文件、运行程序、删除文件等。 命令执行通常是通过一个命令行界面或终端窗口进行的。在…

【数据结构-单调队列】力扣2762. 不间断子数组

给你一个下标从 0 开始的整数数组 nums 。nums 的一个子数组如果满足以下条件&#xff0c;那么它是 不间断 的&#xff1a; i&#xff0c;i 1 &#xff0c;…&#xff0c;j 表示子数组中的下标。对于所有满足 i < i1, i2 < j 的下标对&#xff0c;都有 0 < |nums[i1…

扩充vmware磁盘大小以及分区

扩充vmware磁盘大小以及分区 扩充vmware磁盘大小 分区 目前使用vmware版本为17.5.2 gparted fdisk cxqubuntu:~$ sudo fdisk -l Disk /dev/loop0: 219 MiB, 229638144 bytes, 448512 sectors Units: sectors of 1 * 512 512 bytes Sector size (logical/physical): 512 …

【Python图像处理】进阶实战续篇(七)

在上一篇文章中&#xff0c;我们探讨了Python在图像处理中的几个前沿技术&#xff0c;包括语义分割和视频帧间插值。本篇将继续深化这些话题&#xff0c;并进一步拓展到其他相关的高级技术应用中&#xff0c;以便为读者提供更为详尽的知识体系。 12. 深度学习在语义分割中的应…

TIOBE 指数 12 月排行榜公布,VB.Net排行第九

IT之家 12 月 10 日消息&#xff0c;TIOBE 编程社区指数是一个衡量编程语言受欢迎程度的指标&#xff0c;评判的依据来自世界范围内的工程师、课程、供应商及搜索引擎&#xff0c;今天 TIOBE 官网公布了 2024 年 12 月的编程语言排行榜&#xff0c;IT之家整理如下&#xff1a; …

从零开始开发纯血鸿蒙应用之UI封装

从零开始开发纯血鸿蒙应用 一、题引二、UI 组成三、UI 封装原则四、实现 lib_comps1、封装 UI 样式1.1、attributeModifier 属性1.2、自定义AttributeModifier<T>类 2、封装 UI 组件 五、总结 一、题引 在开始正文前&#xff0c;为了大家能够从本篇博文中&#xff0c;汲…