由php事务挂掉开始

论坛 期权论坛 编程之家     
选择匿名的用户   2021-6-2 20:55   1350   0

今天有同事碰到一个问题,说是开事务了,然后在中间有个地方因为代码的原因中断了,结果数据库就堵在哪里了。

一、首先,同事说是因为中间代码有错误,就会停止执行。于是我写了一段代码

20 try{
21 $a = $b;
22 $c = $a;
23 echo "c=$c\n";
24
25 }
26 catch(Exception $e){
27 echo "exception caught".$e->getMessage()."\n";
28 }
29 echo "done\n";

发现上面的代码是能一直执行下去的,就开始怀疑同事的说法,觉得php是解释型语言,碰到错误就直接忽略,继续执行

后来,同事在里面加了一行代码

$aa::a();

立马执行不了了

比较了这两个程序,发现一个是语法错误,另一个是运行时错误,就像难道php会先进行语法检查,看了下php的执行过程,确实,php脚本先由zend引擎编译成opcode序列,这个过程中如果有语法错误,是不会进行编译的。这里有个问题,错误处理函数能捕获到到语法错误不?

于是就想php有哪些语法错误:查了下,常见的大概有这么几种

Parse error: parse error, expecting
1、变量没加$号
2、缺少;号
3、(,)不匹配

4、“”,‘’不匹配

这个是=====================
$num=$this->ExecuteQuery("DELETE FROM resultlist WHERE ID=".$ID); if($num==1) return TRUE; else return FALSE;
如果你的源代码被出来,要么你的php环境没搭好,要么你用了<? ?>,要是后都的话,请改为<?php ?>即可.

没整明白===================

二、事务为啥没有回滚捏

事务开启之后,客户端一开始与服务器交互,加了一堆锁,然后突然挂掉了,服务器一直在等待客户端发commit或rollback命令,一直到链接超时,才会自动回滚

结论:语法错误,必须人工保证,而运行时错误,php会继续继续执行,如果开启了事务,尤其是全局事务,要特别小心,如果出现语法错误(代码质量够差的,联调、测试的时候可能出现),或者线上代码不小心被人覆盖代码(这个还是有一定的可能的),那就悲剧了,所以若非必要,还是要避免全局事务,代码质量真的很重要


分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:3875789
帖子:775174
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP