惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

P
Proofpoint News Feed
Microsoft Azure Blog
Microsoft Azure Blog
Jina AI
Jina AI
博客园_首页
宝玉的分享
宝玉的分享
The Cloudflare Blog
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
量子位
T
Tailwind CSS Blog
雷峰网
雷峰网
Blog — PlanetScale
Blog — PlanetScale
Last Week in AI
Last Week in AI
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Hugging Face - Blog
Hugging Face - Blog
月光博客
月光博客
罗磊的独立博客
F
Fortinet All Blogs
酷 壳 – CoolShell
酷 壳 – CoolShell
Stack Overflow Blog
Stack Overflow Blog
J
Java Code Geeks
V
V2EX
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
The GitHub Blog
The GitHub Blog
Apple Machine Learning Research
Apple Machine Learning Research
博客园 - 聂微东
U
Unit 42
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
D
Docker
阮一峰的网络日志
阮一峰的网络日志
I
InfoQ
Simon Willison's Weblog
Simon Willison's Weblog
D
DataBreaches.Net
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
I
Intezer
Scott Helme
Scott Helme
B
Blog
M
MIT News - Artificial intelligence
K
Kaspersky official blog
H
Help Net Security
V
Vulnerabilities – Threatpost
C
CXSECURITY Database RSS Feed - CXSecurity.com
Engineering at Meta
Engineering at Meta
博客园 - 【当耐特】
L
Lohrmann on Cybersecurity
P
Privacy & Cybersecurity Law Blog
Project Zero
Project Zero
The Hacker News
The Hacker News
B
Blog RSS Feed
T
Tor Project blog

博客园 - 码甲哥不卷

哈哈哈哈哈打不过我吧,没有办法我(vllm)就是这么强大! GLM模型这么火,咱们用vllm也咧一个呗! 同样都是九年义务教育,他知道的AI算力科普好像比我多耶 higress 这个中登才是AI时代的心头好 MetalLB才是给Ingress这个老登做负重前行的那个男人 超性感的轻量级openclaw平替,我给nanobot打call 我不允许谁还不清楚function call在AI-Agent领域中打手的地位 还有比ollama更傻瓜式的大模型本地部署方式吗 ? 🔎我不允许谁还分不清这三种watch机制的区别 云原生AI算力平台的架构解读 🚀糟糕,我实现的k8s informer好像是依托答辩 🎉在k8s调度的花园里面挖呀挖 🎉卷不过AI算法, AI工程化或许是一个出路 我是新来的,我需要知道这些吗?网关上的限流器 新来的外包,在大群分享了它的限流算法的实现 新来的外包,限流算法用的这么6 面试总被追问k8s调度器工作原理, 收藏 == 学废 kong网关反向代理grpc请求 幂等的双倍快乐,你值得拥有 JWT 这点小秘密,你们肯定知道! Go动态感知资源变更的技术实践,你指定用过!
3min手搓一个帮助文档,很合理吧!
神仙别打架 · 2026-06-20 · via 博客园 - 码甲哥不卷

最近在加班加点的做一个Token工厂, 模式类似与京东:有自营算力产生的模型,也外接第三方旗舰模型。

作为Token聚合分发平台,帮助文档是刚性需求。

Docsify是一个将Markdown文件转换为单页面静态网站(无需任何构建过程)的开源项目,实测下来3min就能构建并搭建一个 帮助文档站点。


1. 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访问;

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

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

3. Docsify固若金汤

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

sudo vim 

[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 路径到帮助文档站

思路也很清晰:

  • 主站走/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

但实际上会有问题,帮助文档站虽然是单页面, 但是会有许多资源请求。

上面的ingress规则,会让/docs路径命中帮助文档站首页, 但是页面上其他资源不感知docs, 发起的请求不会带上docs,那么就会走向下面的主站路由, 这就不是预期的显示。

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

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