暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Oracle 触发器记录错误密码登录信息到alert

侯志清 2020-05-27
1636

问题描述

oracle 11g2的库,用户经常被锁定,现在的FAILED_LOGIN_ATTEMPTS 是10次,看网上有说看 listener.log 文件是哪个IP 导致的

专家解答

logon_denied_to_alert密码错误写入alert,创建后在alert日志里看是哪个IP错的

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; /

不建议改成unlimited,如果是业务用户不断的重连可能会有library cache lock。解决不了根本问题。

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论