用户名:
密 码: 记住
您当前的位置:首页 > 站长百科 > 服务器技术

新手看招:在Linux操作系统下创建锁文件

时间:2015-01-23  来源:西部数据  作者:西部数据

一、概述

Linux提供了多种特性来实现文件锁定。其中最简单的方法就是以原子操作的方式创建锁文件,所谓“原子操作”就是在创建锁文件时,系统将不允许任何其它的事情发生。这就给程序提供了一种确保它所创建的文件是唯一性的方式,且该文件不可能被其它程序在同一时刻创建。 

二、方法 

锁文件仅仅是充当一个指示器的角色,程序间需要通过相互协作来使用它们。锁文件只是建议性锁,与此对立的是强制性锁。 

为创建一个用作指示器的文件,我们使用带O_CREATE和O_EXCL标志的open系统调用。这将使我们以一个原子操作同时完成两项工作:确定文件不存在,然后创建它。 

三、实现

  1. //file : lock.c#i nclude <unistd.h>#i nclude <stdlib.h>#i nclude <stdio.h>#i nclude <fcntl.h>#i nclude <errno.h>int main(){int file_desc;int save_errno;file_desc = open("/tmp/LockFile.test", O_RDWR | O_CREAT | O_EXCL, 0444);if (file_desc < 0){save_errno = errno;printf("Open failed with error is %dn", save_errno);}else {printf("Open succeededn");}exit(EXIT_SUCCESS);} 

第一次运行程序:$ lock

输出如下:Open succeeded

我们再次运行程序:$ lock

输出如下:Open failed with error is 17

分析:第一次运行程序时,由于文件并不存在,所以执行成功,对于后续的执行,因为文件已经存在而失败了,若想程序再次执行成功,必须删除锁文件。 

在Linux系统中,通常错误号码17代表的是EEXIST,此错误用以表示一个文件已存在,错误号定义在头文件errno.h或(更常见的)它所包含的头文件中.

来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
栏目更新
栏目热门