当前位置: 首页 > news >正文

3min手搓一个帮助文档,很合理吧!

Docsify小试牛刀

前置安装环境:npm i docsify-cli -g安装docsify cli客户端;

初始化项目目录:docsify init .,这会在当前目录下创建工作目录,默认有:

  • index.html : 整站是一个单页面静态页面
  • README.md: 默认的主页
  • .nojekyll: 防止GitHub Pages忽略以下划线开头的文件

接下来docsify serve ./就启动并在localhost:3000部署了这个帮助文档站点,文档内容来自README.md文件, 默认绿色主题深得我心。

2. Docsify羽翼丰满

现在可以写更多的markdown文件:
eg: guide.md, 在单页面/#/guide访问; 子文件夹 ./docs/class1.md, 在单页面/docs#/class1访问

一个更常见的组织方式是 侧边栏:

  • 编写_sidebar.md文件, 指定md文件的组织和路由
* [快速指南](/ "快速指南")
* [文生图](text2image.md "文生图")
* [文生视频](text2video.md "文生视频")
* [虚拟人素材](assert.md "虚拟人素材")
* [WorkBuddy接入文档](WorkBuddy.md "WorkBuddy接入文档")
  • 在index.html加载_sidebar.md文件, 注意下面的loadSideBarbool值
<script>
window.$docsify = {
name: '',
repo: '',
loadSidebar: true,
subMaxLevel: 2
}
</script>

3. Docsify固若金汤

一般会使用systemd服务进程来部署Docsify,具备进程管理和重试能力。

sudo vim /etc/systemd/system/docsify.service

[Unit]
Description=docsify Service
After=network.target
[Service]
Type=simple
User=你的用户名
WorkingDirectory={help-docs的工作目录}
ExecStart=/usr/local/bin/docsify serve ./
Restart=always
RestartSec=10
[Install]
WantedBy=multi-user.target

sudo systemctl daemon-reload
sudo systemctl enable docsify # 设置开机自启
sudo systemctl start docsify

4. Docsify宿主服务接入k8s集群

Token工厂项目是k8s部署,已经配上了带ssl证书的域名,本次希望将这个Docsify宿主机服务快速接入k8s集群, 走主站的/docs 路径到帮助文档站,同时利用k8s集群上配置好的证书,走正规军路线。

k8s如何接入宿主机服务?

将这个宿主机服务,抽象为k8s服务,但是需要走自定义endpoint模式。

apiVersion: v1
kind: Service
metadata:
name: external-docs-svc # 服务名,可自定义
namespace: tokenhub
spec:
ports:
- port: 3000
targetPort: 3000
---
apiVersion: v1
kind: Endpoints
metadata:
name: external-docs-svc # 必须与 Service 同名
namespace: tokenhub
subsets:
- addresses:
- ip: 10.8.65.1 # 外部进程的 IP
ports:
- port: 3000

配置ingress规则:主站走/docs 路径到帮助文档站

ingress path 路径匹配,默认不rewrite path,为了让帮助文档站所有请求都进入特定的服务。

思路也很清晰:

  • 主站域名 +/docs路径请求到帮助文档站;后端服务需要关注/docs前缀
  • 主站域名+ /`请求 到主站服务;
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: tokenhub-ingress
namespace: tokenhub
annotations:
nginx.ingress.kubernetes.io/ssl-redirect: "true"
nginx.ingress.kubernetes.io/hsts: "true"
nginx.ingress.kubernetes.io/hsts-max-age: "31536000"
# 如果后端期望不带 /docs 前缀,可取消下面注释
# nginx.ingress.kubernetes.io/rewrite-target: /$2
spec:
ingressClassName: nginx
tls:
- hosts:
- tokengine.hanyoai.com
secretName: tokenhub-tls
rules:
- host: tokengine.hanyoai.com
http:
paths:
- path: /docs
pathType: Prefix
backend:
service:
name: external-docs-svc # 指向上一步创建的 Service
port:
number: 3000
- path: /
pathType: Prefix
backend:
service:
name: new-api
port:
number: 3000

同时我们必须让帮助文档站发出的请求都 带上/docs前缀,那么需要将上面docsify 工作目录下所有的md文件移动到一个docs目录下(index.html 位置不变)。

这样主站/docs路径命中docsify 首页, 首页附带的其他资源因为在docs目录下,发起请求时自然也有/docs前缀,于是由自然而然根据ingress /docs前缀进入后端服务, 完美闭环。

http://www.jsqmd.com/news/1091686/

相关文章:

  • Simcenter STAR-CCM+安装步骤(附安装包)STAR-CCM+ 超详细下载安装教程
  • libuvc实战:跨平台USB摄像头控制与多设备区分
  • 如何深度掌控AMD Ryzen处理器:SMU Debug Tool完整指南
  • 人工智能大模型兵棋推演系统软件平台:有哪些优点和缺点
  • 先说个常见的情况
  • BurpSuite 2023+ 上游代理配置实战:告别UserOptions,拥抱Settings新路径
  • NFS服务安全加固:从CVE-1999-0554漏洞看showmount信息泄露的深度防御
  • 射频工程师实战指南:S参数、OP1dB、IMD与NF的测量要点与校准技巧
  • 如何在 Python 项目中避免循环引用
  • 关于防范利用非主流二级域名进行钓鱼攻击的风险提示
  • SetDPI深度解析:Windows DPI缩放管理的命令行艺术
  • FPGA I/O Bank选型指南:HP、HR、HD三大Bank特性与应用场景全解析
  • 【Claude】Claude Code 企业/团队环境完整配置指南
  • 如何用Revelation光影包打造电影级Minecraft体验:完整安装与配置指南
  • 告别手动对齐:用MathType在Word中高效管理公式编号与引用
  • Python自动化AutoCAD:从重复劳动到智能设计的革命性跨越
  • Nmap从入门到精通:主机发现、端口扫描与安全审计实战指南
  • GHelper完整攻略:华硕ROG笔记本性能控制终极指南
  • ChatGPT Plus额度限制真相:不是按月固定,而是基于RLHF反馈权重的动态滑动窗口(附Python额度预测模型代码)
  • 深入解析MSPM0 DEBUGSS调试子系统:从架构原理到安全功耗实战
  • eNSP模拟器环境搭建:从VirtualBox到Wireshark的完整依赖链部署指南
  • TypeScript的keyof typeof组合:从对象推导出键名联合类型
  • 你熟悉多线程,请举例说明你在项目中如何正确使用线程池,以及遇到过哪些线程安全问题?
  • Spring Boot 虚拟线程实战:ThreadLocal 串数据、连接池打爆、synchronized 钉住线程,三个坑及解决方案
  • 终极指南:3大核心功能让原神日常任务效率翻倍
  • Win11Debloat:让Windows 11重获新生的终极优化工具
  • /loop 实现,看 Loop Engineering 如何从概念走向工程实践
  • 如何用League Akari实现英雄联盟客户端全能优化:终极指南
  • WordPress渗透测试实战:从漏洞利用到后渗透的完整攻防解析
  • 2026企业AI智能体落地深度观察:揭秘实在Agent高复购与扩容率背后的技术逻辑