bool flock ( int handle, int operation [, int &wouldblock] );
flock() 操做的 handle 必须是一个已经打开的文件指针。operation 能够是如下值之一:php
建两个文件
(1) a.phphtml
$file
=
"temp.txt"
;
$fp
=
fopen
(
$file
,
'w'
);
if
(
flock
(
$fp
, LOCK_EX)){
fwrite(
$fp
,
"abc\n"
);
sleep(10);
fwrite(
$fp
,
"123\n"
);
flock
(
$fp
, LOCK_UN);
}
fclose(
$fp
);
|
(2) b.php数据库
$file
=
"temp.txt"
;
$fp
=
fopen
(
$file
,
'r'
);
echo
fread
(
$fp
, 100);
fclose(
$fp
);
|
运行 a.php 后,立刻运行 b.php ,能够看到输出:
abc
等 a.php 运行完后运行 b.php ,能够看到输出:
abc
123
显然,当 a.php 写文件时数据太大,致使时间比较长时,这时 b.php 读取数据不完整缓存
修改 b.php 为:测试
$file
=
"temp.txt"
;
$fp
=
fopen
(
$file
,
'r'
);
if
(
flock
(
$fp
, LOCK_EX)){
echo
fread
(
$fp
, 100);
flock
(
$fp
, LOCK_UN);
}
else
{
echo
"Lock file failed...\n"
;
}
fclose(
$fp
);
|
运行 a.php 后,立刻运行 b.php ,能够发现 b.php 会等到 a.php 运行完成后(即 10 秒后)才显示:
abc
123
读取数据完整,但时间过长,他要等待写锁释放。spa
修改 b.php 为:指针
$file
=
"temp.txt"
;
$fp
=
fopen
(
$file
,
'r'
);
if
(
flock
(
$fp
, LOCK_SH | LOCK_NB)){
echo
fread
(
$fp
, 100);
flock
(
$fp
, LOCK_UN);
}
else
{
echo
"Lock file failed...\n"
;
}
fclose(
$fp
);
|
运行 a.php 后,立刻运行 b.php ,能够看到输出:
Lock file failed…
证实能够返回锁文件失败状态,而不是向上面同样要等好久。code
结论:
建议做文件缓存时,选好相关的锁,否则可能致使读取数据不完整,或重复写入数据。
file_get_contents 好像选择不了锁,不知道他默认用的什么锁,反正和不锁获得的输出同样,是不完整的数据。
我是要作文件缓存,因此只须要知道是否有写锁存在便可,有的话就查数据库就能够了。
测试环境:Linux(Ubuntu 6) , PHP 5.1.2 , Apache 2htm
再转:blog
还有一篇也写得不错的博文: