网站建设资讯

NEWS

网站建设资讯

php数据库加锁 mysql数据库加锁

PHP下如何对文件进行加锁

/**********************************************

成都创新互联服务项目包括榆林网站建设、榆林网站制作、榆林网页制作以及榆林网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,榆林网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到榆林省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!

*file lock

*@author Zeal 

Li

*

***********************************************/

/*

*lock_thisfile:获得独享锁

*@param $tmpFileStr 用来作为共享锁文件的文件名(可以随便起一个名字)

*@param $locktype 锁类型,缺省为false(非阻塞型,也就是一旦加锁失败则直接返回false),设置为true则会一直等待加锁成功才返回

*@return 如果加锁成功,则返回锁实例(当使用unlock_thisfile方法的时候需要这个参数),加锁失败则返回false.

*/

function 

lock_thisfile($tmpFileStr,$locktype=false){

if($locktype == 

false)

$locktype = LOCK_EX|LOCK_NB;

$can_write = 0;

$lockfp = @fopen($tmpFileStr.".lock","w");

if($lockfp){

$can_write = @flock($lockfp,$locktype);

}

if($can_write){

return $lockfp;

}

else{

if($lockfp){

@fclose($lockfp);

@unlink($tmpFileStr.".lock");

}

return false;

}

}

/** 

*unlock_thisfile:对先前取得的锁实例进行解锁

*@param $fp lock_thisfile方法的返回值

*@param $tmpFileStr 

用来作为共享锁文件的文件名(可以随便起一个名字)

*/

function 

unlock_thisfile($fp,$tmpFileStr){

@flock($fp,LOCK_UN);

@fclose($fp);

@fclose($fp);

@unlink($tmpFileStr.".lock");

}

?

?php

// 使用举例

$tmpFileStr = "/tmp/mylock.loc";

// 等待取得操作权限,如果要立即返回则把第二个参数设为false.

$lockhandle = 

lock_thisfile($tmpFileStr,true);

if($lockhandle){

// 

在这里进行所有需要独占的事务处理。

// ... ...

// 事务处理完毕。

unlock_thisfile($lockhandle,$tmpFileStr);

}

?

并发时,php操作mysql需要加锁吗?mysql在并发时读写数据表会加锁,我觉得不用再手动加锁,请问是这样吗?

如果要一次性做很多次插入,最好在每个循环的前后加上LOCK TABLES和UNLOCK TABLES,从而让其他进程也能访问数据表;这么做性能依然不错。

不然的话,会导致数据莫明其妙的插入不完整,或者没插进去的情况。

开发php网站,mysql做数据库一定要用锁吗?

一般情况下,MYSQL在更新操作会自动加表锁。不需要显式加锁。除非是数据要求严格的逻辑写顺序。

执行查询语句(SELECT)前,会自动给涉及的所有表加读锁,在执行更新操作 (UPDATE、DELETE、INSERT等)前,会自动给涉及的表加写锁,这个过程并不需要用户干预,因此,用户一般不需要直接用LOCK TABLE命令给MyISAM表显式加锁。

php里如果二个人同时操一个数据库里表的字段,怎么避免

1、数据库里有个东西叫锁

2、在每个人操作表的时候,对表加锁,这样防止别人对表数据脏读、脏写

3、操作完成后,释放锁

4、小心,加锁后可能会造成死锁,特别是锁过多的时候。

用锁需谨慎,有风险,但对数据来说是安全的

PHP 读文件怎么实现加锁

你的问题是:

1. 很多文件,想多进程处理,以提高效率,缩短总处理时间

2. 这些进程只需要读文件,不需要写

3. 对每个文件,只要有一个进程处理过它就可以了,没有多个进程都必须处理它的需求

你的需求其实是分治,将文件分为多个组(不一定要在文件系统上新建目录),然后分而治之,这种情况不需要用锁.

锁不是用于这种场景的,锁用于下面这种场景:

1. 文件file.txt里面记录了user1的销售额和user2的销售额,user1+user2的销售总额

2. 进程php1负责写入user1的数据,进程php2负责写入user2的数据,两个进程各读出销售总额显示给user1,user2

建议你这样解决:

1. 启动多个PHP进程(nohup php your_script.php your_dir )

2. 每个PHP进程赋予一个序号(假设4个进程,那就0,1,2,3),可以通过对进程自身的pid模运算取余数得到,也可以在启动进程的时候通过命令行传入,随你了

3. 每个进程在处理文件前先对文件名做crc32()运算,模一下进程总数: crc32(file_name) % 4, 取模结果与此进程的序号相等就读取内容并处理,不相等就跳过


文章标题:php数据库加锁 mysql数据库加锁
地址分享:http://njwzjz.com/article/doopojo.html