
@TOC
ExpenseOwl是一款极简、可自托管的个人财务记账工具,专为家庭实验室部署设计,拥有美观的用户界面,支持离线运行,保障数据隐私。
本次实践为个人测试环境,操作系统版本为Ubuntu 22.04.1。
hostname | IP地址 | 操作系统版本 | Docker版本 | 部署项目 |
|---|---|---|---|---|
jeven01 | 192.168.3.88 | Ubuntu 22.04.1 LTS | 27.1.1 | ExpenseOwl |
1.本次实践部署环境为个人测试环境,生产环境请谨慎;
2.在Docker环境下部署ExpenseOwl自托管费用跟踪系统。
检查Docker服务是否正常运行,确保Docker正常运行。
root@jeven01:~# systemctl status docker
● docker.service - Docker Application Container Engine
Loaded: loaded (/lib/systemd/system/docker.service; enabled; vendor preset: enabled)
Active: active (running) since Fri 2025-07-18 07:25:10 UTC; 3 days ago
TriggeredBy: ● docker.socket
Docs: https://docs.docker.com
Main PID: 810 (dockerd)
Tasks: 104
Memory: 191.8M
CPU: 5min 40.472s
CGroup: /system.slice/docker.service
├─ 810 /usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock检查Docker版本
root@jeven01:~# docker -v
Docker version 27.1.1, build 6312585检查Docker compose版本,确保2.0以上版本。
root@jeven01:~# docker compose version
Docker Compose version v2.19.1拉取ExpenseOwl容器镜像,如下所示:
docker pull tanq16/expenseowl:v4.0
mkdir -p /data/expenseowl && cd /data/expenseowl使用docker-cli方式部署,命令参考如下:
docker run -d \
--restart always \
--name expenseowl \
-p 9200:8080 \
-v /data/expenseowl/data:/app/data \
tanq16/expenseowl:v4.0在部署目录下,创建docker-compose.yaml文件,内容如下所示:
vim docker-compose.yamlversion: '3.9'
services:
expenseowl:
image: 'tanq16/expenseowl:v4.0'
volumes:
- '/data/expenseowl/data:/app/data'
ports:
- '9200:8080'
container_name: expenseowl
restart: always执行以下命令,创建ExpenseOwl容器。
docker compose up -d
检查ExpenseOwl容器运行状态,确保ExpenseOwl容器正常启动。
root@jeven01:/data/expenseowl# docker compose ps
WARN[0000] /data/expenseowl/docker-compose.yaml: the attribute `version` is obsolete, it will be ignored, please remove it to avoid potential confusion
NAME IMAGE COMMAND SERVICE CREATED STATUS PORTS
expenseowl tanq16/expenseowl:v4.0 "./expenseowl" expenseowl 37 seconds ago Up 37 seconds 0.0.0.0:9200->8080/tcp, [::]:9200->8080/tcp检查ExpenseOwl容器运行日志,确保ExpenseOwl服务正常运行。
docker compose logs
浏览器地址:
http://<个人的服务器IP>:9200,访问ExpenseOwl的初始页。如果无法访问,请确保宿主机的防火墙已关闭或已放行相关端口,对于云服务器还需配置相应的安全组规则。

在系统设置中,选择货币单位为 CNY(¥)后,点击“save”保存配置。

填写消费项目、类别、消费金额后,新增即可。

类型选择【income】,勾选Report Gain选项,计入收入类别中,如下所示:

在 ExpenseOwl 的主页中,我们可以通过一个直观的饼状图查看整体支出或收入的分布统计情况。

通过本次实践,成功使用Docker快速部署了ExpenseOwl,整个过程简洁高效。利用多架构镜像,可轻松在不同硬件环境中运行并实现数据持久化。Web界面美观易用,PWA支持使其在手机上也能获得接近原生应用的体验。ExpenseOwl功能专注且完全离线运行,是个人财务管理中兼顾隐私与实用性的理想选择。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。