linux多进程之间的文件锁

转载 2015年07月07日 10:14:48

原文地址>>

之前对于文件的操作通常在一个进程中完成,最近需要在两个进程中对同一个文件进行操作。故想到了文件锁。

linux下可以使用flock()函数对文件进行加锁解锁等操作。简单介绍下flock()函数:
      表头文件  #include

   定义函数  int flock(int fd,int operation);

   函数说明  flock()会依参数operation所指定的方式对参数fd所指的文件做各种锁定或解除锁定的动作。此函数只能锁定整个文件,无法锁定文件的某一区域。

   参数  operation有下列四种情况:

   LOCK_SH 建立共享锁定。多个进程可同时对同一个文件作共享锁定。

  LOCK_EX 建立互斥锁定。一个文件同时只有一个互斥锁定。

  LOCK_UN 解除文件锁定状态。

   LOCK_NB 无法建立锁定时,此操作可不被阻断,马上返回进程。通常与LOCK_SH或LOCK_EX 做OR(|)组合。

   单一文件无法同时建立共享锁定和互斥锁定,而当使用dup()或fork()时文件描述词不会继承此种锁定。

   返回值  返回0表示成功,若有错误则返回-1,错误代码存于errno。

为了更好的移植性,对于文件的打开与关闭我选择了fopen和fclose的组合,但flock的第一个参数要求的是int类型的文件描述符。这里对fopen返回的FILE类型的文件指针进行转换,转换为int型的文件描述符 (假设open函数返回的文件描述符为fd,而fopen返回的文件指针为*fp,则fd等价于fp->_fileno).


下面为两个进程的实例:

 

#include

#include

#include

#include


int main(void)

{

    FILE *fp = NULL;

    int i = 20; 

    

    if ((fp = fopen("./file_lock.test", "r+b")) == NULL) //打开文件

        printf("file open error!\n");

    if (flock(fp->_fileno, LOCK_EX) != 0) //给该文件加锁

        printf("file lock by others\n");

    while(1) //进入循环,加锁时间为20秒,打印倒计时

    {   

        printf("%d\n", i--);

        sleep(1);

        if (i == 0)

            break;

    }   

    fclose(fp); //20秒后退出,关闭文件

    flock(fp->_fileno, LOCK_UN); //文件解锁

    return 0;

 

}


 

#include

#include

#include

#include


int main(void)

{

    FILE *fp = NULL;

    int i = 0;

    

    if ((fp = fopen("./file_lock.test", "r+b")) == NULL) //打开文件

        printf("file open error!\n");

    flock(fp->_fileno, LOCK_EX); //文件加锁

    while(1) //进入循环

    {   

        printf("%d\n", i++);

        sleep(1);

    }   

    fclose(fp); //关闭文件

    flock(fp->_fileno, LOCK_UN); //释放文件锁

    return 0;

 

}


首先运行file1.c,紧接着运行file2.c(运行file1.c后20秒内要运行file2.c否则看不到现象)
现象是:file1.c执行起来以后,开始倒计时。此时运行file2.c会阻塞在加锁处。当file1.c运行20秒后关闭文件,并释放文件锁后,file2.c会开始运行。

UNIX/LINUX编程学习之文件锁、记录锁

转自: http://shihaiyang.iteye.com/blog/482656 锁定中的几个概念       文件锁定的是整个文件,而记录锁定只锁定文件的某一特定部分。UNIX 的记...
  • hcwzq
  • hcwzq
  • 2011年09月14日 08:40
  • 2182

Linux多进程之间的文件锁详解

之前对于文件的操作通常在一个进程中完成,最近需要在两个进程中对同一个文件进行操作。故想到了文件锁。linux下可以使用flock()函数对文件进行加锁解锁等操作。简单介绍下flock()函数: 1....
  • wangbaochu
  • wangbaochu
  • 2015年09月18日 15:38
  • 3985

Linux进程间通信中的文件和文件锁

Linux进程间通信中的文件和文件锁  来源:穷佐罗的Linux书 前言 使用文件进行进程间通信应该是最先学会的一种IPC方式。任何编程语言中,文件IO都是很重要的知识,所以使用文件进行...
  • Real_Myth
  • Real_Myth
  • 2016年08月12日 23:17
  • 679

Java进程互斥–FileLock

原文: http://www.cnblogs.com/XL-Liang/articles/2852998.html 系统中不同Java进程通常情况下运行于不同的Java虚拟机资源中(JVM),拥...
  • u013063153
  • u013063153
  • 2017年05月26日 11:36
  • 298

Linux: 文件锁及其实例

1.  文件锁基本概念 Linux中软件、硬件资源都是文件(一切皆文件),文件在多用户环境中是可共享的。 文件锁是用于解决资源的共享使用的一种机制:当多个用户需要共享一个文件时,Linux通常采用...
  • u014338577
  • u014338577
  • 2017年01月17日 16:56
  • 158

Linux 多进程读写文件 文件锁

目前遇到一个问题:多个进程对同一个文件进行写操作,如何避免冲突。研究了一下,做个小结。   对于多进程写文件,主要有以下两种处理方式: 1.类似于Linux日志文件服务 启动一...
  • abcd1f2
  • abcd1f2
  • 2015年07月07日 14:30
  • 1014

linux多进程之间的文件锁

之前对于文件的操作通常在一个进程中完成,最近需要在两个进程中对同一个文件进行操作。故想到了文件锁。 linux下可以使用flock()函数对文件进行加锁解锁等操作。简单介绍下flock()函数:...
  • xueyuehanzhu123
  • xueyuehanzhu123
  • 2015年05月06日 12:36
  • 258

LINUX程序(进程)在内存中的布局

翻译自: http://duartes.org/gustavo/blog/post/anatomy-of-a-program-in-memory/ 感谢作者, 尤其一些图 很漂亮,建议读者亲自读一遍英...
  • mumumuwudi
  • mumumuwudi
  • 2015年07月30日 02:00
  • 3056

linux下进程间通信

1.文件 2.文件锁 3.管道pipe和命名管道FIFO 4.信号 5.套接字 system V 6.消息队列 7.共享内存 8.信号量 posix 9.互斥量 10.条件变量 11.读写锁...
  • le119126
  • le119126
  • 2015年04月07日 10:38
  • 458

Linux C:多进程文件操作之文件锁

flock函数可以锁定文件,避免多个进程对同个文件进行操作时出现数据出错。flock的用法是在打开文件后对文件读写前调用flock函数上锁,文件操作完后flock解锁,但需注意另一个进程操作同个文件时...
  • qq_35535992
  • qq_35535992
  • 2016年10月19日 21:07
  • 1461
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:linux多进程之间的文件锁
举报原因:
原因补充:

(最多只允许输入30个字)