bash – 当传递引用的参数时,为什么我得到“/ bin / sh:参数列表太长”?

前端之家收集整理的这篇文章主要介绍了bash – 当传递引用的参数时,为什么我得到“/ bin / sh:参数列表太长”?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
可以将命令行传递给sh -c“多长时间? (在bash和bourne @L_301_0@)

这个限制远远低于OS(在现代Linux的情况下).

例如:

$/bin/true $(seq 1 100000)
$/bin/sh -c "/bin/true $(seq 1 100000)"
bash: /bin/sh: Argument list too long

那我该怎么规避这个问题呢?

更新

我想要注意的是,getconf在这里无法帮助(因为这不是系统限制):

$seq 1 100000 | wc -c
588895
$getconf ARG_MAX
2097152

更新#2

现在我明白了这里的意义.这不是一个shell限制,这是一个系统限制,但是对于每个参数的长度,而不是整个arglist.

$/bin/true $(seq 1 100000)
$/bin/true "$(seq 1 100000)"
bash: /bin/true: Argument list too long

谢谢CodeGnome的解释.

TL; DR

单个参数必须短于MAX_ARG_STRLEN.

分析

根据this link

And as additional limit since 2.6.23,one argument must not be longer than MAX_ARG_STRLEN (131072). This might become relevant if you generate a long call like “sh -c ‘generated with long arguments'”.

这正是OP所确定的“问题”.虽然允许的参数数量可能相当大(参见getconf ARG_MAX),当您将引用的命令传递给/ bin / sh时,shell会将引用的命令解释为单个字符串.在OP的示例中,这个单个字符串超出MAX_ARG_STRLEN限制,而不是扩展参数列表的长度.

实施具体

参数限制是具体的实现.然而,this Linux Journal article提出了几种解决方法,包括增加系统限制.这可能不直接适用于OP,但它在一般情况下仍然有用.

做其他事情

OP的问题实际上并不是一个真正的问题.这个问题正在强加一个不能解决现实问题的任意约束.

您可以使用循环轻松解决这个问题.例如,Bash 4:

for i in {1..100000}; do /bin/sh -c "/bin/true $i"; done

工作很好它肯定会很慢,因为您在每次循环中产生一个进程,但它肯定会绕过您遇到的命令行限制.

描述你的真正问题

如果一个循环不能解决您的问题,请更新该问题以描述您实际使用真正长的参数列表解决的问题.探索任意行长限制是一个学术活动,而不是Stack Overflow的主题.

猜你在找的Bash相关文章