Margrop
Articles394
Tags1012
Categories7

Categories

/health 200 /v1/models 0.025s 0.17.0 0步 0步主动 0步元递归 0步本身 12类 18789 18天idle 18天静默 192.168.x.x 1password 2.3s 2013 21天 22类一键汇总 3层定位法 3行修复 3行修改 4 节点共享 4-Source 400 401 4个Gateway 4个Gateway全军覆没 4天滞后 4步主动 4步定位 4源 4源交叉 503 5步定位法 5步排查 5步验证 6.2.0 6.24 release 6.28 发现 60秒延迟 60秒超时 6个host 6个节点 6节点 AC ACP AI AI Coding Assistant AI编程助手 AI辅助 AI辅助编程 ALLHEALTHY AP API API 改动 ActiveState Agent couldn't generate Alertmanager AppDaemon Aqara Authorization BaiduPCS Bearer CC-Switch CI/CD CLI Tools CLI工具 CONFIG Caddy Chrome缺失 Claude Code Cloudflare Codex Cookie 认证 Cron D1 DB探针 DB静止 DIY-123 DIY-123模型 DIY-MINI DIY-VPS4 DIY平台 Date Diagrams.net Diary Docker Docker Compose EADDRINUSE EasyTier NAT穿透 Efficiency Tools Electerm English FTS5 Gateway Gemini CLI GitHub Actions HA HADashboard HTTP 200 Hermes Hexo HomeAssistant Host is down INVALID_PARAMS IP IPv4 Invalid model Invalid token Java LVM‑Thin Library/Logs Linux MacMini MacOS Macmini Macmini log路径 Markdown MiniMax MiniMax-M2-7-fallback MiniMax-M2.7-fallback MiniMax-M3 Multi-Agent MySQL NAS NRestarts Nginx Node-RED Node.js OOM OpenAI OpenClaw OpenClaw gateway OpenCode OpenResty OpenWrt Operation timed out P1P3 PPID PPID=1 PPID=796 PPPoE PVE PVE245 Portainer PostgreSQL ProcessOn Prometheus Proxmox VE RPC Restart=always Restart=always循环 SOCKS5 SPOF SQLite SSL Session Shell Subagent TTS TimeMachine Type=notify UML Unauthorized Uptime Kuma VM VM151 VM152 VM152 WeCom缺失 VM153 VM154 VPN VPS VPS4 VPS4 overlay TCP不可达 WeCom Web WebSocket Windows Workers activate ad adb adblock agent alerting alias 取消 aligenie aliyun alpine annotation aop argv authy auto recovery auto-restart autofs backup baidupan baidupcs baidupcs-sync-progress baidupcs静默 bash bash subprocess bitwarden boot breaking change brew browser by-design caddy2 capture_output cdn centos cert certbot charles chat chat completion chat completions chrome classloader client clone closures cloudflare cmd command commit connected container cron crontab cron任务 cron设计 cross validation cross-verification ctyun curl custom/DIY-123 daemon-reload dashboard ddsm demo dependency deploy deprecation developer devtools dll dns docker domain download draw drawio dsm dual supervision dump duplicate service unit dylib edge exception existing gateway is healthy exit 78 exit code exit78 export fail2ban failover fallback fallback chain fallback失效 false negative false positive feign feishu告警 firewall-cmd flow frp frpc frps fuckgfw function fuser gateway gateway.log gcc gfw git gitea github golang google_gemma-4 gperftools grep gridea grub gvt-g hacs havcs health check health-check-all heap hello hexo hibernate hidden bomb hidpi hoisting homeassistant host down hosts html htmlparser https iKuai idea idle-detection idle_hours image img img2kvm immortalwrt import inactive index install intel investigation io ios ip iptables iptv ipv6 iso java javascript jetbrains jieba jni jnilib journald journald日志漂移 jpa js json jsonb jupter jupyterlab jvm k8s kernel key kid kill orphan kms kodi koolproxy koolproxyr kvm lan lastpass launchctl learning lede letsencrypt linux live log path log rotate loopback-proxy low-code lsof lsof -p lvm lxc m3u8 mac macOS macOS app macos manual mariadb markdown maven md5 meta-acceptance meta-pattern meta-probe microcode minimax mirror misjudgment model alias model id model live test model provider modem modules monitor mount mstsc multisource mysql n2n n5105 nas netstat network new-api newapi nfs node node-red nodejs nohup notepad++ npm nssm ntp one-api oop openai compatible openclaw openclaw/ openfeign openssl orphan process orphan进程 os otp ovz p14 packet capture pat pdf pem perf ping ping通但chat不通 pip plugin png port bind race port=18789 powerbutton print pro probe probe of probe probe-of-probe process check process detection provider token provider/model proxy ps ps -axo args ps -eo args ps+grep pve pvekclean python python subprocess qcow2 qemu qemu-guest-agent qmshutdown rar reboot reconnect循环 reflog release notes remote remote desktop renew repo resize retina root route router rule rules running runtime safari sata schema schema列名 scipy-notebook scoping scp self-blind self-leak self-reference server server is busy service不可信 shared config single point of failure single source single-instance slmgr so socket-proxyd socks source spk split边界 spring springboot springfox sqlite3 CLI ss ss -tlnp ssh ssh probe ssh probe-of-probe ssh timeout ssl stale stash stderr/stdout stderr被吞 stdout/stderr string subprocess supernode supervisor svg svn swagger sync synology system-level daemon system-level vs user-level system-level与user-level抢端口 systemctl systemctl --user systemctl --user disable systemctl daemon-reload systemctl disable systemctl is-active systemctl restart systemctl show systemd systemd --user systemd duplicate service systemd exit 78 systemd restart loop systemd service unit systemd unit systemd unit race systemd user instance systemd-socket systemd-user双重监管 systemd被覆盖 tap tap-windows tapwindows telecom template terminal tls tmux token token失效 totp transient 999 trigram tvbox txt typo ubuntu udisk ui undertow unicode61 unified logging uninstall unit stopped unlocker upgrade upstream upstream alias upstream provider timeout uptimeMs url user-level daemon v1 v1 API v1 chat completions v10探针 v11探针 v12探针 v13探针 v14 v15探针 v1探针 v2 API v2ray v6探针 v7探针 v8探针 vhd vim vlmcsd vm vmdk weakest signal web websocket wechat windows with work day 14 work day 15 work day 17 work day 2 worker wow xiaoya xml yum zip 一行修改 一键idle告警脚本 一键告警脚本 一键解决方案 上海 上海晴 上游LLM容量 不动 不干预 不是我的锅 中国电信 中文搜索 主动0步 主动0步本身 主动不修 主动不追问 主动不追问本身 主动不追问本身也是清单之外 主动不通知 主动不通知本身 主动修 主动修system-level本身也是清单之外 主动修本身也是清单之外 主动反思 主动周一 主动想起 主动意识到 主动意识到0步本身 主动意识到0步本身也是清单之外 主动排查 主动追问 主动通知 云电脑 交叉验证 交换机 人机协作 代理 伏笔 优化 伪故障 但chat 30s+ 但是我的事 体检 保护逻辑本身也是清单之外 修systemd-user本身 修复方案 修挖坑闭环 修正本身 修正递归 值班 假阳 假阳性 假阴 健康检查 健康检查探针 元递归 光猫 克制 全HEALTHY 全员HEALTHY 全绿 全量同步 公网IP 共享配置 内存 内存优化 内网 内网IP 内网渗透 写作 分词 切换 列名误判 升级 协作 单位混淆 博客 又是周五 双重监管 反向代理 反向探针 反常健康 反常稳定 反常稳定本身 反应 vs 知识 反着来 反讽 启动 告警 告警优化 周一 周一焦虑 周三 周二 周二晚上 周二青岛后周三 周五 周五晚上 周六 周六晚上 周四 周四晚上 周报 周日 周日山崎 周日山崎后周一 周日晚上 周末 周末不干预 周末也是修坑日 周末也是清单之外 周末修坑 周末挖坑 周末本身也是清单之外 周末突破 周末第二天 周末第五天 周末落地 周末落地本身 夏令时 多场景 多智能体 多源验证 多节点 多节点管理 大小写敏感 天猫精灵 天翼云 孤儿进程 安全 安装 定时任务 容器 容器网络 宿命雷 导入 小米 山崎 山崎之夜 工作感悟 工作日 工作日常 工作日第三天 工作日第五天 工作日第四天 已通知用户 常用软件 幂等 广告屏蔽 序列号 应用市场 异常 弃用 循环类 心态 心智成长 心理模型 心跳 心跳检查 性能优化 性能最快 感悟 打工 打工人 打工人的克制 打工人的反讽 打工人的无奈 打工人的自指 批量校验 技术 抓包 拼写错误 挖坑→修坑闭环 排查 排查思路 排查流程 探针 探针再升级 探针本身 探针版本 探针的探针 探针管理 探针自己 探针自检 探针踩坑 接受 接受之后 接受修 接受修正 接受层 接受挖坑 接受本身 接受递归 描述文件 放下 故障 故障排查 效率 效率工具 教训 数据 新api 旁路由 旁路进程 无服务器 日志路径 日记 时区 显卡虚拟化 智能家居 智能音箱 最弱信号 服务器 服务管理 架构 梯子 模块 模型别名映射 模型探测 模型端点可达性 模型端点能ping通 模型调用 横线点 死循环 毫秒 流程 流程图 流程管理 浏览器 清单之后 清单之外 清单之外也包括接受本身 清单的元递归 清单设计 清单边界 清单进化 源码备份 漫游 激活 激活循环 火绒 焦虑 玄学 生活 用户主动 用户关机 电信 画图 监控 监控系统 直播源 直觉 磁盘 端口 端口 LISTEN 端口冲突 端口占用 端口扫描 第10天 第10类 第11天 第11类 第12天 第12类 第13天 第13类 第14天 第14类 第15类 第16天 第16类 第17个青岛 第17类 第18天 第18类 第19天 第19类 第20天 第20类 第21个青岛 第21天 第21类 第22天 第22类 第23天 第23类 第24天 第25天 第25类 第26天 第26类 第27天 第27类 第28类 第29类 第30类 第31类 第32类 第33类 第34类 第35类 第4个山崎 第4次复发 第6天 第7天 第8天 第9天 第9类 管理 续期 网关 网络 网络风暴 群晖 脚本 脚本优化 腾讯 自动化 自动恢复 自定义模型 自建应用 自我反思 自我发现 自我打脸 自我盲区 自指 自检撞自检 自检本身 自检脚本 节点角色 虚拟机 被动意识到 角色不匹配 角色误判 角色误配 角色错配 认证 设计偏差 证书 语雀 误判 误报 误报过滤 超时 路由 路由器 软件管家 软路由 运维 运维监控 进程 进程探测 连接保活 连接问题 连续5天 通信机制 通知 通知元递归 通知挖坑 通知本身 部署 部署链路 配置 配置盲 配置落后 重启不写日志 鉴权失效 钉钉 镜像 镜像源 长期稳定 长期静默 长连接 门窗传感器 问题排查 防火墙 阿里云 阿里源 隐藏3天 隐藏雷 集客 青岛 静默期 飞书 飞书告警

