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

推荐订阅源

GbyAI
GbyAI
博客园_首页
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
阮一峰的网络日志
阮一峰的网络日志
酷 壳 – CoolShell
酷 壳 – CoolShell
博客园 - 司徒正美
V
V2EX
Cloudbric
Cloudbric
Hugging Face - Blog
Hugging Face - Blog
腾讯CDC
量子位
博客园 - 三生石上(FineUI控件)
博客园 - 叶小钗
K
Kaspersky official blog
博客园 - 【当耐特】
T
Tenable Blog
L
Lohrmann on Cybersecurity
The Cloudflare Blog
S
Schneier on Security
A
Arctic Wolf
Latest news
Latest news
C
Cyber Attacks, Cyber Crime and Cyber Security
罗磊的独立博客
T
The Exploit Database - CXSecurity.com
Cisco Talos Blog
Cisco Talos Blog
小众软件
小众软件
P
Privacy & Cybersecurity Law Blog
WordPress大学
WordPress大学
Simon Willison's Weblog
Simon Willison's Weblog
雷峰网
雷峰网
NISL@THU
NISL@THU
人人都是产品经理
人人都是产品经理
月光博客
月光博客
J
Java Code Geeks
V
Visual Studio Blog
S
Security Affairs
博客园 - Franky
T
Tailwind CSS Blog
Apple Machine Learning Research
Apple Machine Learning Research
H
Heimdal Security Blog
有赞技术团队
有赞技术团队
V2EX - 技术
V2EX - 技术
AWS News Blog
AWS News Blog
G
GRAHAM CLULEY
T
Troy Hunt's Blog
SecWiki News
SecWiki News
Spread Privacy
Spread Privacy
宝玉的分享
宝玉的分享
www.infosecurity-magazine.com
www.infosecurity-magazine.com
博客园 - 聂微东

少数派

派早报: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 - 少数派
🫘Beancount × 群晖NAS——本地私有化财务系统部署指南 - 少数派
2025-03-02 · via 少数派

本文记录在群晖NAS上部署Beancount记账系统的完整流程。作为一款基于文本的开源复式记账工具,Beancount可以通过fava实现数据可视化,本部署指南通过以下技术方案解决实际问题:

  • 随处访问:利用Docker在群晖DSM系统中运行fava服务,通过浏览器实现跨平台访问
  • ​访问控制:通过群晖SSO(Synology Single Sign-On),为Web界面添加账户鉴权
  • ​数据安全:将Beancount账本文件存储在私有Git仓库并进行GPG加密
  • ​云端同步:将账本文件托管至Git私有仓库,配合cron定时任务实现「本地修改→加密提交→NAS服务定时拉取更新」的跨端数据流(确保各设备数据一致性)

适用读者

本文面向具备基础开发和运维能力的爱折腾型用户,适合以下场景:

  • 已使用Beancount但希望实现跨设备访问的个人用户
  • 寻求私有化部署财务系统的NAS使用者

部署前的环境准备

在开始部署前,请确保已完成以下基础设施配置。这些条件既是系统运行的底层依赖,也是保障数据安全与远程访问的关键前提。

群晖NAS基础环境

​系统要求:DSM 7.0及以上版本(测试机型:DS920+)
​必要套件:

  • Container Manager(套件中心安装)
  • SSO 服务器(套件中心安装,用于增加鉴权)
  • Web Station (用于增加别名访问)

域名与网络配置

​域名指向:已注册域名(示例:nas.domain.com)

​HTTPS证书:通过域名服务商可以申请免费或者其他有效的HTTPS证书

代码托管准备

​GitHub私有仓库:

拥有一个有Beancount账本数据并可以在本地正常运行的Github私有仓库(可以参考mckelvin大佬的beancount-boilerplate-cn仓库)

针对仓库中私人的敏感数据进行加密,推荐使用git-crypt

NAS内访问仓库的准备

生成Github私有仓库访问密钥:

