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

时间:2020-01-13 22:35:00 来源:互联网 作者: 神秘的大神 字体:

在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地址了

<img title="clipboard" style="border-top: 0px; border-right: 0px; background-image: none; border-bottom: 0px; padding-top: 0px; padding-left: 0px; border-left: 0px; display: inline; padding-right: 0px" border="0" alt="clipboard" src="https://img2018.cnblogs.com/blog/823295/202001/823295-20200113223437141-84092171.png" width="1075" height="137" class="img-responsive">

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