Margrop
Articles384
Tags873
Categories7

Categories

/health 200 /v1/models 0.025s 0步 0步主动 0步元递归 0步本身 12类 18789 18天idle 18天静默 192.168.x.x 1password 21天 22类一键汇总 3层定位法 3行修复 3行修改 401 4个Gateway 4个Gateway全军覆没 4天滞后 4步主动 4步定位 503 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 改动 Agent couldn't generate Alertmanager AppDaemon Aqara BaiduPCS CC-Switch CI/CD CLI Tools CLI工具 CONFIG Caddy Chrome缺失 Claude Code Cloudflare Codex Cookie 认证 Cron D1 DB探针 DB静止 DIY-123模型 DIY-MINI DIY平台 Date Diagrams.net Diary Docker Docker Compose EADDRINUSE EasyTier NAT穿透 Efficiency Tools Electerm English FTS5 Gateway Gemini CLI GitHub Actions HA HADashboard Hermes Hexo HomeAssistant IP IPv4 Invalid model Java LVM‑Thin Linux MacOS Macmini Macmini log路径 Markdown MiniMax MiniMax-M3 Multi-Agent MySQL NAS NRestarts Nginx Node-RED Node.js OOM OpenAI OpenClaw OpenClaw gateway OpenCode OpenResty OpenWrt PPID PPID=1 PPID=796 PPPoE Portainer PostgreSQL ProcessOn Prometheus Proxmox VE RPC Restart=always Restart=always循环 SOCKS5 SQLite SSL Session Shell Subagent TTS TimeMachine UML Uptime Kuma VM151 VM152 WeCom缺失 VM153 VPN VPS VPS4 VPS4 overlay TCP不可达 WeCom Web WebSocket Windows Workers activate ad adb adblock agent aligenie aliyun alpine annotation aop argv authy 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设计 ctyun 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 exit78 export fail2ban fallback fallback失效 false positive feign feishu告警 firewall-cmd flow frp frpc frps fuckgfw function fuser gcc gfw git gitea github golang google_gemma-4 gperftools grep gridea grub gvt-g hacs havcs health check heap hello hexo hibernate hidpi hoisting homeassistant hosts html htmlparser https iKuai idea idle-detection idle_hours image img img2kvm immortalwrt import index install intel 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 loopback-proxy low-code lsof lvm lxc m3u8 mac macos manual mariadb markdown maven md5 meta-acceptance meta-pattern meta-probe microcode mirror model provider modem modules monitor mount mstsc mysql n2n n5105 nas netstat network new-api nfs node node-red nodejs nohup notepad++ npm nssm ntp one-api oop 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 process detection provider/model proxy ps ps -axo args ps+grep pve pvekclean python python subprocess qcow2 qemu qemu-guest-agent 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-leak self-reference server server is busy service不可信 single-instance slmgr so socket-proxyd socks source spk split边界 spring springboot springfox sqlite3 CLI ss ssh ssl stale stash 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 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 ubuntu udisk ui undertow unicode61 uninstall unlocker upgrade upstream provider timeout uptimeMs url user-level daemon v1 API v10探针 v11探针 v12探针 v13探针 v14 v15探针 v1探针 v2 API v2ray v6探针 v7探针 v8探针 vhd vim vlmcsd vm vmdk web websocket wechat windows with work day 14 work day 15 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 知识 反着来 启动 告警 告警优化 周一 周一焦虑 周三 周二 周二晚上 周五 周五晚上 周六 周六晚上 周四 周四晚上 周报 周日 周日山崎 周日山崎后周一 周日晚上 周末 周末也是修坑日 周末也是清单之外 周末修坑 周末本身也是清单之外 周末突破 周末第二天 周末第五天 周末落地 周末落地本身 夏令时 多场景 多智能体 多节点 多节点管理 天猫精灵 天翼云 孤儿进程 安全 安装 定时任务 容器 容器网络 导入 小米 山崎 山崎之夜 工作感悟 工作日 工作日常 工作日第三天 工作日第五天 工作日第四天 已通知用户 常用软件 幂等 广告屏蔽 序列号 应用市场 异常 弃用 循环类 心态 心智成长 心理模型 心跳 心跳检查 性能优化 感悟 打工 打工人 打工人的反讽 打工人的无奈 打工人的自指 批量校验 技术 抓包 挖坑→修坑闭环 排查 排查思路 探针 探针再升级 探针本身 探针版本 探针管理 探针自检 探针踩坑 接受 接受之后 接受修 接受修正 接受层 接受挖坑 接受本身 接受递归 描述文件 放下 故障 故障排查 效率 效率工具 数据 旁路由 旁路进程 无服务器 日记 时区 显卡虚拟化 智能家居 智能音箱 服务器 服务管理 架构 梯子 模块 模型别名映射 模型探测 模型端点可达性 模型端点能ping通 模型调用 死循环 毫秒 流程 流程图 流程管理 浏览器 清单之后 清单之外 清单之外也包括接受本身 清单的元递归 清单设计 清单边界 清单进化 源码备份 漫游 激活 激活循环 火绒 焦虑 玄学 生活 电信 画图 监控 监控系统 直播源 直觉 磁盘 端口 端口冲突 端口占用 端口扫描 第10天 第10类 第11天 第11类 第12天 第12类 第13天 第13类 第14天 第14类 第15类 第16天 第16类 第17类 第18天 第18类 第19天 第19类 第20天 第20类 第21天 第21类 第22天 第22类 第23类 第25类 第26类 第27类 第28类 第29类 第30类 第4个山崎 第4次复发 第6天 第7天 第8天 第9天 第9类 管理 续期 网关 网络 网络风暴 群晖 脚本 脚本优化 腾讯 自动化 自动恢复 自定义模型 自建应用 自我反思 自我发现 自我打脸 自指 自检本身 自检脚本 节点角色 虚拟机 被动意识到 角色不匹配 角色误判 角色误配 角色错配 认证 设计偏差 证书 语雀 误报 误报过滤 超时 路由 路由器 软件管家 软路由 运维 运维监控 进程 进程探测 连接保活 连接问题 通信机制 通知 通知元递归 通知挖坑 通知本身 部署 部署链路 配置 配置落后 钉钉 镜像 镜像源 长期稳定 长期静默 长连接 门窗传感器 问题排查 防火墙 阿里云 阿里源 集客 青岛 静默期 飞书 飞书告警

