ORA-01017 查找机器名 用户名 以及library cache lock 参数含义

应用连不上测试环境的数据库,第一个猜测是用户被锁了?用sysdba连上数据库,发现用户是open状态。 用sqlplus XXX/XXX 测一下,会话直接夯住了,好像有点诡异,查看视图V$SESSION,看下当前数据库的连接数和等待事件等,果然有一大堆的library cache lock! library cache lock和用户无法登录两者联系到一起,那多半是用户密码错误了。

当发现数据库中有大量的library cache lock等待事件后,先去查看它所对应的 P1,P2,P3的值。可以通过视图V$EVENT_NAME,知道每个等待事件的P1,P2,P3的具体含义。这里,p1: 'handle address',p2: 'lock address',p3: '100*mode+namespace'

  1. 查看P1,P2,P3的值

    select to_char(p1,'xxxxxxxxxxxxx') p1raw,to_char(p2,'xxxxxxxxxxxxxxx') p2raw, to_char(p3,'xxxxxxxxxxxxxx') p3raw
    from v$active_session_history where event='library cache lock';
    P1RAW P2RAW P3RAW


    b4f2c3e0 b47952c8 4f0002
    b4f2c3e0 b47c5c68 4f0002
    b4f2c3e0 b460dcf8 4f0002

  2. 然后根据P3的值,查看具体的namespace

    将16进制0x4f转换为10进制
    SQL> select to_number('4f','xx') from dual;
    TO_NUMBER('4F','XX')

    79
    查看 Xkglob,namespace=79 对应的是 ACCOUNT_STATUS SQL> select KGLHDNSP,KGLHDNSD from xkglob where KGLHDNSP=79;
    KGLHDNSP KGLHDNSD


    79 ACCOUNT_STATUS

KGLHDNSP KGLHDNSD
---------- --------------------------------------------------------------------------------
0 SQL AREA
1 TABLE/PROCEDURE
2 BODY
3 TRIGGER
4 INDEX
5 CLUSTER
9 DIRECTORY
17 CONTEXT POLICY
18 PUB SUB INTERNAL INFORMATION
21 APP CONTEXT
24 RESOURCE MANAGER
25 XML SCHEMA
32 JAVA DATA
45 MULTI-VERSION OBJECT FOR TABLE
48 MULTI-VERSION OBJECT FOR INDEX
51 SCHEDULER GLOBAL ATTRIBUTE
53 TEMPORARY TABLE
55 TEMPORARY INDEX
57 SCHEDULER JOB SLAVE
64 EDITION
69 DBLINK
73 SCHEMA
75 SQL AREA STATS
79 ACCOUNT_STATUS
82 SQL AREA BUILD
93 AUDIT POLICY
103 OPTIMIZER FINDING
104 OPTIMIZER DIRECTIVE OWNER
106 Database Vault Rule
107 Database Vault Ruleset
112 USER PRIVILEGE
113 GTT SESSION PRIVATE STATS
115 KZP Exempt Access Policy list
123 Database Vault Realm Participant
127 Last_Successful_Logon_Time
130 APP STATE
136 CMP
137 OPTIMIZER EXPRESSION HEADER
138 OPTIMIZER EXPRESSION OBJECT
140 INMEMORY SERVICE METADATA
141 RUNTIME STATISTICS

从ACCOUNT_STATUS来看,这个等待事件应该与帐号密码验证有关。

  1. 验证猜测

打开 1017 errorstack,观察日志。

复制代码
alter system set events '1017 trace name errorstack level 3';

观察alert log

复制代码
Errors in file u01/app/oracle/diag/rdbms/gu/gu/trace/gu_ora_3737.trc:
ORA-01017: invalid username/password; logon denied

然后,从trace文件中看到客户端信息:

复制代码
client details:
`      O/S info: user: root, term: pts/4, ospid: 3559`
      machine: XXXX program: XXXXXXX (TNS V1-V3)
      application name: XXXXXX (TNS V1-V3), hash value=2077784982

关闭 1017 errorstack

复制代码
alter system set events '1017 trace name errorstack off';
相关推荐
麦聪聊数据14 小时前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_14 小时前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡14 小时前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧15 小时前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon15 小时前
SQL学习指南——视图
数据库·sql
活宝小娜15 小时前
mysql详细安装教程
数据库·mysql·adb
贤时间15 小时前
codex 助力oracle ebs 开发
数据库·oracle
秉承初心16 小时前
PostgreSQL 数据性能瓶颈突破实战
数据库·postgresql·oracle
Database_Cool_16 小时前
即席查询(Ad-Hoc)数据库选型:AnalyticDB MySQL 秒级 Ad-Hoc 分析方案
数据库·mysql