Oracle常见问题:将登录失败的信息记录到alert日志中
2022/6/1 2:53:00
本文主要是介绍Oracle常见问题:将登录失败的信息记录到alert日志中,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
问题描述
有个数据库用户经常被锁,Unlock之后没几秒就会被锁住,因为涉及的项目太多,很难做到逐一排查,不知道是哪个项目用错密码,导致账户被锁。后面排查日志没有发现登录失败的日志,故在网上查找相关资料,发现可以创建一个触发器可将相关日志记录下来。
解决方案
用dba账户创建如下触发器即可。
CREATE OR REPLACE TRIGGER logon_denied_to_alert AFTER servererror ON DATABASE DECLARE message VARCHAR2(168); ip VARCHAR2(15); v_os_user VARCHAR2(80); v_module VARCHAR2(50); v_action VARCHAR2(50); v_pid VARCHAR2(10); v_sid NUMBER; v_program VARCHAR2(48); BEGIN IF (ora_is_servererror(1017)) THEN -- get ip FOR remote connections : IF upper(sys_context('userenv', 'network_protocol')) = 'TCP' THEN ip := sys_context('userenv', 'ip_address'); END IF; SELECT sid INTO v_sid FROM sys.v_$mystat WHERE rownum < 2; SELECT p.spid, v.program INTO v_pid, v_program FROM v$process p, v$session v WHERE p.addr = v.paddr AND v.sid = v_sid; v_os_user := sys_context('userenv', 'os_user'); dbms_application_info.read_module(v_module, v_action); message := to_char(SYSDATE, 'YYYY-MM-DD HH24:MI:SS') || ' Password Erro: logon denied from ' || nvl(ip, 'localhost') || ' ' || v_pid || ' User:' || v_os_user || ' with ' || v_program || ' ' || v_module || ' ' || v_action||' dbuser:'||USER; sys.dbms_system.ksdwrt(2, message); END IF; END;
参考来源
https://www.modb.pro/db/25539
这篇关于Oracle常见问题:将登录失败的信息记录到alert日志中的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-15PingCAP 黄东旭参与 CCF 秀湖会议,共探开源教育未来
- 2024-05-13PingCAP 戴涛:构建面向未来的金融核心系统
- 2024-05-09flutter3.x_macos桌面os实战
- 2024-05-09Rust中的并发性:Sync 和 Send Traits
- 2024-05-08使用Ollama和OpenWebUI在CPU上玩转Meta Llama3-8B
- 2024-05-08完工标准(DoD)与验收条件(AC)究竟有什么不同?
- 2024-05-084万 star 的 NocoDB 在 sealos 上一键起,轻松把数据库编程智能表格
- 2024-05-08Mac 版Stable Diffusion WebUI的安装
- 2024-05-08解锁CodeGeeX智能问答中3项独有的隐藏技能
- 2024-05-08RAG算法优化+新增代码仓库支持,CodeGeeX的@repo功能效果提升