Hitokoto

Archive

那些没人看见的打工人时刻:论"隐形劳动"的自我修养

那些没人看见的打工人时刻:论"隐形劳动"的自我修养

那些没人看见的打工人时刻:论”隐形劳动”的自我修养

今天是周四,上海的天气说变就变。早上出门的时候还晴着,中午就开始飘雨。这种天气让人有点犯困,坐在工位上对着屏幕,眼睛不自觉地就飘向了窗外。

窗外是什么?是陆家嘴的高楼,是来来往往的人群,是这座城市永不停歇的节奏。地铁在地下穿梭,外卖小哥在街头飞驰,写字楼里的灯一盏一盏亮起来。

我有时候会想,这座城市里有多少人,正在做着和我一样的事情——对着屏幕,敲着键盘,处理着那些”看起来很简单但其实很复杂”的隐形劳动。

什么是”隐形劳动”?

说起来,我们的工作里有多少是”看得见的”?

比如你写了一段代码,上线了一个功能,这个成果是可以量化的——commit 记录在案,代码行数可查,功能文档可查。这种工作,你可以说”今天我完成了XXX”,写在周报里也是有分量的。

但还有更多的工作,是没法写进周报里的:

  • 这个 bug 为什么之前没发现?因为上次有人改了个配置没通知我,我花了两个小时排查。
  • 这个服务为什么这么稳定?因为我半夜爬起来处理了一次故障,但没人知道。
  • 这个流程为什么这么顺?因为我把之前踩过的坑都填平了,但新人只觉得”本来就该这么顺”。
  • 为什么这台服务器从来没出过问题?因为我每周都在凌晨默默更新补丁、清理日志、监控告警。

这些工作,我管它们叫”隐形劳动”。

隐形劳动的特点是:你做了没人看见,但你不做马上就会出问题

就像家里的电一样——你从来不感谢电线,因为电”本来就该有”。但如果哪天真停电了,你才会意识到,平时习以为常的东西,原来是需要人维护的。停电的时候,你才会想起那个在背后默默维护电网的人。

运维工作就是这样。服务器正常运行是”应该的”,没人会发邮件表扬你。但如果服务器崩了,第一时间找的就是你。”服务器怎么又挂了?”——这句话大概是每个运维都听过无数遍的。

今天我做了哪些”隐形劳动”?

说起来,今天做的事情还挺多的,但如果你要我写进周报,我能写的大概只有两三条。

剩下的时间,都花在了一些”看起来没什么但其实很重要”的事情上。

第一件事:整理了一个配置文件

上午花了一个多小时,把某个服务的配置文件重新整理了一遍。为什么要整理?因为之前维护的人换了好几个,每个人的习惯不一样,导致配置文件的格式乱七八糟。有些参数重复设置了,有些参数设置了但根本没用,还有些参数你知道它存在但不知道是干什么的。

这种情况,大概每个运维都遇到过。一开始接手一个服务,看到配置文件里密密麻麻的参数,有种”这是啥这又是啥”的感觉。你不知道哪些是关键的,哪些是可以删的,哪些是”前任”留下的历史遗产。

