2.3 KiB
2.3 KiB
自动化营业额数据推送与展示系统
快速部署(Docker)
- 1:准备环境变量(不要提交真实口令到仓库)
- 复制
.env.example到.env并填写ADMIN_TOKEN
- 复制
- 2:启动服务
docker-compose up -d
- 3:访问入口
- 浏览器打开
http://<服务器IP或域名>:57778
- 浏览器打开
腾讯云环境优化
- 使用腾讯云 PyPI 镜像:Dockerfile 已设置
pip -i https://mirrors.cloud.tencent.com/pypi/simple - 设置时区为
Asia/Shanghai:Dockerfile 安装并配置tzdata - 数据持久化:
docker-compose.yml将宿主机./data映射为容器/app/data,数据库路径sqlite:///data/data.db
功能概览
- 每日 23:00(服务器本地时区)自动生成并定版当日营业额
- 修正接口:支持按日期修正金额,前端即时一致更新;修正过程不直接在前端展示
- 审计与日志:所有生成/修正写入审计表,兼容追加到
app.log - 看板:今日/昨日/前日、本周(周一~昨日)、上周(周一~周日)、本月
- 折线图:最近 7 天、本月、上月、最近 90 天;支持缩放、导出图片/CSV
项目结构
.
├── backend/ # Flask API + APScheduler
├── frontend/ # 单页 HTML(Tailwind+Chart.js)
├── data/ # SQLite 数据卷(自动创建/挂载)
├── Dockerfile # 生产镜像(已适配腾讯云)
├── docker-compose.yml # 一键部署
├── .env.example # 环境变量示例(不要提交真实 .env)
└── README.md
环境变量
DATABASE_URL:数据库连接字符串(默认sqlite:///data/data.db)ADMIN_TOKEN:管理修正口令;修正时在请求头加入X-Admin-TokenTZ:容器时区(默认Asia/Shanghai)PORT:应用监听端口(默认5000,示例已改为57778)
修正接口示例
curl -X PUT http://localhost:5000/api/admin/turnover \
-H "Content-Type: application/json" \
-H "X-Admin-Token: $ADMIN_TOKEN" \
-d '{"date":"2025-12-06","amount":3123.45,"reason":"调整入账"}'
生产建议
- 建议使用反向代理(Nginx)暴露
5000端口,并开启 gzip - 建议通过
docker-compose的restart: unless-stopped保持服务稳定 - 如需外部数据库,设置
DATABASE_URL(例如 PostgreSQL),并移除数据卷映射