Garmin数据可视化从零开始:健康数据监控平台搭建指南
2026-03-10 04:55:01作者:尤辰城Agatha
1. 项目快速上手:核心功能与目录解析
Garmin-Grafana是一个开源健康数据监控解决方案,通过Python脚本从Garmin Connect获取健康数据,存储到InfluxDB时序数据库,并通过Grafana实现长期健康趋势可视化。项目采用容器化架构,支持多环境部署,核心功能包括:健康数据自动抓取、时间序列数据存储、自定义仪表板展示。
项目主要目录结构:
- src/:核心Python代码,包含Garmin数据抓取(garmin_fetch.py)、InfluxDB数据导出(influxdb_exporter.py)等模块
- Grafana_Dashboard/:仪表板配置文件,包含JSON和YAML两种格式的配置
- k8s/:Kubernetes部署模板,支持生产环境容器编排
- Grafana_Datasource/:InfluxDB数据源配置文件
2. 3步完成容器部署:从环境准备到服务启动
步骤1:环境准备与代码获取
确保本地已安装Docker和Docker Compose。通过以下命令克隆项目代码:
git clone https://gitcode.com/gh_mirrors/ga/garmin-grafana
cd garmin-grafana
步骤2:配置文件准备
复制示例配置文件并修改必要参数:
cp compose-example.yml docker-compose.yml
该文件定义了三个核心服务:
- garmin-fetch-data:负责从Garmin服务器获取健康数据
- influxdb:时序数据库服务,存储健康指标
- grafana:可视化仪表板服务,展示健康趋势
步骤3:启动服务集群
使用Docker Compose启动所有服务:
docker-compose up -d
首次启动会自动拉取所需镜像并初始化数据库,服务启动后可通过docker-compose ps检查服务状态。
3. 参数配置详解:环境变量与最佳实践
核心配置参数说明
在docker-compose.yml中需要配置以下关键环境变量:
environment:
# InfluxDB数据库配置
- INFLUXDB_HOST=influxdb
- INFLUXDB_PORT=8086
- INFLUXDB_USERNAME=admin
- INFLUXDB_PASSWORD=securepassword
- INFLUXDB_DATABASE=garmin_health
# Garmin账户配置
- GARMINCONNECT_EMAIL=your@email.com
- GARMINCONNECT_BASE64_PASSWORD=base64_encoded_password
# 系统配置
- UPDATE_INTERVAL_SECONDS=3600 # 每小时更新一次数据
- LOG_LEVEL=INFO # 生产环境建议使用INFO级别
配置项最佳实践
- 密码安全:Base64编码密码可通过
echo -n "your_password" | base64生成,避免明文存储 - 更新间隔:根据数据需求调整,运动爱好者建议设为1800秒(30分钟),普通用户可设为3600秒(1小时)
- 存储优化:InfluxDB建议配置数据保留策略,避免磁盘空间溢出
- 日志管理:调试时设为DEBUG级别,生产环境切换为INFO以减少日志量
4. 数据可视化实践:仪表板导入与自定义
仪表板导入步骤
- 访问Grafana界面(默认地址:http://localhost:3000)
- 使用默认账号admin/admin登录,首次登录需修改密码
- 进入"Dashboard" → "Import",上传
Grafana_Dashboard/Garmin-Grafana-Dashboard.json文件 - 选择InfluxDB数据源,完成导入
仪表板功能介绍
导入后的仪表板包含多维度健康数据展示:
主要可视化组件包括:
- 心率趋势图:展示静息心率和运动心率变化
- 睡眠分析:深度睡眠/浅度睡眠周期分布
- 活动地图:GPS轨迹可视化与运动路径分析
- 生理指标:步数、卡路里消耗、爬楼层数等日常活动数据
- 训练效果:运动强度分布与恢复建议
5. 常见问题排查:从数据获取到可视化全流程
数据获取类问题
问题1:Garmin数据无法获取
- 检查网络连接:确认容器可访问Garmin Connect服务器
- 验证凭据:通过
docker-compose logs garmin-fetch-data查看登录错误 - 令牌持久化:确保
garmin_tokens_data卷正确挂载,避免重复登录
问题2:数据更新不及时
- 检查UPDATE_INTERVAL_SECONDS配置值
- 查看日志确认数据抓取任务是否正常执行
- 验证InfluxDB写入权限和磁盘空间
可视化类问题
问题1:Grafana无数据显示
- 检查数据源配置:确认InfluxDB连接参数正确
- 验证数据库存在性:通过
docker exec -it influxdb influx进入数据库检查 - 时间范围设置:确认Grafana查询时间范围包含有效数据
问题2:仪表板加载缓慢
- 优化查询:减少时间范围或降低数据采样频率
- 调整面板数量:拆分复杂仪表板为多个专项视图
- 升级硬件:对于大量历史数据,建议增加InfluxDB内存分配
6. 高级部署选项:Kubernetes集群配置
对于企业级部署,可使用项目提供的Kubernetes配置文件:
cd k8s
make deploy # 基于values.yaml配置部署整个应用栈
Kubernetes部署优势:
- 自动扩缩容:根据数据量动态调整资源
- 高可用性:多副本部署确保服务不中断
- 滚动更新:支持无停机升级应用版本
配置文件位于k8s/templates/目录,包含部署清单、服务定义和持久卷配置,可根据实际环境调整资源需求和网络策略。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust077- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
MiniMax-M2.7MiniMax-M2.7 是我们首个深度参与自身进化过程的模型。M2.7 具备构建复杂智能体应用框架的能力,能够借助智能体团队、复杂技能以及动态工具搜索,完成高度精细的生产力任务。Python00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
Kimi-K2.6Kimi K2.6 是一款开源的原生多模态智能体模型,在长程编码、编码驱动设计、主动自主执行以及群体任务编排等实用能力方面实现了显著提升。Python00
Hy3-previewHy3 preview 是由腾讯混元团队研发的2950亿参数混合专家(Mixture-of-Experts, MoE)模型,包含210亿激活参数和38亿MTP层参数。Hy3 preview是在我们重构的基础设施上训练的首款模型,也是目前发布的性能最强的模型。该模型在复杂推理、指令遵循、上下文学习、代码生成及智能体任务等方面均实现了显著提升。Python00
项目优选
收起
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
434
76
暂无描述
Dockerfile
690
4.46 K
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
407
326
Ascend Extension for PyTorch
Python
547
671
deepin linux kernel
C
28
16
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.59 K
925
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
955
930
本项目是CANN开源社区的核心管理仓库,包含社区的治理章程、治理组织、通用操作指引及流程规范等基础信息
650
232
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.08 K
564
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
C
436
4.43 K