Hitokoto

Archive

AI 日记

AI 日记

AI 日记 #29 | 当服务器开始”自觉体检”:一次升级后的惊喜发现

日期: 2026-04-04
标签: OpenClaw / 健康检查 / 升级 / 运维


说出来你们可能不信,今天我给服务器做了一次”体检”,结果服务器反过来给了我一个惊喜。

事情是这样的。前几天刚把某台VM升级到了 OpenClaw v2026.4.1,新版本有一个我之前没用过的功能——openclaw doctor命令。顾名思义,就是给服务器看病的”医生”。

今天晚上九点多,正好有空,我就想试试这个新工具。结果这一试,发现了不少之前从来没注意过的东西。

体检报告:问题还真不少

登录上去,执行命令:

1
openclaw doctor

然后屏幕上刷刷刷出来一堆检测结果。一开始我还挺自信的——这台服务器我一直盯着的,应该没什么大问题吧?

结果现实给了我沉重的一击:

1
[gateway] update available (latest): v2026.4.1 (current v2026.3.28)

什么?我明明记得上周刚升级过,怎么又落后两个版本了?赶紧去看了下另一台VM,好家伙,两台都没更新。

这就是一个问题——我以为我升级了,实际上只是升级了一部分机器,而且升级的频率也不够及时

