树莓派 ESPHome 固件编译与烧录全攻略(解决超时与串口识别问题)

本文记录在树莓派 Home Assistant (hass) 环境下,使用 ESPHome 编译、构建并烧录 ESP32 固件的完整流程。包含常见网络超时错误的解决方法及串口烧录命令详解。

一、 前置准备与问题排查

在开始之前,请确保你已经安装了 ESPHome。通常它包含在 Home Assistant 的 Python 虚拟环境中。

1. 检查开发环境

首先进入你的 ESPHome 项目目录(假设为 ~/hass/esphome),并确认配置文件存在。

复制代码
cd ~/hass/esphome
ls
# 确保看到类似 esp32.yaml 的配置文件

2. 解决"Github 连接超时"错误(常见坑)

如果在安装依赖或编译时遇到 ConnectTimeout: Connection to github.com timed out,这是因为网络环境无法连接到 GitHub 下载依赖包。

解决方法

  • 方法A(推荐) :配置代理或切换网络环境,确保能访问 github.com
  • 方法B(临时):增加网络超时时间,但这通常治标不治本。
  • 方法C :检查 DNS 设置,尝试将 DNS 修改为 8.8.8.8114.114.114.114

二、 核心命令详解

ESPHome 的操作主要分为三个步骤:验证配置编译固件烧录固件

1. 验证配置

在编译之前,最好先检查 YAML 语法是否正确。

复制代码
esphome config esp32.yaml

输出 SUCCESS 表示配置无误。

2. 编译固件

此步骤会将你的 YAML 配置编译成 ESP32 可执行的二进制文件。

复制代码
esphome compile esp32.yaml

编译成功标志

看到如下日志表示编译完成:

复制代码
========================================================================================== [SUCCESS] Took 1127.25 seconds ==========================================================================================
INFO Successfully compiled program.

3. 烧录固件

编译完成后,需要将固件上传到 ESP32 芯片。这里有两种方式:OTA (无线)串口 (USB)

方式 A:OTA 无线烧录(适用于设备已联网)

如果设备之前已经刷过 ESPHome 且连接了 WiFi,直接运行:

复制代码
esphome run esp32.yaml

*此命令会自动编译并尝试通过 WiFi 上传。*

方式 B:串口烧录(适用于首次烧录或 OTA 失败)

这是最稳妥的方式。首先通过 USB 线连接 ESP32 和树莓派。

步骤 1:查找串口设备

在 Linux 下,串口设备通常位于 /dev/ 目录下。使用以下命令查找:

复制代码
ls /dev/ttyUSB* /dev/ttyACM* /dev/serial/by-id/*
  • /dev/ttyUSB0: 常见的 USB 转串口设备(如 CP2102, CH340)。
  • /dev/serial/by-id/...: 设备的唯一 ID 路径,推荐使用,防止插错设备。

常见输出示例

复制代码
/dev/ttyUSB0
/dev/serial/by-id/usb-Silicon_Labs_CP2102_USB_to_UART_Bridge_Controller_0001-if00-port0

步骤 2:执行烧录命令

找到设备路径后,使用 upload 命令并指定 --device 参数(注意:ESPHome 使用 --device 而不是 --port):

复制代码
# 使用简单设备名
esphome upload esp32.yaml --device /dev/ttyUSB0

# 或者使用唯一 ID(推荐)
esphome upload esp32.yaml --device /dev/serial/by-id/usb-Silicon_Labs_CP2102_USB_to_UART_Bridge_Controller_0001-if00-port0

烧录成功标志

看到如下日志表示烧录成功:

复制代码
Hash of data verified.
Leaving...
Hard resetting via RTS pin...
INFO Successfully uploaded program.
相关推荐
我爱吃土豆11 天前
Gin响应形式
驱动开发·gin
_Emma_1 天前
【QCOM】 Linux下qcom venus 编解码驱动框架分析
linux·驱动开发·视频编解码
春日见2 天前
TEST文件夹:Pytest,集成测试,单元测试
服务器·人工智能·驱动开发·单元测试·计算机外设·集成测试·pytest
清水白石0082 天前
Python 项目 CI/CD 信心模型:证据驱动部署,从“勇敢上线”到“零风险发版”实战指南
驱动开发·python·ci/cd
A.说学逗唱的Coke2 天前
【AI协同软件工程】规范驱动开发工具全景解析:OpenSpec、SpecKit与传统SDD工具深度对比指南
人工智能·驱动开发·软件工程
国医中兴2 天前
Flutter 三方库 pickled_cucumber 的鸿蒙化适配指南 - 玩转 BDD 行为驱动开发、Gherkin 自动化测试实战、鸿蒙级质量守护神
驱动开发·flutter·harmonyos
tdhao8882 天前
部署 VS2022 驱动开发环境-解决无法编译驱动的问题
驱动开发·visual studio
篮子里的玫瑰3 天前
智能天气时钟项目(二):AHT20温湿度传感器驱动开发详解
驱动开发
欲盖弥彰13143 天前
Linux设备驱动 -- TMP75AIDR驱动移植
linux·驱动开发·驱动·驱动移植·嵌入式linux驱动·tmp75aidr
ShawnLiaoking4 天前
华硕ROG LoadLibrary failed 126
驱动开发·显示器