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