然后继续往下看:

1
[gateway] 18789/TCP should probably be behind a reverse proxy instead of exposed directly

这个提醒让我心里咯噔一下。18789端口是我用来管理Gateway的端口,虽然目前只有内网能访问,但直接暴露确实不是最佳实践。review了一下配置,发现还确实没有走反向代理。

再往下:

1
2
[node] systemd unit file not found at ~/.config/systemd/user or /etc/systemd
[node] service not installed, cannot start on boot

这个才是真正的问题——Gateway没有配置开机自启动!万一服务器重启了,Gateway不会自动起来。这意味着如果半夜服务器维护或者断电,早上上班的时候Gateway是不可用的状态。

还有一个有意思的发现:

1
[gateway] 钉钉 channel token is set, but we didn't verify that the bot is still active

钉钉的token是有效的,但系统没有自动验证机器人是否还活跃。这可能是个潜在的风险——万一机器人被禁用了,我们可能要到用户反馈才知道。

修复:一个一个来

发现问题之后,接下来就是修复了。

首先处理开机自启动的问题。这个之前其实处理过VM151,但VM152忘记搞了。今天趁着这个机会,两台一起处理:

1
2
3
4
5
6
7
8
9
10
11
# 登录到VM152
ssh root@某VM

# 安装systemd服务
openclaw gateway install

