[20150331]生产系统登陆缓慢的问题.txt

[20150331]生产系统登陆缓慢的问题.txt

--上午生产系统出现登陆缓慢,查看等待事件library cache lock ,还好开发自己发现是11g设置口令大小写问题,及时纠正了错误.
--事后,我想如果开发不发现,我估计要诊断一段时间才能定位问题,我自己在测试环境做一个模拟看看,便于以后定位:

1.建立测试环境:

SYS@test> @ver1
PORT_STRING                    VERSION        BANNER
------------------------------ -------------- --------------------------------------------------------------------------------
x86_64/Linux 2.4.xx            11.2.0.3.0     Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production

--建立用户test,略,并且设置profile=MONITORING_PROFILE,MONITORING_PROFILE,因为这个用户口令设置许多参数都是无限制的.
ALTER USER TEST PROFILE MONITORING_PROFILE;

$ cat ay.sql
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
connect test/a
--注意口令是不正确的.

SYS@test> host cat /home/oracle11g/sqllaji/wx.sql
select p1,p2,p3,p1raw,p2raw,p3raw,sid,serial#,seq#,event,state,wait_time_micro,seconds_in_wait,sql_id from v$session where wait_class'Idle' and event not like 'SQL*Net%' order by event ;

2. 开始测试,执行如下:
sqlplus -s /nolog @ay &
sqlplus -s /nolog @ay &
sqlplus -s /nolog @ay &

SCOTT@test> @wx
        P1         P2         P3 P1RAW            P2RAW            P3RAW                   SID    SERIAL#       SEQ# EVENT               STATE               WAIT_TIME_MICRO SECONDS_IN_WAIT SQL_ID
---------- ---------- ---------- ---------------- ---------------- ---------------- ---------- ---------- ---------- ------------------- ------------------- --------------- --------------- -------------
3190141048 3195489736    5177346 00000000BE25B078 00000000BE774DC8 00000000004F0002          9         13          3 library cache lock  WAITING                     8903409               9
3190141048 2966733664    5177346 00000000BE25B078 00000000B0D4C360 00000000004F0002        411          5          3 library cache lock  WAITED KNOWN TIME           9994796              19
3190141048 3189066464    5177347 00000000BE25B078 00000000BE154AE0 00000000004F0003         10         41          7 library cache lock  WAITING                     9137097               9

--这个时候如果用户登陆,即使口令正确,也许要很长时间.

$ time echo "select sysdate from dual;" | sqlplus -s test/btbtms

SYSDATE
-------------------
2015-03-30 17:11:45

real    0m16.715s
user    0m0.030s
sys     0m0.011s
--16秒才退出.

3.如何定位:
SYS@test> select * from V$EVENT_NAME where lower(name) like lower('%library cache lock%');
    EVENT#   EVENT_ID NAME                                     PARAMETER1           PARAMETER2           PARAMETER3           WAIT_CLASS_ID WAIT_CLASS# WAIT_CLASS
---------- ---------- ---------------------------------------- -------------------- -------------------- -------------------- ------------- ----------- --------------------
       286  916468430 library cache lock                       handle address       lock address         100*mode+namespace      3875070507           4 Concurrency

--第1个想到的是ash,查看报表,意义不大,看到与上面查不多.

--P1是handle address,可以执行如下:

