YamBMS项目YAML配置完全指南
2025-06-26 12:17:11作者:房伟宁
项目概述
YamBMS是一个基于ESPHome的电池管理系统(BMS)监控解决方案,支持多种BMS设备类型和通信方式。本文将详细介绍如何为YamMBMS项目创建和配置YAML文件,帮助用户实现电池系统的全面监控。
基础配置
网络连接配置
YamBMS支持WiFi和以太网两种连接方式,建议根据实际使用环境选择合适的连接方式。
WiFi配置示例
wifi:
manual_ip:
static_ip: 192.168.0.85
gateway: 192.168.0.1
subnet: 255.255.255.0
dns1: 8.8.8.8
dns2: 8.8.4.4
重要提示:
- 默认情况下,如果ESP32断开WiFi连接,会每15分钟重启尝试恢复连接
- WiFi凭证需要配置在secrets.yaml文件中
以太网配置示例
ethernet:
manual_ip:
static_ip: 192.168.0.85
gateway: 192.168.0.1
subnet: 255.255.255.0
dns1: 8.8.8.8
dns2: 8.8.4.4
Home Assistant API配置
api:
reboot_timeout: 0s
此配置可防止ESP32在Home Assistant断开连接时自动重启。
Web服务器配置
Web服务器组件提供了通过浏览器访问YamBMS信息的界面,但需要注意:
- 启用此组件会占用大量内存
- 可能会影响系统稳定性
- 在不使用Home Assistant时特别有用
硬件板选择
YamBMS支持多种ESP32开发板,以下是常见型号的配置示例:
通用ESP32开发板
device_board: !include packages/board/board_ESP32_Generic.yaml
带显示屏的开发板
device_board: !include
file: packages/board/board_ESP32-S3_AtomS3.yaml
vars:
display_auto_next_page_interval: '5s'
带以太网的开发板
device_board: !include packages/board/board_ESP32-C3_ETH01-EVO.yaml
BMS设备配置
基本规则
- BMS必须从1开始顺序编号
- 主节点使用
bms_combine前缀的配置文件 - RS485总线上的节点使用
bms_modbus前缀的配置文件
JK-BMS配置示例
BLE连接方式
bms1: !include
file: packages/bms/bms_combine_JK_BLE_standard.yaml
vars:
bms_id: '1'
bms_name: 'BMS 1'
bms_ble_protocol_version: 'JK02_32S'
bms_ble_mac_address: 'C8:47:8C:10:7E:AA'
bms_cell_max_cycles: '6000.0'
注意:BLE连接会消耗大量RAM,建议优先考虑UART或RS485连接。
UART连接方式
bms1: !include
file: packages/bms/bms_combine_JK_UART_4G-GPS_full.yaml
vars:
bms_id: '1'
bms_name: 'BMS 1'
bms_uart_id: 'uart_esp_1'
bms_cell_max_cycles: '6000.0'
JBD-BMS配置示例
UART连接方式
bms1: !include
file: packages/bms/bms_combine_JBD_UART_full.yaml
vars:
bms_id: '1'
bms_name: 'BMS 1'
bms_uart_id: 'uart_esp_1'
bms_rx_timeout: '150ms'
bms_max_charge_current: '100'
bms_max_discharge_current: '100'
bms_cell_ovp: '3.650'
bms_cell_uvp: '2.800'
bms_balance_trigger_voltage: '0.010'
bms_cell_max_cycles: '6000.0'
分流器(Shunt)配置
基本规则
- 分流器必须从1开始顺序编号
- 主节点使用
shunt_combine前缀的配置文件 - RS485总线上的节点使用
shunt_modbus前缀的配置文件
Victron SmartShunt配置示例
shunt1: !include
file: packages/shunt/shunt_combine_Victron_SmartShunt_UART.yaml
vars:
shunt_id: '1'
shunt_name: 'Shunt 1'
RS485多节点配置
YamBMS支持通过RS485总线连接多个节点,实现分布式电池监控。
主节点(Modbus客户端)配置
modbus: !include
file: packages/base/device_modbus.yaml
vars:
modbus_role: 'client'
modbus_uart_id: 'uart_esp_1'
bms1: !include
file: packages/bms/bms_combine_modbus_client.yaml
vars:
bms_id: '1'
bms_name: 'BMS 1'
从节点(Modbus服务器)配置
modbus: !include
file: packages/base/device_modbus.yaml
vars:
modbus_role: 'server'
modbus_uart_id: 'uart_esp_1'
bms1: !include
file: packages/bms/bms_modbus_JK_UART_4G-GPS_full.yaml
vars:
bms_id: '1'
bms_name: 'BMS 1'
重要提示:Modbus客户端和服务器的BMS/Shunt ID必须完全匹配。
性能优化建议
- 蓝牙和Web服务器组件会占用大量内存,可能影响稳定性
- 优先使用有线连接(UART/RS485)而非蓝牙
- 对于简单监控需求,可以使用minimal版本的配置文件
- 合理配置自动重启参数,平衡系统稳定性和故障恢复能力
通过以上配置指南,用户可以灵活地构建适合自己需求的电池监控系统,无论是单节点还是复杂的多节点RS485网络。
登录后查看全文
热门项目推荐
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 StartedRust0152- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112
项目优选
收起
暂无描述
Dockerfile
733
4.75 K
Ascend Extension for PyTorch
Python
617
795
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.01 K
1.01 K
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
433
395
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
145
237
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
1.18 K
152
暂无简介
Dart
983
252
Oohos_react_native
React Native鸿蒙化仓库
C++
348
403
昇腾LLM分布式训练框架
Python
166
198
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.68 K
989