zoukankan      html  css  js  c++  java
  • linux文件锁的应用,POSIX,unix标准,linux标准

    1. perl,flock加锁。java也能加锁。

    2. 先创建文件并打开,才能加锁(写打开?)。

    3. 可以用于判断进程是否一直在运行(用另一进程判断),如果锁一直在,则进程在;锁不在,则原进程或意外中断。

    4. 可以用于互斥,使得同一时间只有一个脚本运行(一般使用非阻塞模式)。

    5. 多进程系统中,文件锁可以用于进程互斥。

    6. 为了避免对同一文件读写冲突,在写的时候可以写入另一个文件如**.tmp,然后使用命令`mv **.tmp **`,因为linux保证了mv操作是原子性,所以读打开的时候会打开最新的文件。

    7. 不用语言使用文件锁函数时无效的问题。perl加锁了,java仍然可以进行锁操作。

    perl和python加锁使用的是flock锁(古老一些),而java的FileLock加锁使用的是POSIX锁(新一些),所以perl加锁后,python不能再加锁了,但是java依然可以加锁。

    http://blog.csdn.net/mr_mumu/article/details/50828988

    查看/proc/locks可以知道对文件的加锁,在使用perl和java分别对同一个文件加锁之后,显示如下:

    $ cat /proc/locks
    1: POSIX ADVISORY WRITE 37898 08:01:803341 0 EOF 2: POSIX ADVISORY WRITE 2529 08:01:920589 0 0 3: POSIX ADVISORY READ 2502 08:01:920587 128 128 4: POSIX ADVISORY READ 2502 08:01:920585 1073741826 1073742335 5: POSIX ADVISORY WRITE 885 00:12:543 0 EOF 6: FLOCK ADVISORY WRITE 914 00:12:520 0 EOF 7: FLOCK ADVISORY WRITE 37934 08:01:803341 0 EOF 8: POSIX ADVISORY WRITE 84170 00:12:556 0 EOF 9: FLOCK ADVISORY WRITE 77257 00:15:4 0 EOF 10: POSIX ADVISORY READ 2514 08:01:920587 128 128 11: POSIX ADVISORY READ 2514 08:01:920585 1073741826 1073742335 12: POSIX ADVISORY READ 2508 08:01:920587 128 128 13: POSIX ADVISORY READ 2508 08:01:920585 1073741826 1073742335 14: FLOCK ADVISORY WRITE 1213 00:12:254 0 EOF 15: POSIX ADVISORY WRITE 1037 00:12:521 0 EOF

    第一列表示锁的类型,有FLOCK和POSIX,第二列表示都是建议性锁(建议性锁的意思是,不具备强制性。一个进程使用flock将文件锁住,另一个进程可以直接操作正在被锁的文件修改文件中的数据,原因在于flock只是用于检测文件是否被加锁,针对文件已经被加锁,另一个进程写入数据的情况,内核不会阻止这个进程的写入操作,也就是建议性锁的内核处理策略。)

    第四列表示使用这个锁的进程。在上面的输出中,37898是java进程的pid,使用的是POSIX锁,而perl进程的pid是37934,使用了FLOCK锁。所以没有约束对方。

    注意的是,父进程设置的锁,子进程不会继承。这也符合锁的定义,如果继承了,则会打破锁的功能,两个进程同时操作文件。exec()函数会继承打开的锁。

    8. linux系统建议性锁和强制性锁。

    http://www.linuxidc.com/Linux/2016-11/137614.htm

    http://search.cpan.org/~jtt/File-FcntlLock-0.14/lib/File/FcntlLock.pm

    开启强制性锁,需要对特定文件打开 设置-组-ID位,关闭 组-执行位。

    9. POSIX标准

    可移植操作系统接口(英语:Portable Operating System Interface,缩写为POSIX),是IEEE为要在各种UNIX操作系统上运行软件,而定义API的一系列互相关联的标准的总称,其正式称呼为IEEE Std 1003,而国际标准名称为ISO/IEC 9945。
    此标准源于一个大约开始于1985年的项目。POSIX这个名称是由理查德·斯托曼应IEEE的要求而提议的一个易于记忆的名称。它基本上是Portable Operating System Interface(可移植操作系统接口)的缩写,而X则表明其对Unix API的传承。

    https://stackoverflow.com/questions/1780599/i-never-really-understood-what-is-posix

    https://www.zhihu.com/question/21048638

    比较详细的说明参考:http://blog.csdn.net/u012724405/article/details/20306379

    Unix 1969 年诞生于 AT&T 贝尔实验室,并在 1973 年使用 C 语言进行了重写,从此就具有了很好的可移植性。但是当 AT&T 在 1984 年由于分拆而得以进入计算机领域的市场之后,却引发了 Unix 业界的一场大战。当时最为主要的两个版本是 AT&T 的 System V 和伯克利的 BSD。二者在技术方面(例如终端)和文化方面都存在很多分歧,导致应用程序很难在不同的系统上平滑地进行移植,为了解决这个问题,IEEE (Institute of Electrical and Electronic Engineers)的 1003 委员会着手开发了一系列标准,这就是后来的 POSIX(Portable Operating System Interface for UNIX)标准。其目的是为那些兼容各种 UNIX 变种的应用程序制定应用程序编程接口(API)规范,从而确保这些应用程序的兼容性。这些标准后来被 ISO/IEC 采纳,成为 ISO/IEC 9945 标准。

    POSIX 在 15 份不同的文档中对操作系统与用户软件的接口进行了规范,主要内容包括3个部分:

    • POSIX 系统调用
    • POSIX 命令和工具
    • POSIX 兼容测试

    同时还提供了一套 POSIX 兼容性测试工具,称为 PCTS(POSIX Conformance Test Suite)。

    后来 POSIX 标准又进行了很多扩充,主要包括:

    • POSIX.1,核心服务:主要集成了 ANSI C 标准,包括进程创建和控制、信号、浮点异常、段错误、非法指令、总线错误、定时器、文件和目录操作、管道、C 标准库、I/O 端口和控制
    • POSIX.1b,实时扩展:包括优先级调度、实时信号、时钟和定时器、信号量、消息传递、共享内存、异步和同步 I/O、内存锁
    • POSIX.1c,线程扩展:包括线程创建和控制、线程调度、线程同步、信号处理

    POSIX 最初的设计目标是为 Unix System V 和 BSD Unix 等 Unix 系统上的特性制定规范,使其可以实现更好的可移植性。但是很多其他系统都也兼容POSIX 标准。例如,微软的 Windows NT 就兼容 POSIX 标准的实时部分(POSIX.1b),而 RTOS(LynxOS real-time operating system)也与 POSIX 标准兼容。Windows 上可以通过安装 Windows 的 Services for UNIX 或 Cygwin 来增强对 POSIX 标准的兼容度。

    遵循这个标准的好处是软件可以跨平台。
    linux/unix的大部分系统调用在posix标准中进行了重新实现,虽然接口都一样,但是包含的头文件有些区别。不同的操作系统对标准进行不同的方式实现,但是既然是标准就要求函数的名称、参数列表、返回值以及执行效果必须是相同的。

    10. unix标准

    单一UNIX规范(英语:Single UNIX Specification,缩写为SUS),它是一套UNIX系统的统一规格书。扩充了POSIX标准,定义了标准UNIX操作系统。

    11. linux标准

    Linux标准规范(英语:Linux Standard Base,缩写为 LSB)是一个在Linux基金会结构下对Linux发行版的联合项目,其目标使Linux操作系统匹配软件系统架构,或文件系统架构标准的规范及标准。LSB基于POSIX,统一UNIX规范及其他开放标准,在某些领域扩展它们。
  • 相关阅读:
    RHEL7基本命令
    RHEL7VIM编辑器
    hello world
    配置mysql允许远程连接
    c#利用HttpWebRequest获取网页源代码
    C++局部变量详解(笔试题)
    c语言文件常用的操作
    Cocos2dx v3.1 初识(一)
    创建钩子(Hook)
    Extjs4.2.0 Form 的使用
  • 原文地址:https://www.cnblogs.com/starRebel/p/6898160.html
Copyright © 2011-2022 走看看