SCOTT@test> set serveroutput on
SCOTT@test> exec print_table('select * from x$kglob where kglhdadr=''00000000BE25B078''');
ADDR                          : 0000002A976D7850
INDX                          : 1125
INST_ID                       : 1
KGLHDADR                      : 00000000BE25B078
KGLHDPAR                      : 00000000BE25B078
KGLHDCLT                      : 17744
KGLNAOWN                      :
KGLNAOBJ                      : 96
KGLFNOBJ                      : 96
KGLNADLK                      :
KGLNAHSH                      : 3565438288
KGLNAHSV                      : 36212cd0bb9712c7fc79aeb5d4844550
KGLNATIM                      :
KGLNAPTM                      :
KGLHDNSP                      : 79
KGLHDNSD                      : ACCOUNT_STATUS
KGLHDLMD                      : 3
KGLHDPMD                      : 0
KGLHDFLG                      : 10241
KGLHDOBJ                      : 00
KGLHDLDC                      : 0
KGLHDIVC                      : 0
KGLHDEXC                      : 0
KGLHDLKC                      : 1
KGLHDKMK                      : 0
KGLHDDMK                      : 0
KGLHDAMK                      : 0
KGLOBFLG                      : 0
KGLOBSTA                      : 0
KGLOBTYP                      : -1
KGLOBTYD                      : NONE
KGLOBHMK                      : 0
KGLOBHS0                      : 0
KGLOBHS1                      : 0
KGLOBHS2                      : 0
KGLOBHS3                      : 0
KGLOBHS4                      : 0
KGLOBHS5                      : 0
KGLOBHS6                      : 0
KGLOBHS7                      : 0
KGLOBHD0                      : 00
KGLOBHD1                      : 00
KGLOBHD2                      : 00
KGLOBHD3                      : 00
KGLOBHD4                      : 00
KGLOBHD5                      : 00
KGLOBHD6                      : 00
KGLOBHD7                      : 00
KGLOBPC0                      : 0
KGLOBPC6                      : 0
KGLOBTP0                      : 00
KGLOBT00                      : 0
KGLOBT01                      : 0
KGLOBT02                      : 0
KGLOBT03                      :
KGLOBT04                      : 0
KGLOBT05                      : 0
KGLOBT35                      : 0
KGLOBT06                      : 0
KGLOBT07                      : 0
KGLOBT08                      : 0
KGLOBT09                      : 0
KGLOBT10                      : 0
KGLOBT11                      : 0
KGLOBT12                      : 0
KGLOBT13                      : 0
KGLOBT14                      : 0
KGLOBT15                      : 0
KGLOBT16                      : 0
KGLOBT17                      : 0
KGLOBT18                      : 0
KGLOBT19                      : 0
KGLOBT20                      : 0
KGLOBT21                      : 0
KGLOBT22                      : 0
KGLOBT23                      : 62
KGLOBT24                      : 0
KGLOBT25                      : 0
KGLOBT26                      : 0
KGLOBT28                      : 0
KGLOBT29                      : 0
KGLOBT30                      : 0
KGLOBT31                      : 0
KGLOBT27                      : 0
KGLOBT32                      : 0
KGLOBT33                      : 0
KGLOBWAP                      : 0
KGLOBWCC                      : 0
KGLOBWCL                      : 0
KGLOBWUI                      : 0
KGLOBWDW                      : 0
KGLOBT42                      : 0
KGLOBT43                      : 0
KGLOBT44                      : 0
KGLOBT45                      : 0
KGLOBT46                      : 0
KGLOBT47                      : 0
KGLOBT49                      : 0
KGLOBT50                      : 0
KGLOBT52                      : 0
KGLOBT53                      : 0
KGLOBTL0                      : 0
KGLOBTL1                      : 0
KGLOBTS0                      :
KGLOBTS1                      :
KGLOBTN0                      :
KGLOBTN1                      :
KGLOBTN2                      :
KGLOBTN3                      :
KGLOBTN4                      :
KGLOBTN5                      :
KGLOBTS2                      :
KGLOBTS3                      :
KGLOBTS5                      :
KGLOBTT0                      :
KGLOBCCE                      :
KGLOBCCEH                     : 0
KGLOBCLA                      :
KGLOBCLC                      : 0
KGLOBCCC                      : 0
KGLOBTS4                      :
KGLOBCBCA                     :
KGLOBT48                      : 0
KGLOBDSO                      : 0
KGLOBDEX                      : 0
KGLOBDPX                      : 0
KGLOBDLD                      : 0
KGLOBDIV                      : 0
KGLOBDPS                      : 0
KGLOBDDR                      : 0
KGLOBDDW                      : 0
KGLOBDBF                      : 0
KGLOBDRO                      : 0
KGLOBDCP                      : 0
KGLOBDEL                      : 0
KGLOBDFT                      : 0
KGLOBDEF                      : 0
KGLOBDUI                      : 0
KGLOBDCL                      : 0
KGLOBDAP                      : 0
KGLOBDCC                      : 0
KGLOBDPL                      : 0
KGLOBDJV                      : 0
KGLOBACS                      : 0
KGLOBTS6                      :
KGLOBTS7                      :
KGLOBT54                      : 0
KGLOBT55                      : 0
KGLOBT56                      : 0
KGLOBT57                      : 0
KGLOBDCO                      : 0
KGLOBDCI                      : 0
KGLOBDRR                      : 0
KGLOBDRB                      : 0
KGLOBDWR                      : 0
KGLOBDWB                      : 0
KGLOBT58                      : 0
KGLOBDOR                      : 0
KGLHDMTX                      : 00000000BE25B1A8
KGLHDMVL                      : 0
KGLHDMSP                      : 7
KGLHDMGT                      : 733
KGLHDDMTX                     : 00000000BE25B128
KGLHDDVL                      : 0
KGLHDDSP                      : 0
KGLHDDGT                      : 0
KGLHDBID                      : 17744
KGLHDBMTX                     : 00000000B7EF81F8
KGLHDBVL                      : 0
KGLHDBSP                      : 0
KGLHDBGT                      : 420
KGLOBT59                      : 0
KGLOBDCU                      : 0
-----------------
PL/SQL procedure successfully completed.

