强制性锁和建议性锁的区别

前言:

        所谓建议性锁就是假定人们都会遵守某些规则去干一件事。例如,人与车看到红灯都会停,而看到绿灯才会继续走,我们可以称红绿等为建议锁。但这只是一种规则而已,你并不防止某些人强闯红灯。而强制性锁是你想闯红灯也闯不了。 

       建议性锁只在cooperating processes之间才有用,对cooperating process的理解是最重要的,它指的是会影响其它进程的进程或被别的进程所影响的进程,举两个例子:(1)我们可以同时在两个窗口中运行同一个命令,对同一个文件进行操作,那么这两个进程就是cooperating processes;(2)cat file| sort,那么cat和sort产生的进程就是使用了pipe的cooperating processes。

------------------------------------------------------------------------------------------------------------------------------------------------------------------

APUE中的表述:

        fcntl有强大的功能,它能够复制一个现有的描述符,获得/设置文件描述符标记,获得/设置文件状态标记,获得/设置异步I/O所有权,获得/设置纪录锁。

        当多个用户共同使用,操作一个文件的情况,Linux通常采用的方法就是给文件上锁,来避免共享资源产生竞争的状态。

fcntl文件锁有两种类型:建议性锁和强制性锁

  • 建议性锁是这样规定的:每个使用上锁文件的进程都要检查是否有锁存在,当然还得尊重已有的锁。内核和系统总体上都坚持不使用建议性锁,它们依靠程序员遵守这个规定。(Linux默认是采用建议性锁)

  • 强制性锁是由内核执行的。当文件被上锁来进行写入操作时,在锁定该文件的进程释放该锁之前,内核会阻止任何对该文件的读或写访问,每次读或写访问都得检查锁是否存在。

        使用fcntl文件锁进行I/O操作必须小心:进程在开始任何I/O操作前如何去处理锁,在对文件解锁前如何完成所有的操作,是必须考虑的。如果在设置锁之前打开文件,或者读取该锁之后关闭文件,另一个进程就可能在上锁/解锁操作和打开/关闭操作之间的几分之一秒内访问该文件。当一个进程对文件加锁后,无论它是否释放所加的锁,只要文件关闭,内核都会自动释放加在文件上的建议性锁(这也是建议性锁和强制性锁的最大区别), 所以不要想设置建议性锁来达到永久不让别的进程访问文件的目的(强制性锁才可以)^_^;强制性锁则对所有进程起作用。

在Linux中实现上锁的函数有lock()和fcntl()。

  • lock()用于对文件施加建议性锁

  • fcntl()用于对文件施加建议性锁和强制性锁都行。同时还可以对文件某一条纪录进行上锁,也就是记录锁。

例子:

  • 例1,我有几个进程(不一定有亲缘关系)都通过fctnl机制来操作文件,这个就叫一致的方法。但是,如果同时,又有个流氓进程,管它3721,冲上去,open, write。
    这时候那几个进程fcntl对这种方式无能为力,这样就叫不一致。文件最后的状态就不定了。
    正因为这种锁约束不了其它的访问方式,所以叫建议行锁。强制性锁需要内核支持的,对read, write, open都会检查锁。

  • 例2,所谓建议性锁就是假定人们都会遵守某些规则去干一件事。例如,人与车看到红灯都会停,而看到绿灯才会继续走,我们可以称红绿等为建议锁。但这只是一种规则而已,你并不防止某些人强闯红灯。而强制性锁是你想闯红灯也闯不了。

如何在Linux系统上使用强制性锁呢?

要想让linux支持强制性锁,不但在mount的时候需要加上-o mand(APUE中文版有误,它写成了_omand), 而且对要加锁的文件也需要设置相关权限 (turn on set-group-ID and turn off group-execute)。

------------------------------------------------------------------------------------------------------------------------------------------------------------------

 

  个人理解:

       fcntl使用三个参数 F_SETLK /F_SETLKW,F_UNLCK和F_GETLK,来分别要求、释放、测试record locks,record locks是对文件一部分而不是整个文件的锁,这种细致的控制使得进程更好地协作以共享文件资源。fcntl能够用于读取锁和写入锁,read lock也叫shared lock(共享锁),因为多个cooperating process能够在文件的同一部分建立读取锁;write lock被称为exclusive lock(排斥锁),因为任何时刻只能有一个cooperating process在文件的某部分上建立写入锁。如果cooperating processes对文件进行操作,那么它们可以同时对文件加read lock,在一个cooperating process加write lock之前,必须释放别的cooperating process加在该文件的read lock和wrtie lock,也就是说,对于文件只能有一个write lock存在,read lock和wrtie lock不能共存。

 

建议性锁 (针对合作进程而言的)

建议性锁,就是一种软弱的锁——必须要在参与所有共享数据操作的所有进程之间都遵守这样神圣的约定的前提,建议性的锁才发挥作用,而劝告性的建议锁对于协作进程来说已经足够了!!但是,有读写权限的进程,不遵守这个约定,就会把这一切都搞杂,约定对于他们来说,不好用。但建议性锁也有他的优势:相对与强制性锁,性能好一些。个人理解。

 

协作进程(cooperating processes):如果每个进程所使用的函数都以一致的方法处理记录锁,互斥锁等,则这些进程被称为协作进程。

 

强制性锁

         这个就好理解了,一旦加强制性锁(读锁或写锁),在“可以共享读,但不能共享写”的原则下,其他进程就被限制了,就不会出现不一致了。

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
LG Velvet 是一款由韩国LG公司推出的智能手机。强制BL(Bootloader)是指绕过手机操作系统启动过程中的启动程序,从而能够进行一些自定义、修改系统设置或刷入定制的第三方操作系统等操作。 首先,需要提醒的是,强制BL有一定的风险,可能导致手机变砖或失去保修等问题。因此,在进行此操作前,请仔细考虑风险并做好备份。 要强制LG Velvet的BL,可以按照以下步骤: 1. 首先,确保你的手机电量充足,以免在操作过程中意外断电导致出现不可预料的问题。 2. 在电脑上下载并安装相应的解软件,例如LG Bridge等。 3. 进入手机的开发者选项。一般情况下,可以在设置-关于手机-软件信息中连续点击"版本号"选项七次以上,即可激活开发者选项。 4. 在开发者选项中,找到并打开"OEM解"选项。将其打开后,手机将会提示解的风险。 5. 将手机连接到电脑上,并打开之前安装的解软件。 6. 在解软件中,按照指示进行相应的解操作(具体的操作步骤可能因软件版本而有所不同)。 7. 解完成后,手机将会重新启动。 需要注意的是,强制BL会使您的手机失去官方支持,可能无法获取后续的系统更新,也可能对手机的安全性产生一定的影响。对于没有专业知识的用户来说,建议谨慎操作并尽量避免此类行为。如有必要,建议先咨询专业人士的意见。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值