ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 监控database上的客户端ip地址

监控database上的客户端ip地址

原创 Linux操作系统 作者:zhanglei_itput 时间:2009-04-02 20:30:50 0 删除 编辑

v$session 中记录着客户端的机器名称,但是没有IP , 如果记录clinet ip 呢,可以考虑用创建触发器的办法:

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的client_info列会记录其相应的IP信息。
这里才查询v$session ,你会发现 v$session 多了一列 记录客户端的IP.
select client_info from v$session;
---------------------------------
CLIENT_INFO 
192.16.1.66
弊端:1.如果是中间件连接的话,意义不大
            2.当客户发出conn时,可能会稍慢一些。

2. 利用 DBMS_SESSION 过程包. (未测试)

BEGIN
DBMS_SESSION.set_identifier(SYS_CONTEXT('USERENV', 'IP_ADDRESS'));
END;

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/9252210/viewspace-584425/,如需转载,请注明出处,否则将追究法律责任。

下一篇: 小假期第一天
请登录后发表评论 登录
全部评论

注册时间:2009-02-10

  • 博文量
    400
  • 访问量
    1117345