码迷,mamicode.com
首页 > Web开发 > 详细

php 上锁 概述

时间:2018-08-08 13:42:22      阅读:183      评论:0      收藏:0      [点我收藏+]

标签:flock   计划   只读   释放   ...   判断   其他   fopen   文件   

1,为什么要上锁?

当某个功能访问量小的时候,可以直接加log,然后根据记录判断是否操作过。但是有次我在操作数据批量处理的时候——计划任务
在自动执行那个脚本,客服在手动执行那个脚本,结果create_time的秒数都一样了,这个时候查询结果再if语句是无法限制的,需要用
锁。
当多个脚本同一时间并发访问服务器端时,访问脚本会出现不正确的情况,这个问题需要上锁(锁机制)来解决。
2,mysql上锁
(1),READ读锁,锁定过程中所有客户只读这张表。
(2),WRITE写锁,只有锁定的表客服端可以操作,其他的只能到这个锁释释放。
加锁:LOCK TABLE 表1 READ|WRITE,表2 READ|WRITE...
解锁: UNLOCK TABLES (TABLES解锁多个表)
3,文件锁代码如下:
//建一个文件
$f = fopen(‘/tmp/‘ . $task[‘id‘] . ".txt", "w+");
//上锁
flock($f, LOCK_EX);
//这里是业务代码
中间的代码一次只能一个人访问,原理是建一个文件只允许一个人进出
//释放锁
flock($f, LOCK_EX);
fclose($f);
//删除文件
// unlink(‘/tmp/‘.$task[‘id‘].".txt");

php 上锁 概述

标签:flock   计划   只读   释放   ...   判断   其他   fopen   文件   

原文地址:https://www.cnblogs.com/ayanboke/p/9441909.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!