所以我之前问了一个问题,为ping添加了一个前缀.(我的最后一个问题)给我留下了以下几行:
ping 8.8.8.8 | while read line; do echo "$(date): $line"; done | grep time=
这很有效.我只有一个问题,我无法将其保存在文件中.我尝试了一个简单的重定向,如下所示:
ping 8.8.8.8 | while read line; do echo "$(date): $line"; done | grep time= >> googleping
但没有任何东西被保存在文件中......
然后我尝试了这个:
ping 8.8.8.8 | while read line; do echo "$(date): $line"; done | grep time= | tee -a googleping
用tee将它打印在屏幕上并将其保存在文件中......再也没有运气了.
(但尝试过echo hello | tee -a googleping
并且工作正常...)
所以,然后我尝试了另一个while循环,如下所示:
ping 8.8.8.8 | while read line; do echo "$(date): $line"; done | grep time= | while read line; do echo $line; echo $line >> googleping; done
再没有运气了......
那么一条线可以有多少管道和重定向?如果是这样的话,当我无法访问谷歌时,我仍然可以实现我的记录目标(我只是测试它grep time=
以获得附加的输出,并且将用于grep -v time=
获得所有没有时间的行,无论是什么错误可能是)
所以要补充的是,最后我想在mac终端中进行,但是我在ubuntu服务器和mac上尝试过,并且都不能使用上面描述的任何方法.
我希望有一个人可以帮助我!
hek2mgl的答案解释了您的特定问题与管道数量无关.
但是要回答你标题中的问题("我可以使用多少管道有限制吗?"),是的,对打开的文件描述符有一个限制,但在当前系统上,它在实践中非常大(几千).AFAIU,POSIX保证一个小的限制(可能只有20个).您的系统可能每个进程都有一个文件描述符限制,另一个文件描述符限制系统范围....
要设置或查询每个进程文件描述符限制,可以使用了setrlimit(2)和getrlimit
与RLIMIT_NOFILE
(和ulimit
的内置bash
或limit
的内置zsh
,在交互的shell).您还可以/proc/self/limits
在Linux上阅读(有关伪文件的更多信息,请参阅proc(5)/proc/
).在我的Linux Debian系统上,每个进程有65536个最大文件描述符.
IIRC,/proc/sys/fs/file-max
给出打开的文件描述符的最大数量.在我的系统上,它现在是1632058.
当你达到了文件描述符限制时,pipe(2)系统调用(例如你的shell为带有....的管道完成|
)将失败:
EMFILE
该过程正在使用太多文件描述符.
ENFILE
已达到系统对打开文件总数的限制.
而open(2)也可能因磁盘配额过剩而失败...
EDQUOT
其中O_CREAT
规定,则该文件不存在,并且在文件系统的磁盘块或inode的用户的配额已经用完.
另请参阅pipe(7)并阅读高级Linux编程 ; 当用C编程时,你应该适当而明智地使用fflush(3).