词元计数器构造简介

又咕咕了一段时间 😅 但是这段时间词元也没闲着,除了上次写的迁移,还小修小补,给博客做了不少加载速度、界面、功能上的提升。目前这个版本词元是比较满意的,因此水一则博客介绍一下。 🏗️ 分离构建 虽然 Cloudflare 静态资源托管,流量是无限的,但是每个月有 3,000 分钟的构建时长限制。虽然这也是用不完的1,但是——白嫖怪怎么能接受限制呢? 如果您按照词元的教程,搭建了含有 index.js 的动态 Workers,那么很可惜,词元已经反悔了;这样实在是太浪费 Workers 请求了,都不用 DDoS,写个小脚本请求一天就能干下线 🙃 不过 Workers 也可以纯静态,不消耗 Workers 调用次数,只要删除所有 JS 脚本,从 wrangler.toml 里删掉除了定义静态资源之外的所有配置,就可以转换为静态 Workers 了。例如: 1 2 3 4 5 6 name = "tokeniland" compatibility_date = "2025-05-05" [assets] directory = "./public" not_found_handling = "404-page" 其中 public 是我们构建生成的目录。 话说回来,GitHub Actions 为公开仓库提供了无限时长的构建,结合无限流量的静态 Workers,就能实现全程白嫖。按照 Cloudflare 给出的文档,我们写一个 .github/workflows/build.yaml: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 name: 🌥️ Deploy Tokeniland to Cloudflare Workers on: push: branches: - master workflow_dispatch: jobs: build-and-deploy: runs-on: ubuntu-latest timeout-minutes: 15 steps: - uses: actions/checkout@v4 - name: 🚧 Build the site with Barrel Build run: bash script/build.sh - name: 🚀 Deploy to Cloudflare Workers uses: cloudflare/wrangler-action@v3 with: apiToken: ${{ secrets.CLOUDFLARE_WORKERS_API_TOKEN }} accountId: ${{ secrets.CLOUDFLARE_ACCOUNT_ID }} 很简单吧!先这样(用 Hugo 生成,使用的 script/build.sh 待会儿会说),再那样(用 Wrangler 上传到 Workers),就可以用了。别忘了在 GitHub 仓库里添加 API 密钥和账户 token2。 ...

May 25, 2025 · 2 min · 372 words · 词元