Jquery中文网 www.jquerycn.cn
Jquery中文网 >  脚本编程  >  php  >  正文 file_put_contents 高并发与独占锁定的问题

file_put_contents 高并发与独占锁定的问题

发布时间:2016-12-18   编辑:www.jquerycn.cn
本文介绍下,在php中使用file_put_contents在高并发与独占锁时,写入数据为空的问题及解决方法,有需要的朋友参考下。

在高并发访问时,使用 file_put_contents 写入文件造成数据置空。

查看官方文档:
int file_put_contents ( string $filename , string $data [, int $flags [, resource $context ]] )

参数:
filename
要被写入数据的文件名。

data
要写入的数据。类型可以是 string,array 或者是 stream 资源(如上面所说的那样)。

flags
flags 可以是 FILE_USE_INCLUDE_PATH,FILE_APPEND 和/或 LOCK_EX(获得一个独占锁定),然而使用 FILE_USE_INCLUDE_PATH 时要特别谨慎。

context
一个 context 资源。
直接直至 flags 参数为 LOCK_EX 即可在高并发时获得一个独占锁定。

另外,flock 函数的也提供了文件锁定方法:

<?php
$fp = fopen("/tmp/lock.txt", "w+");

if (flock($fp, LOCK_EX)) { // 进行排它型锁定
fwrite($fp, "Write something here\n");
flock($fp, LOCK_UN); // 释放锁定
} else {
echo "Couldn't lock the file !";
}

fclose($fp);
?>

注意 flock() 需要一个文件指针。

您可能感兴趣的文章:
file_put_contents 高并发与独占锁定的问题
file_put_contents并发性问题解决方案整理
mysql如何锁定单个表
php文件锁产生的问题和解决方案(一个真实案例)
mysql中的锁、事务、并发控制的相关知识
MySQL数据库之锁的详解
Java并发控制机制学习笔记
golang锁记
mysql LOCK TABLES和UNLOCK TABLES
经典Java线程面试题70道

[关闭]