为什么应该在 Linux 上使用命名管道 | Linux 中国
命名管道并不常用,但是它们为进程间通讯提供了一些有趣的特性。-- Sandra Henry-stocker
本文导航? 如何在 Linux 上创建命名管道
17%
? 为何要使用命名管道?57%
编译自 | http://www.networkworld.com/article/3251853/linux/why-use-named-pipes-on-linux.html
作者 | Sandra Henry-stocker
译者 | YPBlib
命名管道并不常用,但是它们为进程间通讯提供了一些有趣的特性。
估计每一位 Linux 使用者都熟悉使用 “|” 符号将数据从一个进程传输到另一个进程的操作。它使用户能简便地从一个命令输出数据到另一个命令,并筛选出想要的数据而无须写脚本进行选择、重新格式化等操作。
还有另一种管道, 虽然也叫“管道”这个名字却有着非常不同的性质。即您可能尚未使用甚至尚未知晓的——命名管道。
普通管道与命名管道的一个主要区别就是命名管道是以文件形式实实在在地存在于文件系统中的,没错,它们表现出来就是文件。但是与其它文件不同的是,命名管道文件似乎从来没有文件内容。即使用户往命名管道中写入大量数据,该文件看起来还是空的。
如何在 Linux 上创建命名管道
在我们研究这些空空如也的命名管道之前,先追根溯源来看看命名管道是如何被创建的。您应该使用名为 mkfifo 的命令来创建它们。为什么提及“FIFO”?是因为命名管道也被认为是一种 FIFO 特殊文件。术语 “FIFO” 指的是它的先进先出first-in, first-out特性。如果你将冰淇淋盛放到碟子中,然后可以品尝它,那么你执行的就是一个LIFO(后进先出last-in, first-out操作。如果你通过吸管喝奶昔,那你就在执行一个 FIFO 操作。好,接下来是一个创建命名管道的例子。
$
mkfifo
mypipe
$
ls
-
l mypipe
prw
-
r
-----.
1
shs staff
0
Jan
31
13
:
59
mypipe
注意一下特殊的文件类型标记 “p” 以及该文件大小为 0。您可以将重定向数据写入命名管道文件,而文件大小依然为 0。
$
echo
"Can you read this?"
>
mypipe
正如上面所说,敲击回车后似乎什么都没有发生(LCTT 译注:没有返回命令行提示符)。
另外再开一个终端,查看该命名管道的大小,依旧是 0:
$
ls
-
l mypipe
prw
-
r
-----.
1
shs staff
0
Jan
31
13
:
59
mypipe
也许这有违直觉,用户输入的文本已经进入该命名管道,而你仍然卡在输入端。你或者其他人应该等在输出端,并准备读取放入管道的数据。现在让我们读取看看。
$
cat
mypipe
Can
you read
this
?
一旦被读取之后,管道中的内容就没有了。
另一种研究命名管道如何工作的方式是通过将放入数据的操作置入后台来执行两个操作(将数据放入管道,而在另外一段读取它)。
$
echo
"Can you read this?"
>
mypipe
&
[
1
]
79302
$
cat
mypipe
Can
you read
this
?
[
1
]+
Done
echo
"Can you read this?"
>
mypipe
一旦管道被读取或“耗干”,该管道就清空了,尽管我们还能看见它并再次使用。可为什么要费此周折呢?
为何要使用命名管道?
命名管道很少被使用的理由似乎很充分。毕竟在 Unix 系统上,总有多种不同的方式完成同样的操作。有多种方式写文件、读文件、清空文件,尽管命名管道比它们来得更高效。
值得注意的是,命名管道的内容驻留在内存中而不是被写到硬盘上。数据内容只有在输入输出端都打开时才会传送。用户可以在管道的输出端打开之前向管道多次写入。通过使用命名管道,用户可以创建一个进程写入管道并且另外一个进程读取管道的流程,而不用关心协调二者时间上的同步。
用户可以创建一个单纯等待数据出现在管道输出端的进程,并在拿到输出数据后对其进行操作。下列命令我们采用 tail 来等待数据出现。
$
tail
-
f mypipe
一旦供给管道数据的进程结束了,我们就可以看到一些输出。
$
tail
-
f mypipe
Uranus
replicated to WCDC7
Saturn
replicated to WCDC8
Pluto
replicated to WCDC9
Server
replication operation completed
如果研究一下向命名管道写入的进程,用户也许会惊讶于它的资源消耗之少。在下面的 ps 命令输出中,唯一显著的资源消耗是虚拟内存(VSZ 那一列)。
ps
u
-
P
80038
USER PID
%
CPU
%
MEM VSZ RSS TTY STAT START TIME COMMAND
shs
80038
0.0
0.0
108488
764
pts
/
4
S
15
:
25
0
:
00
-
bash
命名管道与 Unix/Linux 系统上更常用的管道相比足以不同到拥有另一个名号,但是“管道”确实能反映出它们如何在进程间传送数据的形象,故将称其为“命名管道”还真是恰如其分。也许您在执行操作时就能从这个聪明的 Unix/Linux 特性中获益匪浅呢。
via:
http://www.networkworld.com/article/3251853/linux/why-use-named-pipes-on-linux.html
作者:
Sandra Henry-Stocker
[2]
译者:YPBlib
校对:wxy
本文由
LCTT
原创编译,Linux中国
荣誉推出LCTT 译者YPBlib ??共计翻译:1
篇贡献时间:3 天推荐文章
< 左右滑动查看相关文章 >
点击图片、输入文章 ID 或识别二维码直达
原文链接请访问“原文链接
”获得可点击的文内链接、全尺寸原图和相关文章。- 老板:为什么普工拿4500工资年后还那么多人辞职呢?原因很扎心!
- 一个是皇帝一个是国王,为什么李世民死了要下地狱,他却不用
- 农村合作医疗普及那么久以来为什么还有那么多农民不参保?
- 为什么德国士兵要用毒气来杀害犹太人?真相让人感到心酸
- 为什么日本人这么喜欢切腹自尽?原来这才是背后真正的原因
- 横扫世界的朝代为什么会迅速灭亡?这个朝代究竟有多腐败
- 三分熟和七分熟牛排相遇,你知道它们为什么不打招呼吗?
- “企业年金”你应该知道的那些事
- 慈禧太后为什么越老越风*骚?
- 为什么说祝聃这一箭,从此让天下主周朝由神变成了人呢