访问Personal Access Tokens (Classic),点击右上角Generate new token

保存好你的私有仓库访问密钥,丢失后你需要重新生成将上面的token保存到文件./secrets/github_token.txt中(文件名可任取)

git-crypt解密密钥:

在仓库根目录执行下面的命令导出密钥,用于在Docker容器内部署时内对仓库代码进行解密。

git-crypt export-key ./secrets/git_crypt_key

群晖SSO配置(以DSM 7.2为例)

首先在群晖的套件中心安装SSO服务器,安装好后下面配置SSO服务。

SSO服务器 → 常规设置

账户类型:选择域/LDAP/本地

服务器URL:输入你的DSM地址,记得携带端口号 dsm.yourdomain.com:5000

SSO服务器 → 服务 → OIDC

开启OIDC服务,并记录Well-known URL

SSO服务器 → 应用程序 → 新增

选择SSO协议:OIDC

应用名称: My_Beancount

重定向URL: 填写你的SSO登陆回调地址,后续回调接口地址变更后需要再进入应用程序进行同步修改和添加。

获取OIDC配置参数

创建完成后会获得两个配置参数

  • 应用程序ID
  • 应用程序密钥

准备部署配置

通过Docker Compose实现服务编排,服务流程为用户请求 → Nginx → SSO → Fava服务

具体容器配置如下,省略了部分配置,详细配置可访问Github仓库

# docker-compose.yml
fava:
  container_name: fava_server
  environment:
    - TZ=Asia/Shanghai

sso_gateway:
  image: nginx:latest
  container_name: sso_gateway
  ports:
    - "8111:8111"  # 对外暴露端口
  volumes:
    - ./sso_nginx.conf:/etc/nginx/conf.d/default.conf
  depends_on:
    - sso_auth
    - fava

sso_auth:
  container_name: sso_auth
  depends_on:
    - fava

文件目录结构说明

具体编排代码已经开源,这里做一个简单的说明,详情还请进入仓库具体查看。

.
├── Dockerfile # fava 服务配置
├── README.md
├── cert # https的证书目录
│   ├── ssl.pem
│   └── ssl.key
├── docker-compose.yml # 服务编排配置
├── secrets
│   ├── git_crypt_key # git仓库解密
│   └── github_token.txt # 私有git仓库访问
├── sso_auth
│   ├── Dockerfile # sso鉴权服务配置
│   ├── app.py
│   └── requirements.txt
└── sso_nginx.conf # nginx配置

./Dockerfile 是fava的容器配置文件,你需要修改https://${GITHUB_TOKEN}@github.com/yourname/your_bucket.git 为你自己的github仓库地址。

sso_auth/Dockerfile 是SSO鉴权服务的配置,也需要你进行部分配置项的修改。

部署

  1. 将上面目录结构中的文件传到NAS File Station的任意位置
  2. 在群晖 Container Manager 中创建项目
  3. 打开 Container Manager ,点击项目新增
  4. 点击设置路径,选择步骤1中上传的目录
  5. 弹出的对话框中确定选择使用现有的 docker-compose.yml 来创建项目
  6. 输入项目名称后下一步,设置门户为fava,门户别名可以后续在web station中修改,若修改需要同步修改sso_nginx.conf./Dockerfile中的相关配置。
别名门户访问配置

例子🌰

假设你的群晖DSM地址为: https://nas.domain.com:5000

你的SSO服务器 URL 就应该配置为 https://nas.domain.com:5000

在你开启OIDC后 WELL_KNOWN_URL 可能是 "https://nas.domain.com:5000/webman/sso/.well-known/openid-configuration"

部署成功后fava的请求地址为:https://nas.domain.com:8111/fava

在SSO服务器应用程序中配置的重定向URL为 https://nas.domain.com:8111/fava/callback

SSO 登录界面

至此,你就可以在任意设备中安全的访问beanount的财务系统了,希望我的经验对你有所帮助。