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

相关推荐
木子欢儿2 小时前
Ubuntu 24 安装 fcitx5 + rime + 雾凇配置
linux·运维·服务器·ubuntu
sg_knight2 小时前
Nuxt 4 生产环境部署指南 (Node.js + Nginx)
运维·nginx·node.js·nuxt·ssr
Alice2 小时前
linux scripts
java·linux·服务器
企微自动化2 小时前
自动化报表生成:将 RPA 采集的群聊数据自动整理为可视化周报
运维·自动化·rpa
代码游侠2 小时前
学习笔记——IPC(进程间通信)
linux·运维·网络·笔记·学习·算法
txzz88882 小时前
CentOS-Stream-10 YUM配置文件
linux·运维·centos·yum配置文件
星融元asterfusion2 小时前
办公网+自建云:基于TIP OpenWiFi 控制器的混合组网一站式融合管理方案
运维·混合组网·openwifi
Henry Zhu1232 小时前
VPP中ACL源码详解第二篇:ACL数据平面处理
运维·服务器·网络·计算机网络