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

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

相关推荐
qq_19697617几秒前
硬核教程:用Gemini境像站构建端到端自动化办公工作流,告别重复操作(国内免费镜像实测)
运维·自动化
小此方1 分钟前
Re:Linux系统篇(二十)进程篇·五:深入理解 Linux 进程优先级:从底层逻辑到实战修改
linux·运维·服务器
路溪非溪2 分钟前
Linux下物理总线驱动模型之SDIO驱动框架
linux·驱动开发
深圳市九鼎创展科技2 分钟前
九鼎创展 X7110 开发板(JH7110):国产 RISC-V 多媒体平台全解析
大数据·linux·人工智能·嵌入式硬件·ubuntu·risc-v
流浪0015 分钟前
Linux篇(八) Make 与 Makefile 超详细入门教程|从零基础到手写自动化编译
linux·运维·自动化
爱莉希雅&&&10 分钟前
Redis哨兵模式和主从复制和集群模式搭建与扩容缩容
linux·redis·缓存·集群·哨兵·数据库同步
j_xxx404_10 分钟前
Linux线程:从内存分页机制(Page Table/TLB/Page Fault)彻底读懂 Linux 线程本质
linux·运维·服务器·开发语言·c++·人工智能·ai
不做无法实现的梦~13 分钟前
怎么实现codex控制嘉立创EDA绘制原理图
linux
青梅橘子皮18 分钟前
Linux---冯诺伊曼体系结构,操作系统概况
java·linux·运维
I_am_Damon20 分钟前
安全警告:该网站的安全证书存在问题
运维·服务器·安全