欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-05-13 12:45:15
在Oracle数据库中,我们使用session相关视图(v$session、v$active_session_history,dba_hist_active_session_history等)查找问题时,往往可以定位到相应的主机名,但是,想要更进一步查找IP地址时,却发现各个数据字典表里面都没有记录... ......

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

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