博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PHP解决多线程同时读写一个文件的…
阅读量:4042 次
发布时间:2019-05-24

本文共 399 字,大约阅读时间需要 1 分钟。

用flock在写文件前先锁上,等写完后解锁,这样就实现了多线程同时读写一个文件避免冲突。大概就是下面这个流程

 
  1. /*
  2. *flock(file,lock,block)
  3. *file 必需,规定要锁定或释放的已打开的文件
  4. *lock 必需。规定要使用哪种锁定类型。
  5. *block 可选。若设置为 1 或 true,则当进行锁定时阻挡其他进程。
  6. *lock
  7. *LOCK_SH 要取得共享锁定(读取的程序)
  8. *LOCK_EX 要取得独占锁定(写入的程序)
  9. *LOCK_UN 要释放锁定(无论共享或独占)
  10. *LOCK_NB 如果不希望 flock() 在锁定时堵塞
  11. /*
  12. if (flock($file,LOCK_EX))
  13. {
  14. fwrite($file,'write more words');
  15. flock($file,LOCK_UN);
  16. }
  17. else
  18. {
  19. //处理错误逻辑
  20. }
  21. fclose($file);
  22. )

转载地址:http://npqdi.baihongyu.com/

你可能感兴趣的文章
mongodb管理与安全认证
查看>>
nodejs内存控制
查看>>
nodejs Stream使用中的陷阱
查看>>
windows 自制后台运行进程、exe开机自启动服务
查看>>
MongoDB 索引
查看>>
10gen工程师谈MongoDB组合索引的优化
查看>>
MongoDB 数据文件备份与恢复
查看>>
数据库索引介绍及使用
查看>>
MongoDB数据库插入、更新和删除操作详解
查看>>
MongoDB文档(Document)全局唯一ID的设计思路
查看>>
mongoDB简介
查看>>
Mongodb集群搭建的三种方式
查看>>
MongoDB修改oplog size
查看>>
对 MongoDB 的一些吐槽
查看>>
mongodb分片
查看>>
node.js mongodb ReplSet
查看>>
为什么中国的程序员总被称为码农?
查看>>
MongoDB数据文件内部结构
查看>>
redis 持久化(persistence)
查看>>
Redis持久化实践及灾难恢复模拟
查看>>