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

推荐订阅源

Project Zero
Project Zero
F
Fortinet All Blogs
Recent Announcements
Recent Announcements
云风的 BLOG
云风的 BLOG
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
M
MIT News - Artificial intelligence
S
SegmentFault 最新的问题
Blog — PlanetScale
Blog — PlanetScale
T
Tailwind CSS Blog
WordPress大学
WordPress大学
Engineering at Meta
Engineering at Meta
S
Schneier on Security
N
News and Events Feed by Topic
N
News | PayPal Newsroom
H
Help Net Security
C
CXSECURITY Database RSS Feed - CXSecurity.com
T
The Exploit Database - CXSecurity.com
Attack and Defense Labs
Attack and Defense Labs
博客园 - Franky
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
J
Java Code Geeks
A
About on SuperTechFans
AWS News Blog
AWS News Blog
S
Secure Thoughts
The Cloudflare Blog
Hugging Face - Blog
Hugging Face - Blog
爱范儿
爱范儿
C
Cybersecurity and Infrastructure Security Agency CISA
V2EX - 技术
V2EX - 技术
Recorded Future
Recorded Future
Microsoft Azure Blog
Microsoft Azure Blog
博客园_首页
MyScale Blog
MyScale Blog
Martin Fowler
Martin Fowler
Help Net Security
Help Net Security
人人都是产品经理
人人都是产品经理
Latest news
Latest news
C
Cyber Attacks, Cyber Crime and Cyber Security
大猫的无限游戏
大猫的无限游戏
The Last Watchdog
The Last Watchdog
www.infosecurity-magazine.com
www.infosecurity-magazine.com
月光博客
月光博客
H
Hacker News: Front Page
P
Proofpoint News Feed
N
News and Events Feed by Topic
H
Heimdal Security Blog
L
Lohrmann on Cybersecurity
有赞技术团队
有赞技术团队
L
LangChain Blog
Application and Cybersecurity Blog
Application and Cybersecurity Blog

少数派

