k3s部署yapi启用ldap和导出文档为word插件

介绍

yapi是api 文档管理系统,基于nodejs和mongodb。集成ldap。
启用插件。本次启用的插件是把文档导出为word

编写entrypoint,sh

因为config.json这个配置,通过环境变量来配置比较方便,所以我们写一个entrypoint.sh文件,主要使用sed方法,用环境变量来替换json字段。具体如下,另外再加一个启动yapi的语句。
需要注意的是数字和布尔变量的sed语句和字符串sed语句有一点点不一样,需要多替换2个双引号。

#!/bin/sh
#update config file with env var
conf_file=/yapi/config.json
if [ $YAPI_SERVER_PORT ]; then
    sed -i "s#\"YAPI_SERVER_PORT\"#$YAPI_SERVER_PORT#" $conf_file
fi
if [ $YAPI_ADMINACCOUNT ]; then
    sed -i "s#YAPI_ADMINACCOUNT#$YAPI_ADMINACCOUNT#" $conf_file
fi
if [ $YAPI_TIMEOUT ]; then
    sed -i "s#\"YAPI_TIMEOUT\"#$YAPI_TIMEOUT#" $conf_file
fi
#mongodb
if [ $YAPI_DB_SERVERNAME ]; then
    sed -i "s#YAPI_DB_SERVERNAME#$YAPI_DB_SERVERNAME#" $conf_file
fi
if [ $YAPI_DB_DATABASE ]; then
    sed -i "s#YAPI_DB_DATABASE#$YAPI_DB_DATABASE#" $conf_file
fi
if [ $YAPI_DB_PORT ]; then
    sed -i "s#\"YAPI_DB_PORT\"#$YAPI_DB_PORT#" $conf_file
fi
if [ $YAPI_DB_USER ]; then
    sed -i "s#YAPI_DB_USER#$YAPI_DB_USER#" $conf_file
fi
if [ $YAPI_DB_PASS ]; then
    sed -i "s#YAPI_DB_PASS#$YAPI_DB_PASS#" $conf_file
fi
if [ $YAPI_DB_AUTHSOURCE ]; then
    sed -i "s#YAPI_DB_AUTHSOURCE#$YAPI_DB_AUTHSOURCE#" $conf_file
fi
................
................
#start yapi
node server/app.js

编写yapi的dockerfile

基础镜像是node:11.15
最后打包镜像是node:11.15-alpine
把entrypoint.sh从本人github下载下来,加入到镜像中。
把config.json也从本人github下载下来,放入镜像中。
还需要下载input.docx

FROM node:11.15 as builder
WORKDIR /yapi
RUN npm install -g node-gyp yapi-cli ykit
RUN wget https://github.com/YMFE/yapi/archive/refs/tags/v1.9.2.tar.gz
RUN tar -zxvf v1.9.2.tar.gz
RUN mv yapi-1.9.2 vendors
RUN wget https://raw.githubusercontent.com/xie-shujian/yapi/main/ldap_docx/config.json
RUN yapi plugin --name yapi-plugin-export-docx-data
WORKDIR /yapi/vendors
RUN npm install --production
RUN wget https://raw.githubusercontent.com/xie-shujian/yapi/main/ldap_docx/entrypoint.sh
RUN wget https://raw.githubusercontent.com/inceptiongt/Yapi-plugin-export-docx-data/master/input.docx

FROM node:11.15-alpine
LABEL maintainer="xiesj@live.com"
ENV TZ="Asia/Shanghai"
COPY --from=builder /yapi/vendors /yapi/vendors
COPY --from=builder /yapi/config.json /yapi/config.json
WORKDIR /yapi/vendors
RUN cat /yapi/config.json
EXPOSE 3000
ENTRYPOINT ["sh", "entrypoint.sh"]

这里使用了多重镜像,使用 copy --from 命令,第一个镜像作为builder镜像,把第一个镜像的builder结果,复制到第二个镜像里

制作成镜像

docker build -t xieshujian/yapi:1.9.2-ldap .

镜像大小大概是164m,还是很小的

k8s部署yaml文件

  • 创建secret
  • 创建部署
    编写环境变量,包含mongodb的连接信息
    编写探针
  • 创建service
    service端口是80,容器端口是3000
---

apiVersion: v1
kind: Secret
type: Opaque
metadata:
  name: yapi-secret
stringData:
  YAPI_DB_PASS: yapipassword

---

apiVersion: apps/v1
kind: Deployment
metadata:
  name: yapi
  labels:
    app: yapi
