解决Oracle ERP死锁的方法

2016-02-19 21:14 5 1 收藏

下面图老师小编要向大家介绍下解决Oracle ERP死锁的方法,看起来复杂实则是简单的,掌握好技巧就OK,喜欢就赶紧收藏起来吧!

【 tulaoshi.com - 编程语言 】

  今天,功能顾问说客户在作付款的时候忽然客户端掉电,然后再次登录以后就无法继续付款了,报错界面如下。

  明显是意外掉电导致的客户端进程没有释放,所以产生了始终不释放的lock。

  如果对于业务比较熟悉,知道这是哪个form,问清楚客户使用的什么职责,通常从v$lock和v$session中就可以得到足够的信息,然后kill掉产生lock的会话就可以了。

  但是如果对于业务不熟悉就只能依靠Oracle RDBMS的知识一点点检查了,我的解决方法基本上是这样。

  1。为发生错误的Form加上跟踪

  2。重现错误,在udump目录下查看trace文件

  3。找到这样的报错

  PARSINGINCURSOR#70len=120dep=0uid=44oct=3lid=44tim=2502449707361hv=3320467580ad=’99f21c88′
  SELECTLAST_DOCUMENT_NUM+1FROMAP_CHECK_STOCKSWHERECHECK_STOCK_ID=:b1FORUPDATEOFLAST_DOCUMENT_N
  UMNOWAIT
  ENDOFSTMT
  PARSE#70:c=0,e=2425,p=0,cr=2,cu=0,mis=1,r=0,dep=0,og=0,tim=2502449707353
  WAIT#70:nam=’SQL*Netmessagetoclient’ela=2p1=1952673792p2=1p3=0
  WAIT#70:nam=’SQL*Netmessagefromclient’ela=356p1=1952673792p2=1p3=0
  BINDS#70:
  bind0:dty=2mxl=23(22)mal=00scl=00pre=00oacflg=03oacfl2=0size=24offset=0
  bfp=800003fb8005b6f8bln=23avl=04flg=05
  value=10094
  EXEC#70:c=0,e=1159,p=0,cr=7,cu=1,mis=0,r=0,dep=0,og=4,tim=2502449709034
  ERROR#70:err=54tim=256250850

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

  4。确认err=54是资源繁忙的错误

  $oerrora54
  00054,00000,“resourcebusyandacquirewithNOWAITspecified”
  //*Cause:Resourceinterestedisbusy.
  //*Action:Retryifnecessary.

  5。查看dba_objects和v$locked_object,找到对SQL中的表加锁的SESSION_ID,然后kill这个会话。

  这一步需要注意的是,Oracle ERP系统中使用了大量的带有CLIENT_INFO环境参数的视图,比如本例中的AP_CHECK_STOCKS就是一个视图,所以直接从v$locked_object里面是查不到锁定视图的会话的,所以通常我们还需要找到这个视图的定义,然后查询视图使用的基表。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

来源:https://www.tulaoshi.com/n/20160219/1625618.html

延伸阅读
对于今天的 RDBMS 体系结构而言,死锁难以避免 — 在高容量的 OLTP 环境中更是极为普遍。正是由于 .NET 的公共语言运行库 (CLR) 的出现,SQL Server 2005 才得以为开发人员提供一种新的错误处理方法。在本月专栏中,Ron Talmage 为您介绍如何使用 TRY/CATCH 语句来解决一个死锁问题。一个示例死锁 让我们从这样一个示例开始说起,它...
    项目中用到Oracle,服务器端使用AMERICAN_AMERICA.WE8ISO8859P1字符编码,我没有修改服务器端的权限,只能修改客户端.但是客户端无论我换什么字符编码均得到乱码,最后我将客户端的字符编码也设为AMERICAN_AMERICA.WE8ISO8859P1,然后从程序中下手.     AMERICAN_AMERICA.WE8ISO8859P1,这个字符编码是西欧字符编码...
方法 查找symcjit.dll,会找到两处,都是jre(Java Runtime Environment) 将此两文件改名为symcjit_.dll,然后安装,可以完全正常。 安装硬件(已经正常安装): Server: Dell PowerEdge 2600 双至强 2.8G 1G内存 PC: P4 2.4GB 512M内存 说明: 前几天在Win2000下装两年前下的Oracle 8.1.7 NTEE Relea...
最近,在项目开发过程中,碰到了数据库死锁问题,在解决问题的过程中,笔者对MySQL InnoDB引擎锁机制的理解逐步加深。 案例如下: 在使用Show innodb status检查引擎状态时,发现了死锁问题: *** (1) TRANSACTION: TRANSACTION 0 677833455, ACTIVE 0 sec, process no 11393, OS thread id 278546 starting index rea...
如果两个用户进程分别锁定了不同的资源,接着又试图锁定对方所锁定的资源,就会产生死锁。此时,SQL Server将自动地选择并中止其中一个进程以解除死锁,使得另外一个进程能够继续处理。系统将回退被中止的事务,并向被回退事务的用户发送错误信息。 大多数设计良好的应用都会在接收到这个错误信息之后重新提交该事务,此时提交成功的...

经验教程

569

收藏

73
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部