派早报:Google 发布 Fitbit Air 等 - 少数派 「新人报到」確認需求,再開始 - 少数派 从 SOLO 独立开发者社区,我看到了越来越多开发者开始做自己的产品 - 少数派 我怎么管理那些"不常做,但总会忘"的生活事项 - 少数派 人形机器人量产元年,数据才是具身智能的“生死线” - 少数派 BuhoLaunchpad 高度还原 Mac 启动台:开发历程与思考 - 少数派 五年陪伴依然不舍,DIY 换壳后让罗技 MX Master 3 继续服役 - 少数派 新玩意 240|少数派的编辑们最近买了啥? - 少数派 一日一技|为什么你应该关闭 iOS 的键盘声音 - 少数派 我做了个插件和 Skills,一键提取任何网站的设计规范 Design.md - 少数派 住在三四线城市的你,该开始录播客了 - 少数派 甘南秘境,大白高国 - 少数派 AI的审美:谁让把我变成川内倫子 - 少数派 返工怎能不烦恼,打工人片单总有一部是你的「嘴替」 - 少数派 为了让「上厕所」更健康,我做了一个小工具 - 少数派 AI + Skill,能够让生成的文章去除 AI 味吗? - 少数派 新玩意|韶音OpenDots ONE 耳夹式耳机 - 少数派 《美满》| 在每一个春天的晚上相爱(362) - 少数派 新玩意|优篮子 PS01 MagSnap 磁吸支架 - 少数派 自我整合手记 | 我开始早睡了:用稳定规则,为自由托底 - 少数派 用龙虾(OpenClaw)两个多月,我最深的12个体会 - 少数派 听歌时间到,12 张你可能错过的 2025 华语乐坛好专辑 - 少数派 承诺能追吗 - 少数派 macOS 26启动台没了? 我做了个不一样的App启动器 - Keboard - 少数派 《四海为家的人》| INTJ对话INTJ(361) - 少数派 你发过的那些黑历史,是时候一次清干净了 - 少数派 新玩意:安安静静玩,越玩越专注:计客密码机 - 少数派 iPad 用户首次体验 Android 平板:vivo Pad6 Pro - 少数派 数据逻辑强 - 少数派 极北行+ | 一路向北,探访日本至北之地 | 001 - 少数派 万字剖析:千问App深度体验报告(2026) - 少数派 在2026年,如何真正防止别人抄袭你的作品 - 少数派 怎么用 50 块搭个 AI 语音助手?我踩了 3 天坑 - 少数派 YeeroAI:让 AI 对话真正成为知识管理的一部分 - 少数派 爬泰山 - 少数派 「旅图显影」 App 更新:这次,我们补上了一点「手感」 - 少数派 假期出门太折磨?我的 23 条经验帮你规划惬意旅行 - 少数派 工作流会变吗 - 少数派 Claude Opus 4.6 怎么用最省钱?我测了 5 种方案 - 少数派 GPT Image 2 让图文并茂不再稀罕 - 少数派 用户侧出发——什么是AI,我要不要学习? - 少数派 找片、转存、整理、播放一条龙!让你的付费网盘值回票价 - 少数派 欢迎试用!日课一问2.0插件 - 少数派 自己做的MDeditor,原本想购买 Typora 试了两次支付不成功,干脆自己做一个 - 少数派 vibe coding了一个 3MB 的小工具,让 ~/Downloads 彻底告别混乱 - 少数派 因为受不了 Mac 的风扇策略,我做了一个风扇控制工具 - 少数派 别只怪模型 - 少数派 Warp 终端的 AI 功能怎么用?我测了一周的体验 - 少数派 AI 写代码老是出 bug?这 5 个配置我后悔没早知道 - 少数派 「新玩意」苹果出相机可能就这样:Sigma BF + 45mm F2.8 DG Contemporary - 少数派 一个面向2030年的AI操作系统是什么样子的:浅谈cola这款有灵魂的Agent - 少数派 别只看写代码 - 少数派 每天解决10个问题,还是一口气攻坚解决400个? - 少数派 AI 交易机器人怎么搭?我用 Claude 跑了一周实盘 - 少数派 Maptoposter Online:把你爱的城市画成艺术海报 - 少数派 Function Calling 怎么用?我测了 3 个模型发现差距真大 - 少数派 Legend Talk:我做了个 AI 圆桌,让 160 位思想家围着你的问题转 - 少数派 如何找到自己的蓝方?在小县城寻找压力测试 - 少数派 语音输入与软件接口|2026年聊AI时,我们都聊些什么(上) - 少数派 混动已经卖爆,纯电又来补刀——钛7闪充版简直“不讲武德” - 少数派 本月玩什么|朋友收藏、识质存在、沙罗周期 - 少数派 为什么要每天坚持输出? - 少数派 Claude API 挂了好几个小时,你的项目有备用方案吗? - 少数派 Function Calling 没你想的复杂——我用它做了个有点用的工具 - 少数派 登录系统立即播放视频或者图片音乐的软件 - 少数派 我为什么创建 FlipHTML5 下载工具 - 少数派 残局没电?多品牌外设电量统一管理软件EasyBluetooth已支持RTSS游戏内显示以及AIDA64 - 少数派 前往通义路的路 - 少数派 太好看了,媲美Sun的个人导航页,NAS部署星云门户 - 少数派 乌黑嘴唇“一键检测”上线了 - 少数派 派早报:Claude AI 接入多个创意软件生态、FILCO 生产方接手品牌等 - 少数派 【更新】BearCLI、Claude 连接器与 MCP 服务器 - 少数派 记了上千条流水,还是看不懂财务?我做了一个让 AI 读懂账本的工作台 - 少数派 MINI R56 升级原厂 Sport 模式 - 少数派 新玩意 | 一棵柠檬树(仿真版) - 少数派 Momenta的“物理AI”野望,需迈过“含摩量”这道关 - 少数派 网页直接投屏控制手机!NAS一键部署PandaScrcpy,流畅丝滑可远程。 - 少数派 众测|邀你一同探索随身 AI 硬件入口 YoooClaw C·ONE - 少数派 2050大会:分享时间是真诚 参会记 - 少数派 iPad 赋能电影创作:国内首部宣纸手绘长片《燃比娃》的幕后故事 - 少数派 AI的审美:我用 8 个大模型给 100 张旅行照片打分 - 少数派 普通人如何破圈?去参加一个本地协会 - 少数派 把极空间的图标全换了,主题DIY全攻略打造你的专属NAS桌面 - 少数派 电子便签墙,帮你实现便签自由 - 少数派 我如何用三个 CLI 工具取代文档创建需求 - 少数派 原来真的有人可以玩一辈子 - 少数派 社区速递 139 | 派友热议三月买了啥、复古单反尼康 Df 体验 - 少数派 06 作品的赏析与评价 - 少数派 TDS REVIEW|索尼 WF-1000XM6 降噪真无线耳机体验 - 少数派 35.98万起售的第二代腾势D9,我看重的不是堆料,而是不凑合 - 少数派 鼠须管 Squirrel 皮肤配置指北 - 少数派 从watch ultra2换到redmi watch6 - 少数派 派早报:阿里巴巴发布视频生成模型 HappyHorse 1.0 等 - 少数派 别迷信1M - 少数派 家人们天塌了!网盘“大封杀”,多个渠道多条路,NAS部署PanHub - 少数派 AI与人勾心斗角!NAS一键部署AI狼人杀,假日休闲必备。 - 少数派 电商必备!Comfyui工作流批量生图插件,一次生成12张!支持Nano banana pro模型 - 少数派 Comfyui工作流配置Gpt-image-2模型教程,0.03/张 - 少数派 OpenClaw第三方APi怎么配置?可使用Gpt-image-2模型 - 少数派 会员社区话题精选 Ep. 103 - 少数派
月寒日暖,来煎人寿 - 少数派
2024-11-30 · via 少数派