SCOTT@test> column object format a30
SCOTT@test> select kglnaown "Owner", kglnaobj "Object" from x$kglob where kglhdadr='00000000BE25B078';
Owner  Object
------ ------------------------------
       96

--从以上输出基本可以确定用户信息相关.
SCOTT@test> select user#,name from sys.user$ where user#=96;
     USER# NAME
---------- --------------------
        96 TEST

--如果打开登陆审计的,一般错误登陆的信息会记载.执行如下:
SCOTT@test> SELECT username,userhost,timestamp,action_name,returncode  FROM DBA_AUDIT_SESSION WHERE returncode != 0 and timestamp>= sysdate-1/1440;
USERNAME  USERHOST  TIMESTAMP           ACTION_NAME  RETURNCODE
--------- --------- ------------------- ------------ ----------
TEST      xxxdg     2015-03-31 08:16:59 LOGON              1017
TEST      xxxdg     2015-03-31 08:17:09 LOGON              1017
TEST      xxxdg     2015-03-31 08:17:19 LOGON              1017
TEST      xxxdg     2015-03-31 08:17:29 LOGON              1017

$ oerr ora 1017
01017, 00000, "invalid username/password; logon denied"
// *Cause:
// *Action:

--这样基本可以确定用户登陆口令错误.

4.从P2,P3的信息确定:

SCOTT@test> set linesize 2000
SCOTT@test> select * from x$kgllk where kgllkhdl='00000000BE25B078';
ADDR                   INDX    INST_ID KGLLKADR         KGLLKUSE         KGLLKSES           KGLLKSNM KGLLKHDL         KGLLKPNC         KGLLKPNS           KGLLKCNT   KGLLKMOD   KGLLKREQ   KGLLKFLG   KGLLKSPN   KGLNAHSH KGLLKSQLID    KGLHDPAR           KGLHDNSP USER_NAME  KGLNAOBJ  KGLLKEST              KGLLKEXC KGLLKCTP
---------------- ---------- ---------- ---------------- ---------------- ---------------- ---------- ---------------- ---------------- ---------------- ---------- ---------- ---------- ---------- ---------- ---------- ------------- ---------------- ---------- ---------- --------- ------------------- ---------- --------
0000002A97543AF8         79          1 00000000B0BC4F58 00000000BD2D93A0 00000000BD2D93A0         20 00000000BE25B078 00               00                        0          0          2          0          4 3565438288 gsydfqra88jah 00000000BE25B078         79 SYS        96        1970-01-01 08:00:04          0 OPEN
0000002A97543BF8         80          1 00000000B091B940 00000000BD2B8768 00000000BD2B8768         31 00000000BE25B078 00               00                        0          0          2          0          4 3565438288 gsydfqra88jah 00000000BE25B078         79 SYS        96        1970-01-01 08:00:04          0 OPEN
0000002A97543CF8         81          1 00000000B0CFA8B0 00000000BD75CE40 00000000BD75CE40        404 00000000BE25B078 00               00                        1          3          0          1         18 3565438288 gsydfqra88jah 00000000BE25B078         79 SYS        96        1970-01-01 08:00:18          0 OPEN

SCOTT@test> @wx
        P1         P2         P3 P1RAW            P2RAW            P3RAW                   SID    SERIAL#       SEQ# EVENT               STATE               WAIT_TIME_MICRO SECONDS_IN_WAIT SQL_ID
---------- ---------- ---------- ---------------- ---------------- ---------------- ---------- ---------- ---------- ------------------- ------------------- --------------- --------------- -------------
3190141048 2965131096    5177346 00000000BE25B078 00000000B0BC4F58 00000000004F0002         20         99          3 library cache lock  WAITING                     4705883               5
3190141048 2966398896    5177346 00000000BE25B078 00000000B0CFA7B0 00000000004F0002        404        157          4 library cache lock  WAITED KNOWN TIME           9981035              15
3190141048 2962340160    5177346 00000000BE25B078 00000000B091B940 00000000004F0002         31         63          7 library cache lock  WAITING                     4757373               5

