zoukankan      html  css  js  c++  java
  • php 上锁 概述

    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");

  • 相关阅读:
    Open vSwitch流表应用实战
    《智慧网络协同组织机理》智慧网络可编程技术 小记
    DS实验题 sights
    switch parser.p4源码
    OpenFlow.p4 源码
    Mininet实验 OpenFlow1.3协议基于Mininet部署与验证
    Ubuntu/linux 安装 kernel-devel
    yolo
    ssd
    铁道栏杆的项目做的事情
  • 原文地址:https://www.cnblogs.com/ayanboke/p/9441909.html
Copyright © 2011-2022 走看看