FIFO管道是一種文件類型,在Linux上創建FIFO非常容易,FIFO文件固有管道的特性,但和pipe管道有一定的區別,下面小編將針對FIFO管道的創建和使用做個詳細介紹,以便你有個詳細的了解。
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進行通信。
上面就是Linux創建FIFO管道的方法介紹了,本文除了介紹了FIFO管道的創建外,還稍微介紹了下FIFO的使用及其注意事項,在使用的時候需特別注意。