Linux cd 和 df 命令执行异常

这篇记录一些奇奇怪怪的命令执行异常的情况,后续有新的发现也会补录进来

情况一 /tmp 目录权限导致 按 tab 补充报错

情况描述

cd 按 tab 自动补充文件报错(普通用户

复制代码
bash: cannot create temp file for here-document: Permission denied

处理办法

因为原先修改 /tmp 目录权限忘了改回来碰到的,把 /tmp 执行权限恢复以后,就正常了。

补充信息

按照上述的情况,按 tab 是需要 /tmp 目录下创建临时文件的,但是我通过检测没看到有新增的文件出来,所以不是很清楚原因,按 tab 还不能通过 strace 追踪,就更迷糊了。

复制代码
watch -d ls -al /tmp

补全的实现种类

  • Bash补全 :Bash是Linux中最常用的shell之一,它通过名为bash-completion的包提供Tab补全功能。安装此包后,可以通过.bashrc.bash_profile文件配置补全行为。
  • Zsh补全:Zsh是另一种流行的shell,它具有更高级的补全系统,通常被认为比Bash的补全功能更加强大和灵活。

我检查了,8版本的系统上面,这两个包都存在。

复制代码
# 这个目录里面定义了对应命令的填充脚本的方式
/usr/share/bash-completion/completions
# 支持自定义的补全脚本
~/.bash_completion

Bash补全机制

  • 当用户输入命令的一部分并按下 Tab 键时,Bash 会尝试查找对应的补全脚本。
  • 补全脚本可能会使用以下机制来实现补全:
    • 静态补全:对于一些固定的选项或参数,脚本可以直接定义它们
    • 动态补全:对于一些需要实时计算的补全,如文件名或命令输出,脚本可能会执行外部命令来获取可能的补全选项
    • 模式匹配:脚本可以使用正则表达式来匹配用户输入,并提供与之匹配的补全建议
    • 上下文感知:脚本可以检查用户已经输入的内容,根据上下文提供相关的补全建议

情况二 nfs 无法访问导致 df 命令执行异常

情况描述

巡检脚本没有正常结束,复现发现是 df 命令无响应

复制代码
df -Th    # 无响应 打印文件系统类型
df -lh    # 正常   只打印本地文件系统

处理步骤

1、按经验判断,这种就是 nfs 无法访问导致的,执行 mount 看看是否存在 nfs 挂载就行了

2、如果没碰到过,可以用 strace df -Th 去看看最终在哪卡住,再分析也能找到原因

3、处理办法就是先恢复 nfs ,然后卸载重新挂载即可(自行评估影响)


情况三 df 命令卡住且无法 kill

情况描述

这个不同于上面 nfs 异常导致的 df 命令卡住,这个甚至都无法 kill 进程

分析步骤

1、登录服务器复现问题,发现df命令执行会卡住,且进程无法kill

2、strace df -Th 追踪执行情况,发现执行最终停止在 /proc/sys/fs/binfmt_misc

复制代码
# strace df -Th
... ...
stat("/sys/kernel/config", {st_mode=S_IFDIR|0755, st_size=0, ...}) = 0
stat("/", {st_mode=S_IFDIR|0755, st_size=4096, ...}) = 0
stat("/proc/sys/fs/binfmt_misc", 
^C
^C
Process 20192 detached
<detached ...>

3、上网搜索这个问题,df 执行到 /proc/sys/fs/binfmt_misc 报错

Linux 使用命令df -h 卡住 解决方法-CSDN博客

df 被 hang 住,无法查看磁盘使用情况解决 - 简书

4、重启如下服务恢复,原因不明

复制代码
systemctl restart proc-sys-fs-binfmt_misc.automount

这篇笔记里面好几处问题都没有找到原因,有了解的朋友可以评论讨论一下,谢谢!

相关推荐
Jooolin5 小时前
【Linux】虚拟机、服务器、双系统,谁才是 Ubuntu 的最佳方案?
linux·ubuntu·ai编程
K·Herbert10 小时前
最新CentOS 7 yum源失效的解决方案(2025年6月)
linux·运维·centos
别骂我h10 小时前
部署KVM虚拟化平台
linux·运维·服务器
繢鴻10 小时前
紧急救援!Ubuntu崩溃修复大赛
linux·服务器·ubuntu
showmethetime11 小时前
优化nginx参数(基本通用参数)
运维·nginx
老六ip加速器11 小时前
获取ip地址安全吗?如何获取静态ip地址隔离ip
运维·网络·智能路由器
净心净意19 小时前
浅谈DaemonSet
运维·jenkins
Apex Predator1 天前
jenkins流水线打包vue无权限
运维·jenkins
hujun86101 天前
Ubuntu安装无线网卡
linux
Johny_Zhao1 天前
CentOS Stream 8 高可用 Kuboard 部署方案
linux·网络·python·网络安全·docker·信息安全·kubernetes·云计算·shell·yum源·系统运维·kuboard