RaspberryPi-如何启用看门狗

简述:树莓派 5 的硬件看门狗由 RP1(南桥)提供,对应的内核驱动是 bcm2712_wdt;

1. 安装硬件看门狗模块:

sudo apt install watchdog

2. 启用并配置它:

sudo systemctl enable watchdog

sudo systemctl start watchdog

3. 检查系统是否已经识别看门狗:

看到类似 bcm2712-wdt / bcm2835-wdt 或 /dev/watchdog0,说明内核已创建设备。/dev/watchdog0 是具体的看门狗实例设备节点,/dev/watchdog 是为兼容性提供的默认入口,用户态程序通过 /dev/watchdog 与看门狗设备交互,用户态程序也可以直接打开 /dev/watchdog0,效果等同于通过 /dev/watchdog

dmesg | grep -i wdt

ls -l /dev/watchdog*

4. 【二选一】配置 /etc/watchdog.conf:

是给 watchdog daemon 的配置文件,这个守护进程会按配置去做一系列"自定义健康检测(health checks)"

用户态守护进程 - 可能有多个线程,做自定义监控,但守护进程挂掉就无法喂狗。如果 systemd 已经占用 hardware watchdog,守护进程可能报错:cannot open /dev/watchdog

有24个"需要CPU资源才能推进的任务"处于活跃状态,包括正在运行的和排队等待的线程/进程。

PID用的是2331:

验证:

# 方法 1 (先停止守护进程,等待超时,等待时间约等于 /sys/.../timeout 的值)

sudo systemctl stop watchdog

# 方法 2 (打开设备然后挂起,不喂)

sudo bash -c 'exec 3>/dev/watchdog; sleep 60'

# watchdog 服务日志(近期有没有错误)

journalctl -u watchdog -b --no-pager

# 查看上一次 boot kernel 日志里是否有 watchdog 重启痕迹

journalctl -k -b -1 | grep -i watchdog

# 或查看上一次系统日志的时间轴

journalctl -b -1 | grep -i watchdog

4. 【二选一】配置 /etc/systemd/system.conf:

设置 systemd runtime watchdog(操作系统自带的 watchdog,守护整个 userspace,不依赖任何额外进程,稳定、可靠、开机早就接管,防止用户态守护进程挂掉)

保存后并启用 watchdog 服务:

sudo systemctl enable --now watchdog0

sudo systemctl status watchdog0

systemd 在启动时会扫描所有可用的看门狗设备,选择第一个可用的设备也就是/dev/watchdog0:

验证:

# 直接让内核panic

sudo bash -c "echo 1 > /proc/sys/kernel/panic; echo 1 > /proc/sys/kernel/panic_timeout; echo c > /proc/sysrq-trigger"

# 查看当前启动的所有看门狗相关日志

sudo journalctl -b 0 | grep -iE "watchdog|panic|reset|reboot"

# 查看 systemd 服务的看门狗日志

sudo journalctl -u systemd | grep -i watchdog

# 查看所有日志中的看门狗信息

sudo journalctl | grep -i watchdog | tail -20

5. 查看内核当前状态:

只要 /dev/watchdog 被某个进程占用,并且 sysfs 能看到 identity/timeout,就说明 watchdog 已经启用并在工作。

# 查看看门狗设备状态

sudo wdctl

# 查看设备节点信息

ls -l /dev/watchdog*

# 查看 sysfs 中的设备信息

ls /sys/class/watchdog/

cat /sys/class/watchdog/watchdog0/identity

cat /sys/class/watchdog/watchdog0/timeout

# 查看 watchdog 服务状态( systemd

sudo systemctl status watchdog

# 查看所有与看门狗相关的 systemd 服务

systemctl list-units --all | grep -i watchdog

# 查看内核 watchdog 消息

sudo dmesg | grep -i watchdog

# 查看 watchdog 是否被某个进程占用

sudo lsof /dev/watchdog

# 检查 systemd 进程( PID 1 )打开了哪些文件

sudo ls -l /proc/1/fd/ 2>/dev/null | grep watchdog

# 服务没有启动,需要使用

sudo systemctl start watchdog

sudo systemctl enable watchdog

# 停止并禁用独立的 watchdog 服务

sudo systemctl disable --now watchdog.service

相关推荐
Doro再努力21 分钟前
【Linux操作系统06】深入理解权限掩码与粘滞位
linux·运维·服务器
wdfk_prog23 分钟前
[Linux]学习笔记系列 -- [drivers][dma]stm32-dma
linux·笔记·学习
mzhan01730 分钟前
[Linux] vdso 32bit vs 64bit
linux·运维·服务器
旖旎夜光35 分钟前
Linux(13)(上)
linux·网络
忧郁的橙子.35 分钟前
26期_01_Pyhton linux基本命令
linux·运维·服务器
郝学胜-神的一滴38 分钟前
深入解析Linux网络编程之bind函数:从基础到实践的艺术
linux·服务器·网络·c++·websocket·程序人生
西京刀客41 分钟前
macOS 打出来的 tar 包,Linux 常见告警(tar 包里带了 macOS 的扩展属性(xattr))
linux·运维·macos
mango_mangojuice41 分钟前
Linux学习笔记(角色,权限管理)1.21
linux·笔记·学习
遇见火星1 小时前
Linux综合性能监控工具dstat命令详解
linux·服务器·php·dstat
相思难忘成疾1 小时前
通向HCIP之路:第三步:动态路由协议OSPF(全)
服务器·网络·智能路由器·hcip