PHP解决多进程同时读写一个…

原文地址:PHP解决多进程同时读写一个文件的问题作者:陌上花开

首先PHP是支持进程的而不支持多线程(这个先搞清楚了),如果是对于文件操作,其实你只需要给文件加锁就能解决,不需要其它操作,PHP的flock已经帮你搞定了。

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

/*

*flock(file,lock,block)

*file 必需,规定要锁定或释放的已打开的文件

*lock 必需。规定要使用哪种锁定类型。

*block 可选。若设置为 1 或 true,则当进行锁定时阻挡其他进程。

*lock

*LOCK_SH 要取得共享锁定(读取的程序)

*LOCK_EX 要取得独占锁定(写入的程序)

*LOCK_UN 要释放锁定(无论共享或独占)

*LOCK_NB 如果不希望 flock() 在锁定时堵塞

/*

if (flock($file,LOCK_EX))

{

fwrite($file,'write more words');

flock($file,LOCK_UN);

}

else

{

//处理错误逻辑

}

fclose($file);

)

现在主流方法都是用redis进行分布式加锁:

说明从2.6.12版本后可以直接用set 进行加锁,避免进程中断造成永久死锁

  /**
     * redis加锁
     * @param $key
     * @param int $timeout
     * @param int $value
     * @return bool
     */
    public function lock($key, $timeout = 5, $value = 1) {
        return $ret = $this->set($key, $value, ['nx', 'ex' => $timeout]);
        /*
        $ret = $this->setnx($key, $value);
        if ($ret && $timeout > 0) {
            //抢到锁设置超时
            $this->expire($key, $timeout);
        }
        return $ret;
        */
    }
    
    /**
     * 删除锁 移除key
     * @param $key
     */
    public function unlock($key){
        $this->redis->del($key);
    }

http://www.leojen.com/

猜你喜欢

转载自blog.csdn.net/zhanqixuan22/article/details/51545429
今日推荐