python中给程序加锁之fcntl模块的使用

简介:

python 中给文件加锁——fcntl模块

import fcntl


打开一个文件

f = open('./test') ##当前目录下test文件要先存在,如果不存在会报错。

对该文件加密:

fcntl.flock(f,fcntl.LOCK_EX)

这样就对文件test加锁了,如果有其他进程对test文件加锁,则不能成功,会被阻塞,但不会退出程序。

解锁:fcntl.flock(f,fcntl.LOCK_UN)



fcntl模块:

flock() : flock(f, operation)

  operation : 包括:

    fcntl.LOCK_UN 解锁

    fcntl.LOCK_EX  排他锁

fcntl.LOCK_SH  共享锁

fcntl.LOCK_NB  非阻塞锁

LOCK_SH 共享锁:所有进程没有写访问权限,即使是加锁进程也没有。所有进程有读访问权限。

LOCK_EX 排他锁:除加锁进程外其他进程没有对已加锁文件读写访问权限。

LOCK_NB 非阻塞锁:

    如果指定此参数,函数不能获得文件锁就立即返回,否则,函数会等待获得文件锁。LOCK_NB可以同LOCK_SH或LOCK_NB进行按位或(|)运算操作。 fcnt.flock(f,fcntl.LOCK_EX|fcntl.LOCK_NB)




下面是一个简单的例子:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
#!/usr/bin/python
#coding:utf8
 
import  os
import  sys
import  time
import  fcntl  #导入模块
 
class  FLOCK(ojbect):
     def  __init__( self ,name):
         """
         :param name: 文件名
         """
 
         self .fobj  =  open (name, 'w' )
         self .fd  =  self .fobj.fileno()
 
     def  lock( self ):
         try :
             fcntl.lockf(sefl.fd,fcntl.LOCK_EX|fcntl.LOCK_NB)  #给文件加锁,使用了fcntl.LOCK_NB
             print  '给文件加锁,稍等 ... ...'
             time.sleep( 20 )
             return  True
         except :
             print  '文件加锁,无法执行,请稍后运行。'
             retrun  False
 
     def  unlock( self ):
         self .fobj.close()
         print  '已解锁'
 
if  __name__  = =  "__main__" :
     print  sys.argv[ 1 ]
     locker  =  FLOCK(sys.argv[ 1 ])
     =  locker.lock()
     if  a:
         print  '文件已加锁'
     else :
         print  '无法执行,程序已锁定,请稍等'

执行结果:

# python suo.py test

test

file lock please waiting.....  (在等待期间,在另一个终端,运行此程序会有下面的结果)

 文件已加锁


# python suo.py test

test

file no lock please check file...

无法执行,程序已锁定,请稍等 


##程序中使用了fcntl.LOCK_NB 所以程序会直接退出,没有等待。



本文转自 ZhouLS 51CTO博客,原文链接:http://blog.51cto.com/zhou123/1650185

相关文章
|
1天前
|
存储 索引 Python
Python从入门到精通——1.3.1练习编写简单程序
Python从入门到精通——1.3.1练习编写简单程序
|
2天前
|
开发者 Python
Python的os模块详解
Python的os模块详解
14 0
|
5天前
|
数据挖掘 API 数据安全/隐私保护
python请求模块requests如何添加代理ip
python请求模块requests如何添加代理ip
|
6天前
|
数据采集 JavaScript 前端开发
使用Python打造爬虫程序之破茧而出:Python爬虫遭遇反爬虫机制及应对策略
【4月更文挑战第19天】本文探讨了Python爬虫应对反爬虫机制的策略。常见的反爬虫机制包括User-Agent检测、IP限制、动态加载内容、验证码验证和Cookie跟踪。应对策略包括设置合理User-Agent、使用代理IP、处理动态加载内容、验证码识别及维护Cookie。此外,还提到高级策略如降低请求频率、模拟人类行为、分布式爬虫和学习网站规则。开发者需不断学习新策略,同时遵守规则和法律法规,确保爬虫的稳定性和合法性。
|
7天前
|
测试技术 Python
Python 有趣的模块之pynupt——通过pynput控制鼠标和键盘
Python 有趣的模块之pynupt——通过pynput控制鼠标和键盘
|
7天前
|
Serverless 开发者 Python
《Python 简易速速上手小册》第3章:Python 的函数和模块(2024 最新版)
《Python 简易速速上手小册》第3章:Python 的函数和模块(2024 最新版)
39 1
|
7天前
|
SQL 安全 Go
如何在 Python 中进行 Web 应用程序的安全性管理,例如防止 SQL 注入?
在Python Web开发中,确保应用安全至关重要,主要防范SQL注入、XSS和CSRF攻击。措施包括:使用参数化查询或ORM防止SQL注入;过滤与转义用户输入抵御XSS;添加CSRF令牌抵挡CSRF;启用HTTPS保障数据传输安全;实现强身份验证和授权系统;智能处理错误信息;定期更新及审计以修复漏洞;严格输入验证;并培训开发者提升安全意识。持续关注和改进是保证安全的关键。
16 0
|
9天前
|
Python
python学习-函数模块,数据结构,字符串和列表(下)
python学习-函数模块,数据结构,字符串和列表
49 0
|
10天前
|
Python
python学习14-模块与包
python学习14-模块与包
|
2月前
|
Python
使用PyInstaller将Python应用程序打包成EXE文件
使用PyInstaller将Python应用程序打包成EXE文件
160 0

热门文章

最新文章