PHP数据库加锁代码 php数据库密码加密

怎么加线程锁 phpPHP语言本身是不支持多线程的 。网上关于PHP模拟多线程的方法,都是利用了LINUX和APACHE等本身所具有的多线程能力 。既然是模拟的,就不是真正的多线程,其实只是多进程 。
1. 利用LINUX操作系统
?php
for ($i=0;$i10;$i) {
echo $i;
sleep(5);
}
?
上面存成test.php, 然后写一段SHELL代码
#!/bin/bash
for i in 1 2 3 4 5 6 7 8 9 10
do
php -q test.php
done
2. 利用fork子进程(其实同样是利用LINUX操作系统)
【PHP数据库加锁代码 php数据库密码加密】?php
declare(ticks=1);
$bWaitFlag = FALSE; /// 是否等待进程结束
$intNum = 10;/// 进程总数
$pids = array();/// 进程PID数组
echo ("Startn");
for($i = 0; $i$intNum; $i) {
$pids[$i] = pcntl_fork();/// 产生子进程,而且从当前行之下开试运行代码,而且不继承父进程的数据信息
if(!$pids[$i]) {
// 子进程进程代码段_Start
$str="";
sleep(5 $i);
for ($j=0;$j$i;$j) {$str.="*";}
echo "$i - " . time() . " $str n";
exit();
// 子进程进程代码段_End
}
}
if ($bWaitFlag)
{
for($i = 0; $i$intNum; $i) {
pcntl_waitpid($pids[$i], $status, WUNTRACED);
echo "wait $i - " . time() . "n";
}
}
echo ("Endn");
?
3. 利用WEB SERVER, PHP不支持多线程, APACHE可是支持的, 呵呵.
假设我们现在运行的是a.php这个文档. 但是我在程式中又请求WEB服务器运行另一个b.php
那么这两个文档将是同时执行的.
?php
function runThread()
{
$fp = fsockopen('localhost', 80, $errno, $errmsg);
fputs($fp, "GET /a.php?act=brnrn");
fclose($fp);
}
function a()
{
$fp = fopen('result_a.log', 'w');
fputs($fp, 'Set in ' . Date('h:i:s', time()) . (double)microtime() . "rn");
fclose($fp);
}
function b()
{
$fp = fopen('result_b.log', 'w');
fputs($fp, 'Set in ' . Date('h:i:s', time()) . (double)microtime() . "rn");
fclose($fp);
}
if(!isset($_GET['act'])) $_GET['act'] = 'a';
if($_GET['act'] == 'a')
{
runThread();
a();
}
else if($_GET['act'] == 'b') b();
?
也可以把需要多线程处理的部分交给JAVA去处理 , 然后在PHP里调用 。
?php
system('java multiThread.java');
?
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,对一些内容加锁 , 而不是账号密码正确就跳转你这个密码都没进行md5加密的,想要更换跳转方式 , 就在跳转链接前加个if判断条件,里面写上你的要求,如果成立才跳转
php中mysql加锁问题有表锁,行锁 , 页锁
页级:引擎 BDB 。
表级:引擎 MyISAM , 理解为锁住整个表,可以同时读 , 写不行
行级:引擎 INNODB,单独的一行记录加锁
1) 表级锁:开销小,加锁快;不会出现死锁;锁定粒度大 , 发生锁冲突的概率最高,并发度最低 。
2) 行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小 , 发生锁冲突的概率最低,并发度也最高 。
3) 页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般 。
一般不在PHP中使用锁操作,因为如果锁了库,如果遇到错误没有及时的解锁,就会导致不能访问数据的情况 。
可以使用MYSQL的事务,就是定义事务开始,然后有几个语句要执行,然后根据情况,如果有一个语句没有执行成功,可以回滚(取消这几个语句的执行),从而达到几个语句都执行成功或者都不执行的效果,在强事务型的应用中一般使用这个方式
你可以去后盾人平台看看,里面的东西不错
关于PHP数据库加锁代码和php数据库密码加密的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。

    推荐阅读