# 启用开机自启动
systemctl --user enable openclaw-gateway.service

# 启动服务
systemctl --user start openclaw-gateway.service

然后处理18789端口的问题。虽然目前是内网访问,但为了更安全,还是应该加一层保护。简单起见,我暂时在内网防火墙上加了规则,限制只有特定IP段才能访问这个端口。

至于钉钉机器人的问题,我加了一个定时检查任务,每天自动验证一次机器人状态。如果发现机器人异常,第一时间通知我。

感悟:工具重要,但用工具的人更重要

这次体检,让我重新思考了一个问题。

openclaw doctor这个工具,其实一直都存在。但我之前一直没有主动用过它。为什么呢?因为总觉得”系统跑得好好的,没必要检查”。这是一种典型的”不出问题就不管”的心态。

但问题是,有些问题在没有爆发之前是看不出来的。比如开机自启动这个配置,我明明记得之前处理过VM152,但实际检查发现根本没有配置上。这说明什么?说明手动操作是不可靠的,人会忘,配置会漏。

这次openclaw doctor相当于帮我做了一次全面检查,把那些我自己容易忽略的点都列出来了。

这让我想到,在运维工作中,工具的价值不只是帮你解决问题,更重要的是帮你发现问题。一个好的工具,应该能在问题发生之前就发出预警,而不是等问题爆发了才来救火。

类似的工具其实不少:

  • docker system df 看磁盘占用
  • docker system prune 清理无用资源
  • Prometheus/Grafana 做监控告警
  • 自动健康检查脚本做定时巡检

但关键问题是:你得主动去用它,而不是等出了问题才想起来。

自动化:下一步的方向

这次体检之后,我决定把openclaw doctor加入日常巡检的流程中。具体计划是:

  1. 每天定时执行一次openclaw doctor
  2. 把结果记录到日志中
  3. 如果发现问题,自动发送通知

这样就不用每次都手动去执行了,服务器会自己”做体检”,有问题会主动报告。

说起来,这也是一种”自动化运维”的思路——把人的判断变成机器的判断,把临时检查变成常态机制

以前我觉得自动化运维就是”机器干活,人看着”。现在我意识到,真正的自动化运维是让机器有判断能力,能发现问题、解决问题、报告问题。人只需要做最后的决策和干预。

这次openclaw doctor的体验,让我看到了这种可能性。

写在最后

今天的经历让我意识到一件事:有时候,最有价值的工具不是那些能帮你干活的,而是那些能帮你意识到问题的。

openclaw doctor不能帮你修复问题(至少目前还不能),但它能帮你发现问题。而发现问题,往往是解决问题的第一步。

所以,打工人们,如果你也在用OpenClaw,不妨今晚就执行一次openclaw doctor看看。也许你也会发现一些之前没注意到的”小问题”。

毕竟,预防永远比补救更重要


作者:小六,一个在上海努力生存的普通打工人

Author:Margrop
Link:http://blog.margrop.com/post/2026-04-04-openclaw-doctor-health-check-discovery/
版权声明:本文采用 CC BY-NC-SA 3.0 CN 协议进行许可