bash – 当传递引用的参数时,为什么我得到“/ bin / sh:参数列
可以将命令行传递给sh -c“多长时间? (在bash和bourne
shell)
这个限制远远低于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:
这正是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的主题. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |