Docker搭建Yapi及迁移

2024-01-22 04:38
文章标签 docker 搭建 迁移 yapi

本文主要是介绍Docker搭建Yapi及迁移,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Docker搭建Yapi及迁移
安装mongo
docker run -p 27017:27017 -d -v /data/mongo/data:/data/db -v /data/mongo/conf:/data/configdb --name mongoserver mongo --auth
1
安装yapi
注意: yapi不要开放外网,存在恶意mock漏洞,解决办法:Yapi的mock漏洞

我采用的是dockfile,搭建yapi服务,

准备工作
Dockerfile内容:

FROM alpine:latest
LABEL MAINTAINER = ‘Levon’
RUN mkdir -p /yapi/vendors/
COPY vendors/ /yapi/vendors/

RUN echo “https://mirrors.aliyun.com/alpine/latest-stable/main/” > /etc/apk/repositories \

RUN sed -i ‘s/dl-cdn.alpinelinux.org/mirrors.ustc.edu.cn/g’ /etc/apk/repositories
&& apk update
&& apk add nodejs=14.17.6-r0
&& apk add npm=7.17.0-r0
&& apk add --no-cache git bash curl tar vim python3 python3-dev gcc libcurl make
&& rm -rf /var/cache/apk/*
RUN npm config set registry https://registry.npm.taobao.org
&& npm i -g node-gyp
&& npm install -g yapi-cli
RUN cd /yapi/vendors
&& npm install --production --registry https://registry.npm.taobao.org
WORKDIR /yapi/vendors
COPY config.json /yapi/
COPY entrypoint.sh /usr/local/bin/
RUN chmod 755 /usr/local/bin/entrypoint.sh
COPY .vimrc /root/
EXPOSE 3000
ENTRYPOINT [“entrypoint.sh”]

entrypoint.sh内容:

#!/bin/bash

yapi初始化后会有一个init.lock文件

lockPath="/yapi/init.lock"

进入yapi项目

cd /yapi/vendors

如果初始化文件文件存在,则直接运行,否则初始化

if [ ! -f “$lockPath” ]
then

启动Yapi初始化

node server/install.js

若是初始化成功的情况下直接运行yapi

node server/app.js
else

运行yapi管理系统

node server/app.js
fi

config.json内容

{
“port”: “端口”,
“adminAccount”: “用户名”,
“timeout”:120000,
“mock”: false,
“db”: {
“servername”: “mongoserver”,
“DATABASE”: “yapi”,
“user”: “mongo账号”,
“pass”: “mongo密码”,
“port”: 27017,
“authSource”: “”
},
“mail”: {
“enable”: false,
“host”: “smtp.163.com”,
“port”: 465,
“from”: “*@163.com",
“auth”: {
“user”: "@163.com",
“pass”: "

}
}
}

vendors文件中Yapi版本:6925c98da73,master最新版本中package-lock.json存在一些问题,无法访问的去哪儿的镜像地址

构建
docker build -f dockerfile -t yapi:v1 .

启动yapi镜像
docker run -d --name yapi -p 3000:3000 yapi:v1

迁移
备份
备份数据到 /data 路径下(路径下有一个yapi的文件)
docker exec 容器名 mongodump -d yapi -o /data/

进入到容器中打包备份文件
docker exec -it 容器名 /bin/bash
cd /data
tar -zcvf yapi.tar /data/yapi

将备份文件移动到宿主机
docker cp 容器名:/data/yapi.tar /data/backup

恢复
进入到新服务器,将备份文件copy到新服务的data/backup中
复制宿主机的备份文件到docker的mongo中
docker cp /data/backup/yapi.tar 容器名:/data/

进入到容器中解压文件
docker exec -it 容器名 /bin/bash
cd /data
tar -zxvf yapi.tar

还原数据
docker exec 容器名 mongorestore -d yapi --drop --dir /data/yapi

这篇关于Docker搭建Yapi及迁移的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

搭建Kafka+zookeeper集群调度

前言 硬件环境 172.18.0.5        kafkazk1        Kafka+zookeeper                Kafka Broker集群 172.18.0.6        kafkazk2        Kafka+zookeeper                Kafka Broker集群 172.18.0.7        kafkazk3

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

pico2 开发环境搭建-基于ubuntu

pico2 开发环境搭建-基于ubuntu 安装编译工具链下载sdk 和example编译example 安装编译工具链 sudo apt install cmake gcc-arm-none-eabi libnewlib-arm-none-eabi libstdc++-arm-none-eabi-newlib 注意cmake的版本,需要在3.17 以上 下载sdk 和ex

禅道Docker安装包发布

禅道Docker安装包发布 大家好, 禅道Docker安装包发布。 一、下载地址 禅道开源版:   /dl/zentao/docker/docker_zentao.zip  备用下载地址:https://download.csdn.net/download/u013490585/16271485 数据库用户名: root,默认密码: 123456。运行时,可以设置 MYSQL_ROOT_P

CentOs7上Mysql快速迁移脚本

因公司业务需要,对原来在/usr/local/mysql/data目录下的数据迁移到/data/local/mysql/mysqlData。 原因是系统盘太小,只有20G,几下就快满了。 参考过几篇文章,基于大神们的思路,我封装成了.sh脚本。 步骤如下: 1) 先修改好/etc/my.cnf,        ##[mysqld]       ##datadir=/data/loc

CentOS下mysql数据库data目录迁移

https://my.oschina.net/u/873762/blog/180388        公司新上线一个资讯网站,独立主机,raid5,lamp架构。由于资讯网是面向小行业,初步估计一两年内访问量压力不大,故,在做服务器系统搭建的时候,只是简单分出一个独立的data区作为数据库和网站程序的专区,其他按照linux的默认分区。apache,mysql,php均使用yum安装(也尝试

Linux Centos 迁移Mysql 数据位置

转自:http://www.tuicool.com/articles/zmqIn2 由于业务量增加导致安装在系统盘(20G)磁盘空间被占满了, 现在进行数据库的迁移. Mysql 是通过 yum 安装的. Centos6.5Mysql5.1 yum 安装的 mysql 服务 查看 mysql 的安装路径 执行查询 SQL show variables like

828华为云征文|华为云Flexus X实例docker部署rancher并构建k8s集群

828华为云征文|华为云Flexus X实例docker部署rancher并构建k8s集群 华为云最近正在举办828 B2B企业节,Flexus X实例的促销力度非常大,特别适合那些对算力性能有高要求的小伙伴。如果你有自建MySQL、Redis、Nginx等服务的需求,一定不要错过这个机会。赶紧去看看吧! 什么是华为云Flexus X实例 华为云Flexus X实例云服务是新一代开箱即用、体

docker-compose安装和简单使用

本文介绍docker-compose的安装和使用 新版docker已经默认安装了docker-compose 可以使用docker-compose -v 查看docker-compose版本 如果没有的话可以使用以下命令直接安装 sudo curl -L https://github.com/docker/compose/releases/download/1.16.1/docker-c