Oracle v$session视图显示客户端IP地址

烈酒焚心 提交于 2021-02-12 15:28:01

在Oracle数据库中,我们使用session相关视图(v$session、v$active_session_history,dba_hist_active_session_history等)查找问题时,往往可以定位到相应的主机名,但是,想要更进一步查找IP地址时,却发现各个数据字典表里面都没有记录IP。而开发人员和领导往往更关注IP地址,那么,如何让Oracle数据库显示IP呢?

可以创建系统触发器来捕获IP地址,系统触发器如下:

-- 使用sys执行
create or replace trigger on_logon_trigger
after logon on database
begin
    dbms_application_info.set_client_info(sys_context( 'userenv', 'ip_address' ) );
end;
之后就可以在v$session中看到IP地址了

clipboard

但是在历史视图v$active_session_history,dba_hist_active_session_history中还是没有IP。

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!