mandatory and advisory文件锁(File Lock)
http://blog.csdn.net/elfprincexu/article/details/43564425
文件锁(File Lock)是一种在特定的时间内只允许一个进程进行访问文件的机制,通过使用文件锁,可以使得多进程访问文件更加安全。
在这片文章中,我们会探索两种不同的文件锁,并且通过实际案例去了解他们的机制和不同之处。
我们会举以下两个例子来解释为什么文件锁(file lock)是必须的
- 进程A打开并且读一个文件,这个文件关于账户信息
- 进程B此时也打开并且读这个相同的文件。
- 现在,进程A改变了一条记录,并且把改变写入了这个相同的文件内
- 进程B却无法知晓这个文件已经被改变了,这个时候进程B也做了相同记录改变的事情,把它的改变也写入了这个文件内
- 现在,这个文件只包含了进程B所做的改变
为了避免这类问题的发生,我们使用文件锁(file lock)来使进程串列化。
转载文章,请注明出处: http://blog.csdn.net/elfprincexu
接下来我们介绍两种linux的文件锁(advisory尝试性文件锁和mandatory强制性文件锁)
1. Advisory Locking
尝试性文件锁需
要各个进程的无私合作,试想A进程获得一个 写 的文件锁,它开始往文件里写操作。
同时B进程,却没有去尝试获取写操作,它也同样可以进行写操作。但是很显然,B进程违反了游戏规则。我们称之为不合作进程。
尝试性文件锁,需要各个进程遵守统一规则,在文件访问时,都要礼貌的去尝试获得文件锁,然后进一步操作。
2.Mandatory Locking
强制性文件锁不需要进程的合作,强制性文件锁是通过内核强制检查文件的打开,读写操作是否符合文件锁的使用规则。
为了是强制性文件锁工作,我们必须要在文件系统上激活它,必要的操作包括
- 挂载mount文件系统,通过 “-o mand”参数选项
- 对于文件锁施加的文件,打开 set-group-id 位,并且关闭 group-execute 位。我们必须选择这种顺序,因为你一旦关闭 group-execute 位,set-group-id 就没有意义了
Linux 系统下文件锁的实际案例
为了了解linux系统下文件锁的原理,我们创建 file_lock.c 文件
- #include <stdio.h>
- #include <fcntl.h>
- int main(int argc, char **argv) {
- if (argc > 1) {
- int fd = open(argv[1], O_WRONLY);
- if(fd == -1) {
- printf("Unable to open the file\n");
- exit(1);
- }
- static struct flock lock;
- lock.l_type = F_WRLCK;
- lock.l_start = 0;
- lock.l_whence = SEEK_SET;
- lock.l_len = 0;
- lock.l_pid = getpid();
- int ret = fcntl(fd, F_SETLKW, &lock);
- printf("Return value of fcntl:%d\n",ret);
- if(ret==0) {
- while (1) {
- scanf("%c", NULL);
- }
- }
- }
- }
然后编译文件gcc
- # cc -o file_lock file_lock.c
重新挂载文件系统,当然,必须以root身份才可以挂载,
- # mount -oremount,mand /
新建两个新的文件,一个 “advisory.txt”, 另一个为 “mandatory.txt”文件,同时对“mandatory.txt” 文件开启 set-group-id 位,关闭 group-execute 位。
- # touch advisory.txt
- # touch mandatory.txt
- # chmod g+s,g-x mandatory.txt
测试:
转载文章,请注明出处: http://blog.csdn.net/elfprincexu
1. 测试 advisory.txt 文件
现在运行刚才编译 file_lock 可执行文件,
- # ./file_lock advisory.txt
这个程序会等待用户的输入,我们另开一个terminal, 并且输入以下命令:
# ls >>advisory.txt
在上面的例子中, ls 命令会把当前的名录文件信息全部写入到 advisory.txt文件中,尽管我们的file_lock程序中尝试获得write 写文件锁,但 ls 依然可以写入。
2. 测试 mandatory.txt 文件
现在运行刚才编译 file_lock 可执行文件,
- # ./file_lock mandatory.txt
这个程序会等待用户的输入,我们另开一个terminal, 并且输入以下命令:
# ls >>mandatory.txt
在上面的例子中, ls 命令会把当前的名录文件信息全部写入到 advisory.txt文件中,和上面例子不同的在于,ls 命令会等待我们的file_lock 程序退出才写入文件中,尽管ls 进程仍然是个不合作进程,但是强制性文件锁迫使它遵守规则。
mandatory and advisory文件锁(File Lock)的更多相关文章
- 启动受管服务器出现:unable to get file lock, will retry...
启动受管服务器出现:unable to get file lock, will retry... 解决方法:一.删掉Domain下的*.lok文件1. 删除edit.lok进入到domain_home ...
- <BEA-141281> <unable to get file lock, will retry ...> --reference
I ran into this error the first time I restarted Weblogic on one of my installs, the only reference ...
- 启动weblogic11g一直提示<141281> <unable to get file lock, will retry ...>
一次非正常关闭weblogic之后,再次启动时启动不成功,一直提示:<141281> <unable to get file lock, will retry ...> 解决方 ...
- 【从翻译mos文章】Weblogic AdminServer 启动fail,报错"unable to get file lock, will retry"
Weblogic AdminServer 启动fail,报错"unable to get file lock, will retry" 参考原始: Weblogic AdminSe ...
- 15-5-23 下午02时22分58秒 CST> <Info> <Management> <BEA-141281> <unable to get file lock, will retry ...>
A-141281> <unable to get file lock, will retry ...> http://gdutlzh.blog.163.com/blog/s ...
- 【记录】文件加密软件 Gilisoft File Lock Pro v11.0 中文注册版
---恢复内容开始--- GiliSoft File Lock Pro 是一款优秀的加密工具,用它可以隐藏或加密文件.文件夹.磁盘分区,而且被加密的文件不会因为被加密(忘记密码)而丢失,可算是很安全的 ...
- kafka.common.KafkaException: Failed to acquire lock on file .lock in /tmp/kafka-logs. A Kafka instance in another process or thread is using this directory.
1.刚才未启动zookeeper集群的时候,直接启动kafka脚本程序,kafka报错了,但是进程号启动起来来,再次启动出现如下所示的问题,这里先将进程号杀死,再启动脚本程序. [hadoop@sla ...
- 解决Warning Couldn't flush user prefs: java.util.prefs.BackingStoreException: Couldn't get file lock.
系统:Ubuntu 16.04 LTS 环境:vscode+java extension pack打开了一个gradle的java项目:另外,用一个terminal启动了groovysh 报错: gr ...
- Failed to acquire lock on file .lock in /tmp/kafka-logs. A Kafka instance in another process or thread is using this directory.
1. 问题现象 启动 kafka 时报错:Failed to acquire lock on file .lock in /tmp/kafka-logs. A Kafka instance in an ...
随机推荐
- img的基线对齐问题
http://blog.csdn.net/u011997156/article/details/44806523
- js 二分搜索树删除子节点
删除的节点含有左子树或者右子树,用其子树来代替成为被删除节点的父节点的子树 删除左右都有孩子的节点,找到右边子树最小的节点作为父节点
- c# 之 System.Type.GetType()与Object.GetType()与typeof比较
Object.GetType()与typeof的区别 //运算符,获得某一类型的 System.Type 对象. Type t = typeof(int); //方法,获取当前实例的类型. ; Con ...
- 【Hadoop 分布式部署 七: 使用ntp配置内网中集群机器时间同步 】
集群的时间要同步,如果时间不同步,会出现很多问题. 找一台机器做时间服务器 所有的机器与这台机器的时间进行定时的同步 比如,每日十分钟同步一次 我们这里使用 hadoop-senior.zuoyan ...
- Shiro学习笔记(二)
首先还是先搭建工程运行环境 依旧搭建的是Maven工程,如果不是Maven 也可以去网上找jar包然后导入 (我使用Maven主要是找依赖配置文件就行,我自己导jar包的时候就是很容易报错) 还是先 ...
- Bytom猜谜合约使用指南
准备工作: 1.安装全节点钱包V1.0.5以上并同步完成: 2.已经发行一种资产,发行资产的方法具体见文章<如何在Bytom上发布资产?> 3.准备好一些BTM作为手续费: 设置谜语(锁定 ...
- CommandLineParser命令行解析类
目的:方便用户在命令行使用过程中减少工作量 以前版本没这个类时,如果要运行带参数的.exe,必须在命令行中输入文件路径以及各种参数,并且输入的参数格式要与代码中的if语句判断内容格式一样,一不小心就输 ...
- 转载:linux tar 解压命令总结
把常用的tar解压命令总结下,当作备忘: tar -c: 建立压缩档案 -x:解压 -t:查看内容 -r:向压缩归档文件末尾追加文件 -u:更新原压缩包中的文件 这五个是独立的命令,压缩解压都要用到其 ...
- spring配置freemarker
<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.spr ...
- [转载]Linux中的网络接口及LO回环接口
转自:https://blog.csdn.net/weixin_39863747/article/details/80564358 Linux中的网络接口及LO回环接口 2018年06月04日 10: ...