php文件读写锁

$file = fopen("test.txt", $fileOpenMode);
flock($file, $lockMode) or die("Can‘t lock");
//...
flock($file, LOCK_UN);
fclose($file);

$fileOpenMode:"r"(读);"r+"(写)(不能用"w",否则由于先打开再加锁,打开后文件内容已经清空了)

$lockMode:LOCK_SH(读);LOCK_EX(写)

<?php
sleep(3);
return;
$mode = $_GET[‘mode‘];
switch($mode){
case "r":
    $fileOpenMode = "r";
    $lockMode = LOCK_SH;
    $sleepTime = 3;
    break;
case "w":
    $fileOpenMode = "r+";
    $lockMode = LOCK_EX;
    $sleepTime = 5;
    break;
}

echo "QueryTime:" . time() . "<br>";
$startTime = time();
echo "Mode:" . $mode . "<br>";
$file = fopen("test.txt", $fileOpenMode);
flock($file, $lockMode) or die("Can‘t lock");
sleep($sleepTime);
switch($mode){
case "r":
    echo "Data:" . fgets($file) . "<br>";
    break;
case "w":
    echo "Data:" . "(Written)" . "<br>";
    fputs($file, "Write data info file at " . time());
    break;
}
flock($file, LOCK_UN);
fclose($file);
echo "Time:" . (time()-$startTime) . "<br>";
echo "Now:" . time() . "<br>";
?>
时间: 2024-10-16 19:41:12

php文件读写锁的相关文章

FileShare枚举的使用(文件读写锁)

FileShare 相信这个枚举类型大家会比较陌生,甚至有同学见都没见过(惭愧的是,我也是才认识它没多久),陌生归陌生,但它的作用力也是不可低估,只是.Net帮我们把它封装得比较好,以至于我们一度认为它不是什么重要角色.好吧,进入主题! 包含用于控制其他 FileStream 对象对同一文件可以具有的访问类型的常数.这句话是什么意思呢?说实话,我现在看句话还是觉得很纠结,相信很多同学看到也是一头雾水,没关系,我们先跳过! 看它的成员描述,和FileAccess很是相似,那我们就尝试着来揭开它暂时

高并发请求中的读写锁

在数据库中使用读写锁 数据库中使用读写锁,这样能更好地读取某一类统计数据,但一般读取不应该加锁,但修改操作却要慎重 事务的特性 1. 原子性(atomic),事务必须是原子工作单元:对于其数据修改,要么全都执行,要么全都不执行 2. 一致性(consistent),事务在完成时,必须使所有的数据都保持一致状态. 3. 隔离性(insulation),由并发事务所作的修改必须与任何其它并发事务所作的修改隔离. 4. 持久性(Duration),事务完成之后,它对于系统的影响是永久性的. 在j2ee

C#使用读写锁三句代码简单解决多线程并发写入文件时提示“文件正在由另一进程使用,因此该进程无法访问此文件”的问题

在开发程序的过程中,难免少不了写入错误日志这个关键功能.实现这个功能,可以选择使用第三方日志插件,也可以选择使用数据库,还可以自己写个简单的方法把错误信息记录到日志文件. 选择最后一种方法实现的时候,若对文件操作与线程同步不熟悉,问题就有可能出现了,因为同一个文件并不允许多个线程同时写入,否则会提示“文件正在由另一进程使用,因此该进程无法访问此文件”. 这是文件的并发写入问题,就需要用到线程同步.而微软也给进程同步提供了一些相关的类可以达到这样的目的,本文使用到的 System.Threadin

C#使用读写锁解决多线程并发写入文件时线程同步的问题

读写锁是以 ReaderWriterLockSlim 对象作为锁管理资源的,不同的 ReaderWriterLockSlim 对象中锁定同一个文件也会被视为不同的锁进行管理,这种差异可能会再次导致文件的并发写入问题,所以 ReaderWriterLockSlim 应尽量定义为只读的静态对象. 多线程同时写入文件 class Program { static int writeCount = 0; static int wrongCount = 0; static void Main(string

Linux多线程实践(6) --Posix读写锁解决读者写者问题

Posix读写锁 int pthread_rwlock_init(pthread_rwlock_t *restrict rwlock, const pthread_rwlockattr_t *restrict attr); int pthread_rwlock_destroy(pthread_rwlock_t *rwlock); int pthread_rwlock_rdlock(pthread_rwlock_t *rwlock); int pthread_rwlock_wrlock(pthre

读写锁详解

1. 综述 在一些程序中存在读者写者问题,也就是说,对某些资源的访问会存在两种可能的情况,一种是访问必须是排它行的,就是独占的意思,这称作写操作:另一种情况就是访问方式可以是共享的,就是说可以有多个线程同时去访问某个资源,这种就称作读操作.这个问题模型是从对文件的读写操作中引申出来的.    读写锁比起mutex具有更高的适用性,具有更高的并行性,可以有多个线程同时占用读模式的读写锁,但是只能有一个线程占用写模式的读写锁,读写锁的三种状态: (1)当读写锁是写加锁状态时,在这个锁被解锁之前,所有

信号量、互斥锁,读写锁和条件变量的区别

信号量强调的是线程(或进程)间的同步:“信号量用在多线程多任务同步的,一个线程完成了某一个动作就通过信号量告诉别的线程,别的线程再进行某些动作(大家都 在sem_wait的时候,就阻塞在那里).当信号量为单值信号量是,也可以完成一个资源的互斥访问.有名信号量:可以用于不同进程间或多线程间的互斥与同步 创建打开有名信号量 sem_t *sem_open(const char *name, int oflag); sem_t *sem_open(const char *name, int oflag

C基础 读写锁中级剖析

引言 读写锁 是为了 解决, 大量 ''读'' 和 少量 ''写'' 的业务而设计的. 读写锁有3个特征: 1.当读写锁是写加锁状态时,在这个锁被解锁之前,所有试图对这个锁加锁的线程都会被阻塞 2.当读写锁在读加锁状态时,再以读模式对它加锁的线程都能得到访问权,但以写模式加锁的线程将会被阻塞 3.当读写锁在读加锁状态时,如果有线程试图以写模式加锁,读写锁通常会阻塞随后的读模式加锁 我们先举一段标准库构建的读写锁demo来了解读写锁api 的使用 . pthread_rwlock.c #inclu

随想录(一种新的读写锁的写法)

[ 声明:版权所有,欢迎转载,请勿用于商业用途.  联系信箱:feixiaoxing @163.com] 做游戏的同学想必对云风很熟悉.这一段时间他开发的skynet和ejoy2d两个软件框架在github上很火.其中skynet是为游戏服务器开发的,可以看成是一个service框架,ejoy2d是一个客户端的代码,内容不多,主要封装了opengl的一些接口,很多人不一定看得上. 我对游戏服务器不熟,但是服务器的相关代码还是看了一些的.之前vsftpd.redis.sshd.mysqld的代码也