spec:
  replicas: 1
  selector:
    matchLabels:
      app: yapi
  template:
    metadata:
      labels:
        app: yapi
    spec:
      containers:
      - name: yapi
        image: xieshujian/yapi:1.9.2-ldap-docx
        env:
        - name: YAPI_SERVER_PORT
          value: "3000"
        - name: YAPI_ADMINACCOUNT
          value: admin@admin.com
        - name: YAPI_TIMEOUT
          value: "120000"
        - name: YAPI_DB_SERVERNAME
          value: mongodb
        - name: YAPI_DB_PORT
          value: "27017"
        - name: YAPI_DB_DATABASE
          value: yapidb
        - name: YAPI_DB_USER
          value: yapiuser
        - name: YAPI_DB_PASS
          valueFrom:
            secretKeyRef:
              name: yapi-secret
              key: YAPI_DB_PASS
        - name: YAPI_DB_AUTHSOURCE
          value: yapidb
        - name: YAPI_MAIL_ENABLE
          value: "false"
        - name: YAPI_MAIL_PORT
          value: "465"
        - name: YAPI_LDAP_ENABLE
          value: "true"
        - name: YAPI_LDAP_EMAILPOSTFIX
          value: "@163.com"
        imagePullPolicy: IfNotPresent
        ports:
        - containerPort: 3000
        livenessProbe:
          httpGet:
            path: /
            port: 3000
          initialDelaySeconds: 5
          periodSeconds: 5

---
apiVersion: v1
kind: Service
metadata:
  name: yapi
spec:
  selector:
    app: yapi
  ports:
    - protocol: TCP
      port: 80
      targetPort: 3000

config.json是修改过的

因为word插件会修改这个配置文件,所以这个json必须是合法的

{
  "port": "YAPI_SERVER_PORT",
  "adminAccount": "YAPI_ADMINACCOUNT",
  "timeout": "YAPI_TIMEOUT",
  "db": {
    "servername": "YAPI_DB_SERVERNAME",
    "DATABASE": "YAPI_DB_DATABASE",
    "port": "YAPI_DB_PORT",
    "user": "YAPI_DB_USER",
    "pass": "YAPI_DB_PASS",
    "authSource": "YAPI_DB_AUTHSOURCE"
  },
  "mail": {
    "enable": "YAPI_MAIL_ENABLE",
    "host": "YAPI_MAIL_HOST",
    "port": "YAPI_MAIL_PORT",
    "from": "YAPI_MAIL_FROM",
    "auth": {
      "user": "YAPI_MAIL_USER",
      "pass": "YAPI_MAIL_PASS"
    }
  },
  "ldapLogin": {
    "enable": "YAPI_LDAP_ENABLE",
    "server": "YAPI_LDAP_SERVER",
    "baseDn": "YAPI_LDAP_BASEDN",
    "bindPassword": "YAPI_LDAP_BINDPASSWORD",
    "searchDn": "YAPI_LDAP_SEARCHDN",
    "searchStandard": "YAPI_LDAP_SEARCHSTANDARD",
    "emailPostfix": "YAPI_LDAP_EMAILPOSTFIX",
    "emailKey": "YAPI_LDAP_EMAILKEY",
    "usernameKey": "YAPI_LDAP_USERNAMEKEY"
 }
}

我们会用mongodb,servername就是service name就叫mongodb

探针,这里使用http探针,5秒跑一次

建立service叫yapi

创建命名空间

kubectl create ns yapi

安装mongodb

把mongodb chart下载解压,找到values.yaml,打开,修改里面的rootPassword的值改为taihu123
另外把useStatefulSet设置成true,我们使用statefull
执行下面命令安装mongodb
helm repo add bitnami https://charts.bitnami.com/bitnami
helm install mongodb bitnami/mongodb -n yapi -f values.yaml
安装完毕之后进入容器,执行下面命令,新建普通账号,和数据库

mongo -u root -p taihu123
use yapidb
db.createUser({user: "yapiuser",pwd: "yapipassword",roles: [ { role: "dbOwner", db: "yapidb" } ]} )

安装yapi

kubectl apply -f yapi.yaml -n yapi
安装完毕之后,进入其中一个pod
执行下面命令
npm run install-server
初始化数据库
接下来就可以登录yapi了,账号是admin@admin.com,密码是ymfe.org

k3s界面

image.png
image.png
image.png

image.png

image.png

yapi界面

image.png

ldap界面

image.png

插件界面导出word文档

image.png

word文档

image.png
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,222评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,455评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,720评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,568评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,696评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,879评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,028评论 3 409
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,773评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,220评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,550评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,697评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,360评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,002评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,782评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,010评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,433评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,587评论 2 350

推荐阅读更多精彩内容