外面天黑了,而我正坐在电脑前发呆,努力尝试想起来某个文件的路径到底是什么。

脑袋开始混沌走神——我是怎么走到这一步的?我本来是要做什么来着?

想起来了。最初的问题,是 iCloud 空间不大够用来着。

……但是怎么变成现在这样了呢?

大概是“吾不识青天高,黄地厚;唯见月寒日暖,来煎人寿”吧。

从给 Github 库瘦身开始

iCloud 空间不大够用,我打算把不常用的文件挪到 NAS 上去。整理文件时,发现有两个文件夹异常巨大:一个是用来存放和生成 Blog 的文件夹,另一个是存放课程幻灯片的。

Blog 是用 Hugo 生成的静态网站,幻灯片是基于 impress.js 设计的一组网页和资源。这两个文件夹都有自己的 Github 仓库,而且幻灯片文件夹还作为子模块引入了 Blog 仓库。我使用 Github Pages 托管 Blog,把我的域名 yemengma.cn 指向了这个仓库,所以可以通过域名访问 Blog 和幻灯片。

因为是和 Github 同步,所以这两个文件夹下都有用来记录历史的 .git 文件夹;而因为幻灯片作为子模块引入了 Blog 仓库,所以幻灯片的历史也被完整保存在 Blog 仓库中。

这样一来,幻灯片文件夹本身的文件大概有 1G 左右,加上 .git 就有了 2G;而 Blog 仓库里存了一份幻灯片文件夹,还有相应的两份 .git 文件夹,平白多占用了 3G 空间。

本来这也不是什么大问题,几个 G 的空间也不算多……但是问题是我的 iCloud 只有 50G。让重复没用的文件占了 6%,这还能忍?

于是改吧。

所以总结一下, 情况大概是这样:

hugo-site/
  ├── content/
  ├── public/
  │   └── slides/  #  幻灯片文件夹作为子模块引用
  └── themes/

这种结构带来了几个问题:

  • 幻灯片仓库被完整引入 Blog 仓库;
  • 更新时需要同步子模块;
  • 主仓库和子模块各自的 .git 文件夹都保存了完整历史;

所以解决方案也就很清晰了:

  1. 将幻灯片从 Blog 中完全分离;
  2. 重命名幻灯片仓库的主分支为 gh-pages,用 Github Pages 发布;
  3. 删除远程主分支,重新设置分支追踪;
  4. 设置域名解析,指向新的幻灯片地址;

第一步好办,删几个文件夹而已;第二步第三步也无非几个命令。

cd /path/to/slides
git branch -m main gh-pages
git push origin gh-pages
git push origin --delete main
git branch -u origin/gh-pages

删文件令人心情舒畅。修改完的结构如下:

/path/
  ├── hugo-site/    # Blog 内容
  └── slides/       # 独立的幻灯片内容

第四步要去阿里云上设置域名解析。打开了多年没有登录的阿里云,找到域名解析,添加一条新的 CNAME 记录,把 slides.yemengma.cn 指向 mammoth2008.github.io……

然后想起来,我的这个域名一直没备案。

那就顺手备一个吧。

备案需要服务器

网站备案需要域名和服务器,而我没有服务器——Github 非常良心地提供了免费服务。