--x$kgllk的KGLLKADR就是对应P2,因为会变化,我还是选择查询handle address.
--很奇怪查询v$sql视图无法找到KGLLKSQLID=gsydfqra88jah的记录.

SCOTT@test> select sql_text from v$sql where sql_id='gsydfqra88jah';
no rows selected

SCOTT@test> select * from X$KGLOB where kglobt03='gsydfqra88jah';
no rows selected

-- 从P3看,参数格式是PARAMETER3=100*mode+namespace,注意这个是16进制的.
-- mode=4f(10进制79),namespace=2 或者 3.

SYS@test> select distinct KGLHDNSP,KGLHDNSD from x$kglob;
  KGLHDNSP KGLHDNSD
---------- ----------------------------------------------------------------
         0 SQL AREA
         4 INDEX
         1 TABLE/PROCEDURE
        52 SCHEDULER EARLIEST START TIME
         3 TRIGGER
        64 EDITION
        48 MULTI-VERSION OBJECT FOR INDEX
        69 DBLINK
         2 BODY
        79 ACCOUNT_STATUS
        45 MULTI-VERSION OBJECT FOR TABLE
        28 SUBSCRIPTION
        10 QUEUE
        23 RULESET
        73 SCHEMA
        24 RESOURCE MANAGER
        51 SCHEDULER GLOBAL ATTRIBUTE
        74 DBINSTANCE
        38 RULE EVALUATION CONTEXT
        82 SQL AREA BUILD
        75 SQL AREA STATS
         5 CLUSTER
        18 PUB SUB INTERNAL INFORMATION

23 rows selected.

--ACCOUNT_STATUS说明library cache lock是在account上,可能是用错误的用户名密码登录.。

5.转储library cache看看,实际上我觉得这个是没有办法的办法,这个实际在生产系统的共享池都很大,转储的文件也会很大,
SYS@test> Alter session set events 'immediate trace name library_cache level 10';
Session altered.

--直接查找Address=0xbe25b078.

  LibraryHandle:  Address=0xbe25b078 Hash=d4844550 LockMode=X PinMode=0 LoadLockMode=0 Status=VALD
    ObjectName:  Name=96
      FullHashValue=36212cd0bb9712c7fc79aeb5d4844550 Namespace=ACCOUNT_STATUS(79) Type=NONE(255) Identifier=0 OwnerIdn=2147483644
    Statistics:  InvalidationCount=0 ExecutionCount=0 LoadCount=0 ActiveLocks=1 TotalLockCount=8865 TotalPinCount=0
    Counters:  BrokenCount=1 RevocablePointer=1 KeepDependency=0 BucketInUse=10529 HandleInUse=10529 HandleReferenceCount=0
    Concurrency:  DependencyMutex=0xbe25b128(0, 0, 0, 0) Mutex=0xbe25b1a8(404, 48039, 1959, 6)
    Flags=PIN/TIM/[00002801]
    WaitersLists:
      Lock=0xbe25b108[0xacc75fa0,0xb09b6528]
      Pin=0xbe25b0e8[0xbe25b0e8,0xbe25b0e8]
      LoadLock=0xbe25b160[0xbe25b160,0xbe25b160]
    Timestamp:  Current=NULL

--实际上与查询x$kglob获取的信息基本一致.

时间: 2024-10-23 08:46:59

[20150331]生产系统登陆缓慢的问题.txt的相关文章

[20130318]v$rman_backup_job_details访问缓慢的问题.txt

