1.概念
系统中只允许一个该名字的进程存在(进程间互斥),借助fcntl函数来实现锁机制。操作文件的进程没有获得锁时,可以打开,但无法执行read、write操作。
2.fcntl函数
#include <unistd.h>
#include <fcntl.h>
int fcntl(int fd, int cmd, ... /* arg */ );
作用:获取、设置文件访问控制属性。
参数:fd,文件描述符;
cmd,具体操作命令。F_SETLK(struct flock *,设置文件锁-->trylock),F_SETLKW(struct flock *,设置文件锁-->lock,W-->wait)和F_GETLK(struct flock *,获取文件锁)用于获取,释放和测试记录锁(也称为字节范围,文件段或文件区域锁)的存在。
第三个参数,
struct flock {
...
short l_type; /* Type of lock(锁的类型): F_RDLCK,
F_WRLCK, F_UNLCK */
short l_whence; /* How to interpret l_start(偏移位置):
SEEK_SET, SEEK_CUR, SEEK_END */
off_t l_start; /* Starting offset for lock(起始偏移) */
off_t l_len; /* Number of bytes to lock (长度,0表示整个文件加锁)*/
pid_t l_pid; /* PID of process blocking our lock(持有该锁的进程ID)
(set by F_GETLK and F_OFD_GETLK) */
...
};
3.实例
--利用文件锁,操作一个文件描述符,在运行该进程时再另外开启一个终端运行该进程,检验文件锁是否起作用,阻止另一个进程操作。(待继续理解文件机制???)
#include<stdio.h>
#include<unistd.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<fcntl.h>
#include<stdlib.h>
#define _FILE_NAME_ "/home/chen/temp.lock"
int main()
{
int fd = open(_FILE_NAME_,O_RDWR|O_CREAT,0666);
if(fd < 0)
{
perror("open err\n");
return -1;
}
struct flock lk;
lk.l_type = F_WRLCK;
lk.l_whence = SEEK_SET;
lk.l_start = 0;
lk.l_len = 0;
if(fcntl(fd,F_SETFL,&lk) < 0)
{
perror("get lock err\n");
exit(1);
}
//核心逻辑,运行进程,如果在该进程运行的时候再重复运行,会报错
while (1)
{
printf("I am a process, and I am alive!\n");
sleep(1);
}
return 0;
}