所以租了低配的阿里云服务器,有 2 核 CPU、2G 内存、3M 带宽,运行 Ubuntu 20.4,第一年租金不到 100 块。看见域名很便宜,也顺手买了个新域名 lifeplayer.club(目前备案没完成,无法访问),把 lifeplayer.club、www.lifeplayer.club、slides.lifeplayer.club 都解析到这个服务器的 IP 地址。

浪费计算资源是要遭天谴的。于是把 Blog 和幻灯片都同步到服务器上,用 Nginx 配置两个站点,这样在国内访问的速度就会快很多——毕竟 Github 在国内的访问速度比较随机。

先安装 Hugo 和 Nginx。

sudo apt Update
sudo apt install hugo
sudo apt install nginx

然后把文件复制到云服务器上:

rsync -avz /local/hugo-site/ root@IPAddress:/home/admin/hugo-site/
rsync -avz /local/slides/ root@IPAddress:/home/admin/slides/

再写个 Nginx 配置文件:

# Blog 主站配置
server {
    listen 80;
    server_name lifeplayer.club www.lifeplayer.club IPAdress;
    root /home/admin/hugo-site/public;
    index index.html;
    error_page 404 /404.html;
    location / {
        try_files $uri $uri/ =404;
    }
    location /slides {
        alias /home/admin/slides;
        try_files $uri $uri/ =404;
    }
}

# slides 子域名配置
server {
    listen 80;
    server_name slides.lifeplayer.club;
    root /home/admin/slides;
    index index.html;
    error_page 404 /404.html;
    location / {
        try_files $uri $uri/ =404;
    }
}

应用配置,重启 nginx 就行了。

sudo ln -s /etc/nginx/sites-available/hugo /etc/nginx/sites-enabled/
sudo systemctl enable nginx
sudo nginx -t
sudo systemctl restart nginx

人总是能懒则懒的

所以总结一下,现在我修改完文件后,除了要提交到 Github 上之外,还要同步到云服务器上。

嗯……所以更新一下部署脚本吧。

以前我有一个部署脚本,用来在更新文件后提交到 Github 上。现在既然要改,不妨改大一点。除了更新 Github 和云服务器上的内容外,还要考虑特殊文件的处理,以及 Blog 在服务器上的重新生成。要尽量模块化,参数化,安全性也要增强一些。

改进后的部分脚本如下:

#!/bin/bash
check_git_status() {
    if [ -n "$(git status --porcelain)" ]; then
        info "检测到未提交的更改"
        git add .
        git commit -m "Update: $(date '+%Y-%m-%d %H:%M:%S')"
    fi
    local_commit=$(git rev-parse HEAD)
    remote_commit=$(git rev-parse @{u})

    if [ "$local_commit" != "$remote_commit" ]; then
        info "推送本地更改到远程仓库"
        git push || error_exit "推送失败"
    fi
}

sync_to_server() {
    info "开始同步到服务器"
    rsync -avz --exclude '.git*' \
        --exclude 'config.toml' \
        --exclude 'public/' \
        --exclude 'layouts/partials/language-selector.html' \
        ./ root@IPAddress:/home/admin/hugo-site/ || error_exit "同步失败"

    success "同步完成"
}

main() {
    check_git_status
    sync_to_server

    if [[ "$0" == *"deploy-blog"* ]]; then
        ssh root@IPAddress "cd /home/admin/hugo-site && hugo"
    fi
}
main
脚本运行截图

重启能解决 90% 问题

这次的“小问题”最终演变成了网站架构调整。现在的方案有几个明显改进:

存储更合理了。因为删除了重复的文件和历史记录,为 Blog 和幻灯片分别建立了独立的仓库,所以 iCloud 空间节省了约 5G。仓库结构更清晰,便于维护。

访问更便捷了。国内用户通过阿里云服务器快速访问,解决了相当大的问题。另外,依然保留 GitHub Pages 作为备用入口,也通过子域名让资源组织更清晰。

部署更高效了。使用自动化脚本处理了大部分重复工作,也有了更完善的错误处理。省去了许多重复操作。

还有点意外收获。重新捡起来了一点 Ubuntu 操作系统的用法——本来都已经忘差不多了。重新考虑网站架构,未来的扩展也很容易。

Edsger W. Dijkstra(那个著名图算法的发明者)说:“简单性是可靠性的先决条件。”

所以现在我的网站结构更简单了,访问更快捷了,维护更容易了,感觉天都更蓝了!


未标明出处的配图由 FLUX-dev 生成。