[20130318]v$rman_backup_job_details访问缓慢的问题.txt 今天我想检查备份,执行如下: SELECT start_time, end_time, elapsed_seconds,TRIM (time_taken_display) TIME, status, input_type,        compression_ratio, TRIM (input_bytes_display) inputb,        TRIM (output_bytes_disp

xp系统登陆界面如何修改

  xp系统登陆界面如何修改 Windows XP在登录时会先显示一个浅蓝色的屏幕,即登录界面的背景色,想不想更改成其它的颜色.用下面的这个方面就可以了. 打开注册表,找到"HKEY_USERS.DEFAULTControl PanelColor",在窗口右边找到"Background"这个键值,会出现"编辑字符串"对话框,在"数值数据"下的框中输入你想要的颜色键值,"确定"后,重新启动系统即可.(系统默认

用c语言做一个学籍系统登陆界面,求源代码

问题描述 用c语言做一个学籍系统登陆界面,求源代码 请问我要用c语言做一个学籍系统登陆界面咋做,有没有源代码,格式如下: ****************学生学籍管理系统**************** 1,注册 2,登陆 3,修改密码 0,退出系统 请选择0~3 解决方案 http://www.docin.com/p-565175373.htmlhttp://wenku.baidu.com/link?url=k0FVy3GjeXwWYcZsHz3X5ir_qGRBS_OElVg5XDcTydD

flash中通过XMLSocket监控生产系统(3-1)

xml|监控 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />  不断向客户端发送不同类型的有意义的XML数据,模拟生产系统的不同状态.考虑到功能的简便性,服务端只是每2秒向客户端发送一条随机类型的数据,而没有包括模拟生产系统及时的状态,如在某一时刻发生错误时,发送一条表示错误类型的数据,在实际设计编程中,基于本文中的例子,可以轻松扩展实现所需功能. public voi

flash中通过XMLSocket监控生产系统(1)

xml|监控   可是B/S体系结构也不是万能的,由于其工作机制的限制,在某些领域,以前采用B/S体系结构就很难实现要求功能.典型情况下, Web页面和大多数Web应用使用了一种称为请求/响应的工作机制: o 使用者点击一个超级链接,或是提交一个表单等. o 浏览器向服务器发送请求. o 服务器启动一个会话. o 服务器经过处理后,把数据发送给浏览器. o 服务器关闭会话,浏览器显示数据. 我们可以看出,使用B/S体系结构设计软件时,无法回避两个限制:被动性与滞后性.首先,使用者必须通过浏览器请

WinXP系统登陆密码怎么找回

WinXP系统登陆密码怎么找回   1. 创立修复用户密码的启动软盘 微软在WindowsXP中为我们供给了一个创立修复用户密码的启动软盘的功效,在我们忘记密码时,可以通过这张软盘来启动电脑,所以我们应当事先做张密码启动盘以防万一.点击"开始""控制面板"中的"用户账户"选项,在弹出的对话窗口中选择自己的账户便会进入自己账户的把持界面,紧接着点击窗口左上方的"禁止一个已忘记的密码"选项,则进入"忘记密码向导"

如何取消WinXP系统登陆密码

  (1)网上传的删除SAM文件对XP不行的,如果删除SAM文件则不能进入系统! (2)"在DOS下面新建用户:net user USERa(用户名) 123456(密码) /Add .接着使用"net localgroup administrators USERa(用户名) /Add"命令提升USERa用户为管理员级别,即拥有所有权限操作系统 "的方法我试过不行,因为你根本没有登录用户,根本没有权限用这个命令,这个命令的前提是要在有用户登录的情况下! 正确的取消W

win7系统把PDF文件转换为TXT文件的教程

  win7系统把PDF文件转换为TXT文件的教程          1.在网上搜索到类似的,可以将PDF格式文件转换成TXT文件的工具,这个功能是Windows系统中没有的,需要借助第三方软件来完成.搜索到类似的格式转换工具之后,下载安装即可. 2.我们这里以其中的一款工具为例,做一个详细的介绍,打开该工具,之后,看到左侧窗格中拥有多种选项,这里是需要将PDF文件转换为TXT文件,因此,这里就需要对应选择文件转TXT; 3.完成选择之后,可以看到右侧窗口中会有一个添加按钮,点击这个添加按钮,然

win8系统登陆QQ时阻止QQ宠物弹出的方法

  win8系统登陆QQ时阻止QQ宠物弹出的方法.win8系统开机登陆QQ,每次都会弹出QQ宠物,导致系统变卡,每次都要关闭,非常麻烦.有什么办法能够阻止QQ宠物弹出呢?办法当然是有的,下面小编和大家介绍win8系统登陆QQ时阻止QQ宠物弹出的方法. 具体方法如下: 1.首先我们打开QQ登陆页面; 2.登陆QQ以后出现 出现联系人页面以后,点击左下角,从左数第二个图标,也就是设置图标; 3.把 登陆后自动运行QQ宠物取消勾选就可以了. 上述就是win8系统登陆QQ时阻止QQ宠物弹出的方法,如果想