FIFO,又稱作命名管道(named pipe),它是Linux系統中用於進程間通信的一種方法。
FIFO和pipe的區別在於:
FIFO在文件系統中有對應的inode,可以通過ls命令查看。
sh-3.2# ls -lhF ./fifo_file
100 prwxrwxrwx 1 root root 0 Jan 1 1970 ./fifo_file|
sh-3.2#
正因為它有一個名字,所以任何進程都可以訪問它,所以FIFO可用於任意兩個進程之間的通信。
pipe沒有名字,在現有文件系統中無法查看到它的存在。
它只能用於父子進程、兄弟進程等具有血緣關系的進程間通信。
創建FIFO的方法如下:
1. 調用umask系統調用來設定創建文件的權限,
#include <sys/types.h>
#include <sys/stat/h>
mode_t umask(mode_t mask);
2. 調用unlink系統調用先刪除已經存在的fifo,
#include <unistd.h>
int unlink(const char *pathname);
3. 調用mkfifo庫函數去創建一個FIFO文件,
#include <sys/types.h>
#include <sys/stat.h>
int mkfifo(const char *pathname, mode_t mode);
或者可以通過調用mknod系統調用並且指定參數mode為S_IFIFO也可以創建一個FIFO文件,
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
int mknod(const char *pathname, mode_t mode, dev_t dev);
注意:
1. 使用FIFO進行通信,每次傳輸的數據要限定在PIPE_BUF之內;
2. 對於FIFO的訪問就像訪問正規文件(regular file)一樣,可以使用open/read/write/close等系統調用進行訪問。
使用FIFO的應用有:
1. 單純的生產者/消費者問題,一個進程讀數據,一個進程寫數據;
2. 實現client/server架構的程序,客戶端和服務器端通過FIFO進行通信。
也許還有很多其它的應用場景,待遇到時再具體問題具體分析。
關於FIFO,可能還有很多細節問題,再看吧!