ar linux 删除模块_Linux常见系统故障:“Argument list too long”错误与解决方法

一次性付费进群,长期免费索取教程,没有付费教程。

进微信群回复公众号:微信群;QQ群:460500587

 教程列表  见微信公众号底部菜单 |   本文底部有推荐书籍 

f52ac15861cae1bdcd8cb7b1852bcc6d.png

微信公众号:计算机与网络安全

ID:Computer-network

作为一名运维人员,对这个错误并不陌生,在执行rm、cp、mv等命令时,如果要操作的文件数很多,可能会使用通配符批量处理大量文件,这时就可能会出现“Argument list too long”这个问题。

1、错误现象

这是一台MySQL数据库服务器,在系统中运行了很多定时任务,某天通过如下crontab命令又添加了一个计划任务,退出时系统报错。

#crontab -e

编辑完成后,保存退出,就出现如图1所示的错误。

96961cfbd769a9fa8e9c8752ba77d5dc.png

图1  crontab命令编辑完成后发生的错误

2、解决思路

根据上面的报错信息,基本判定是磁盘空间满了,那么首先从检查服务器的磁盘空间开始,先检查/tmp磁盘空间,然后检查根分区的磁盘空间,最后检查系统其他分区的磁盘空间。

3、问题排查

通过df命令查看了这个服务器上所有磁盘分区的情况,/tmp分区空间还有很多,根分区也还有很大剩余空间,都不存在问题,最后发现是/var磁盘分区空间已经达到100%了。至此已经定位了问题,是/var磁盘空间爆满导致的,因为crontab会在保存时将文件信息写到/var目录下,然而这个磁盘没有空间了,所以报错也是理所当然了。

4、解决问题

接着通过“du -sh”命令检查/var目录下所有文件或目录的大小,发现/var/spool/clientmqueue目录占用了/var整个分区大小的90%,那么/var/spool/clientmqueue目录下的文件都是怎么产生的呢,能否删除?下面简单介绍下/var/spool/clientmqueue目录的文件是怎么生成的。

打开/var/spool/clientmqueue目录下的一些文件,发现都是一些邮件信息,邮件内容大多是关于Cron Daemon的,其实/var/spool/clientmqueue就是一个邮件暂存的目录。Linux服务器在默认情况下会发一些邮件,比如当cron执行的程序有输出内容时,就会发送邮件信息到执行cron进程的用户。在发送邮件时,系统首先会把邮件复制到/var/spool/clientmqueue目录下,然后等待MTA(Mail Transfer Agent)程序来处理。而MTA主要的功能是把这个目录中的邮件转移到/var/spool/mqueue目录下,然后再通过sendmail服务发送到真正的目的地。检查这个服务器的sendmail服务,发现其没有开启,这样/var/spool/clientmqueue目录非常大的原因就找到了:没有发送邮件的客户端服务,所有邮件就都堆积在这个目录下了。

在确认完这些邮件内容都没用后,切换到/var/spool/clientmqueue目录下,执行rm命令删除所有的文件时,出现如下错误:

[root@localhost clientmqueue]# rm *

/bin/rm: argument list too long

此时出现了文首谈到的问题。

当在Linux系统中试图传递太多参数给一个系统命令时,就会出现“Argument list too long”错误。这是Linux系统一直以来都有的限制。查看这个限制可以通过命令“getconf ARG_MAX”来实现,如图2所示。

64f588872794a8dd5df4140a21fbbd7f.png

图2  查看CentOS 6.3版本的Linux系统传递参数限制

这是CentOS 6.x版本的一个最大值,而在CentOS 5.x中,这个值相对较小,如图3所示。

99fef6d5cbdc9ed95988c258b48202d2.png

图3  查看CentOS 5.8版本的Linux系统传递参数限制

所以这个问题更多的是发生在Linux低版本中。

知道了产生问题的原因,解决方法就很多了,这里提供四种解决此问题的方法,下面分别进行介绍。

(1)手动把命令行参数分成较小的部分

例如:

rm [a-n]* -rf

rm [o-z]* -rf

这种方法最简单,但是相对较低级,因为必须知道怎么平均分割文件,同时对于文件数目极多的情况,需要输入很多次命令。

(2)使用find命令删除

基本原理是通过find命令筛选文件列表,把符合要求的文件传递给一系列命令。这种方法是最简洁的,也是最有效的。

例如:

find /var/spool/clientmqueue -type f -print -exec rm -f {} \;

但是这种方法也有缺点,需要遍历所有文件,因而在文件数量极多时比较耗时。

(3)通过shell脚本

这种方法是通过编写一个shell脚本,然后通过循序语句实现,与find方法类似。

例如,可以编写如下脚本:

#!/bin/bash# 设定需要删除的文件夹RM_DIR='ar/spool/clientmqueue'cd $RM_DIRfor I in `ls`dorm -f $Idone

(4)重新编译Linux内核

这种方法需要手动增加内核中分配给命令行参数的页数,打开kernel source下面的include/linux/binfmts.h文件,找到如下行:

# define MAX_ARG_PAGES 32

将“32”改为更大的值,例如64或128,然后重新编译内核。

此种方法永久有效,可以彻底解决问题,但是比较复杂,推荐给高级用户使用,没有Linux经验的用户不建议用这种方法。

微信公众号:计算机与网络安全

ID:Computer-network

【推荐书籍】

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值