这种事情,做了没什么”功劳”,但不做的话,以后每次排查问题都要多花时间。你得先搞清楚这个参数是干啥的,才能判断它是不是问题所在。

我花了一个多小时,把配置文件里的每一个参数都过了一遍。有些参数我知道是干啥的,有些不知道——不知道的就上网搜,搜不到的就结合日志和现象推断。最后整理出了一份”参数说明表”,以后再遇到问题,直接翻表就行,不用再一个个查了。

你说这算不算工作?当然算。但你要我写进周报,我只能写”整理配置文件若干”。一个”若干”,包含了多少心血,没人会知道。

第二件事:更新了一个文档

下午花了大半个小时,把某个操作流程的文档更新了一下。不是因为文档丢了,而是因为流程变了,但文档还是老版本。

比如之前的流程是”先启动服务A,再启动服务B,最后启动服务C”。但现在变成了”服务C要在服务A之前启动,否则会有连接问题”。这种变化,如果你不看代码、不问人,根本不知道。

是谁改的?可能是半年前某个同事。他当时改了代码,但忘记更新文档了。或者他更新了文档,但更新在了另一个地方,而你看到的是旧版本。

这种”文档和现实不一致”的问题,大概是最常见的隐形劳动。你不能怪之前的同事,因为他们的工作重点是”把事情做成”,不是”把文档写好”。写文档这种事情,做了不显眼,不做也没人催,所以很容易被无限期推迟。但这种”债务”积累多了,后来的人就要还——而且还的时候往往是在出问题的时候。

我这次更新文档,就是想把之前积压的一些”文档债务”给还掉一些。不求写得多完美,只求”文档和现实一致”,这样下次遇到问题,至少有个地方可以查。

第三件事:排查了一个莫名其妙的问题

这个问题很有意思。某台服务器的应用日志里,每隔几分钟就会有一条 WARNING。WARNING 的内容是”连接池可能会满”。

这个 WARNING 已经存在了很久,之前的人都选择忽略它——毕竟只是 WARNING,又不是 ERROR,服务也没实际受影响。告警群没炸,值班手机没响,好像一切正常。

但我今天突然想知道:这条 WARNING 是什么意思?是真的有问题,还是误报?还是说,连接池真的要满了,只是还没到临界点?

查了半天,发现是代码里有一个阈值设置得太低了。每隔几分钟触发一次,刚好卡在临界点上,所以会打印 WARNING。但因为阈值太接近临界值,稍微有点波动就会触发。

这个问题,严格来说不算”故障”,但它确实是一个隐患。如果哪天流量真的上来了,这个阈值就会成为瓶颈——连接池满了,新请求进不来,开始排队,排队时间长了超时,超时多了服务就不可用了。

链条就是这样断的。一个小问题,积累到一定程度,就会变成大问题。

我没有改代码——因为这涉及其他部门的同事,需要走流程、需要排期、需要测试——但我把这个问题记录了下来,准备下周开会的时候提一下。

这种”发现了但没解决”的工作,最让人纠结。你知道这是个问题,但你不能马上改,因为改代码需要流程、需要排期、需要其他团队的配合。但如果你不记录下来,这个问题可能就会被遗忘,直到有一天变成真正的故障。

所以我选择记下来。记在日报里,记在问题清单里,记在这篇博客里。

隐形劳动的”好处”

说了这么多”隐形劳动”的坏处,也来说说它的”好处”吧。虽然这些”好处”听起来有点阿Q,但有时候需要给自己找点心理安慰。

第一,它让你的工作”不可或缺”

隐形劳动虽然看不见,但它让你的工作变得”不可或缺”。

你可以不写代码,不做项目,但如果所有隐形劳动都不做了,系统马上就会出问题。服务器没人维护,会崩。网络没人优化,会慢。配置没人整理,会乱。文档没人更新,会过时。

这种”不可替代性”,是职场安全感的重要来源。

你可能没有牛逼的背景,没有光鲜的项目经历,但你在这个位置上,知道这个系统是怎么跑的,知道出了问题应该找谁,知道哪些地方有坑——这些”隐性知识”,不是靠学历或者证书能换来的,是靠时间堆出来的。

就像家里的老物件,你知道它怎么用,坏了怎么修。虽然不值钱,但离了你还真不行。

第二,它让你积累”隐性经验”

隐形劳动的另一面,是隐性经验。你踩过的坑、填过的雷、排查过的问题,都是宝贵的经验。

这些经验不是从书里学来的,而是从无数次”只有你知道的”时刻里积累的。比如:

  • 这个问题,之前某台机器遇到过,当时是怎么解决的?
  • 这个配置,不能用默认的,得改成多少多少才行?
  • 这个告警,看着吓人,其实可以忽略,是误报?
  • 这个时间点,不适合重启服务,因为有个定时任务在跑?

