ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

PHP实现对文件锁进行加锁

2021-11-27 23:58:49  阅读:167  来源: 互联网

标签:fp 文件 加锁 log writable file 日志 PHP php


在项目中,一般都用到日志,如数据库查询日志、访问日志、对外接口请求返回参数日志,在处理日志时简单的写法如下

1

2

3

4

5

6

7

$file = 'log.txt';

$fp = fopen($file, 'a+');

if(!is_writable($file)){

  die("The $file is not writable!");

}

fwrite($fp, 'here');

fclose($fp);

但这种写法是由瑕疵的,一个网站同一时间并不是只有一个用户访问的,在多个用户同时访问时,就会出现问题,也就是多个进程使用同一个资源时,前一个进程写到一半后面的进程便开始写了,因此最后生成的日志就乱了。这种情况下,就用到锁了,在文件加锁期间,其他进程是不会修改文件的,只有当文件解锁时,才可以操作。写法如下

1

2

3

4

5

6

7

8

9

$file = 'log.txt';

$fp = fopen($file, 'a+');

if(!is_writable($file)){

  exit("The $file is not writable!");

}

flock($fp, LOCK_EX);// 加锁

fwrite($fp, 'here');

flock($fp, LOCK_UN);// 解锁

fclose($fp);

如果想测试下在文件加锁期间其他进程操作不了文件的例子,可以用下面给出的demo

log.php

1

2

3

4

5

6

7

8

9

10

$file = 'log.txt';

$fp = fopen($file, 'a+');

if(!is_writable($file)){

  exit("The $file is not writable!");

}

flock($fp, LOCK_EX);

fwrite($fp, 'here');

sleep(10);

flock($fp, LOCK_UN);

fclose($fp);

test.php

1

2

3

4

5

6

$file = 'lock.txt';

$fp = fopen($file, 'a');

fwrite($fp, 'good'); // 在sleep期间写不进去

fclose($fp);

// 或是直接使用下面的这个例子,发现在sleep期间打印是个空值

//var_dump(file_get_contents($file));

测试时,先运行log.php,再运行test.php,会发现在sleep期间,test.php是执行达不到效果的。

来源:https://www.jiansouti.com/

标签:fp,文件,加锁,log,writable,file,日志,PHP,php
来源: https://blog.csdn.net/pc5150/article/details/121585853

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有