它让你在面对新问题的时候,能够快速判断”这个我之前见过”。这种判断能力,是区分”普通运维”和”资深运维”的关键。

新人在遇到问题时,需要从头排查,步步推理。老人在遇到问题时,可能一眼就能看出问题所在——因为他们见过类似的情况,知道这种”症状”通常对应哪种”病因”。

经验的积累,靠的是无数次”只有你知道的”时刻。每解决一个问题,就是给自己的”经验库”添加一条记录。

第三,它让你的周报”看起来很闲”

好吧,这个不算好处。但你要是学会用”隐形劳动”填充周报,你会发现自己突然变得”忙”了很多。

“本周完成了配置整理工作,优化了3个服务的启动流程”——听起来很厉害对吧?但实际上就是花了两个小时整理配置文件,然后更新了一下启动脚本。

“排查并解决了3个历史遗留问题”——听起来更厉害了。但实际上就是查了两个小时日志,然后发现是某个阈值设置得太低了。

周报嘛,有时候就是”文字游戏”。同样的事情,换个说法,看起来就不一样了。

当然,这不是教你”摸鱼”,而是教你”更准确地描述自己的工作”。隐形劳动也是劳动,只是它比较难以量化而已。

隐形劳动的”自我修养”

说了这么多”隐形劳动”,最后也想给自己打打气。

第一,学会记录

隐形劳动最大的问题,是做完就忘了。下次遇到同样的问题,又要重新排查。

所以,学会记录很重要。哪怕只是一个简单的笔记:”今天发现XXX服务的连接池阈值设置偏低,可能会在未来成为瓶颈”——这条记录,可能在未来某一天救你一命。

我现在有一个习惯:每天写日报的时候,会把当天排查的问题都记下来。问题现象、排查过程、解决方案,一两句话就行,不用太详细。重要的是”以后再遇到,知道去哪里找答案”。

有时候我还会把一些”临时解决方案”记下来,标注”临时”两个字。因为有些问题暂时没法根治,只能先用 workaround 顶着。这些 workaround,如果记不住,下次遇到又要花时间回忆。

第二,学会”可视化”

隐形劳动虽然不好量化,但你可以尝试让它”可视化”。

比如每次处理完一个问题,简单记录一下:问题现象、排查过程、解决方案。这样积累下来,你就有一份自己的”问题排查手册”。以后遇到类似问题,直接翻手册就行,不用从头排查。

我还尝试用”时间线”的方式记录:今天处理了一个什么问题,花了多长时间,是自己解决的还是求助别人的。这样积累下来,能清楚地看到自己的”成长轨迹”——以前一个问题要花一天,现在可能只需要一小时。

有时候我还会画一些简单的流程图,把排查问题的思路画出来。这个问题是什么症状,可能的原因有哪些,应该怎么排查,排查的顺序是什么——这些东西,画出来之后思路会清晰很多。

第三,学会接受”没人看见”

这是最重要的一点。

隐形劳动之所以叫”隐形”,就是因为它不会被所有人看见。你不能期待每次做好事都被表扬,就像你不能期待每次服务器正常运行都被发奖金。

打工人的心态要放平:做了这件事,是为了对得起自己的专业,而不是为了得到别人的认可

当然,如果你的领导是一个懂行的人,他会知道你的价值。但如果遇到一个只看周报、只看结果、不看过程的领导,那也没关系——你自己知道就行了。

价值的衡量,不应该只靠别人的评价。你做了多少事,你积累了哪些经验,你解决了哪些问题——这些,你自己心里有数。

晚上:写给同样在做”隐形劳动”的你

写到这里,已经快晚上九点了。

今天的天气有点闷,窗外的雨不知道什么时候停了。抬头看看办公室,已经没剩几个人了。隔壁工位的老王不知道什么时候走的,零食袋还留在桌上。

我今天做了什么?说起来很简单:整理了一个配置文件,更新了一个文档,排查了一个小问题。没有什么”惊天动地的大项目”,没有什么”史诗级的技术攻关”,没有什么”从0到1的创新”。

但这些”隐形劳动”,让我的系统在明天会更稳定一点,让我的文档在以后会更好用一点,让我的同事在遇到问题时会少踩一个坑。

这就是我的工作。

在上海这座城市,打工人的价值不只是写在代码里的那些,更是藏在配置文件里、泡在文档里、埋在排查过程里的这些。

隐形劳动,不丢人。

它是专业的一部分,是责任的一部分,是”对得起自己”的一部分。

明天继续加油吧。


作者:小六,一个今天做了很多”隐形劳动”但周报可能写不满三行的普通打工人

题图:Picsum Photos,授权可商用

Author:Margrop
Link:http://blog.margrop.com/post/2026-05-14-the-invisible-work-that-nobody-sees/
版权声明:本文采用 CC BY-NC-SA 3.0 CN 协议进行许可