问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

在Oracle中如何确定远程session客户端的IP地址

发布网友 发布时间:2023-08-17 07:18

我来回答

1个回答

热心网友 时间:2024-02-22 20:20


在 Oracle 中如何确定远程 session 客户端的 IP 地址 前几天,Daniel 所在的环境多个数据库发生了一件惨案:我们把所有数据库主机、数据库的密码更改后, 硬件总集成的一台 windows 主机安装了一个 Oracle数据库监控工具,不断尝试利用错误的密码(有错有对




在 Oracle 中如何确定远程 session 客户端的 IP 地址





前几天,Daniel 所在的环境多个数据库发生了一件惨案:我们把所有数据库主机、数据库的密码更改后,

硬件总集成的一台 windows 主机安装了一个 Oracle数据库监控工具,不断尝试利用错误的密码(有错有对)

连接到我们的数据库中,导致生产环境多个数据库发生大量的 library cache lock 等待事件,虽说对应用

没带来影响,但是给数据库运维带来了巨*烦,所有的登录尝试都失败。十几个人、几家厂商查了一天多

最后还是凭感觉找到了那台windows主机和机主。这次事故给了我们惨痛的教训,使我不得不研究一下怎样

获得远程 session 的客户端 IP 地址,快速定位这类问题。Oracle 中获得 session 的客户端 IP 地址主要

分为当前 session 和非当前 session 的 IP 地址。





1、如何当前 session 的客户端 IP 地址





使用 SYS_CONTEXT namespace 可以获得当前 session 的客户端 IP 地址





[oracle@prod admin]$ sqlplus system/oracle123@prod





SQL*Plus: Release 11.2.0.3.0 Proction on Tue Mar 19 20:48:47 2013





Copyright (c) 1982, 2011, Oracle. All rights reserved.





Connected to:

Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - Proction

With the Partitioning, OLAP, Data Mining and Real Application Testing options





20:48:51 system@PROD>col "My IP Address" for a30

20:48:59 system@PROD>SELECT SYS_CONTEXT('USERENV','IP_ADDRESS') "My IP Address" from al;





My IP Address

------------------------------

192.168.8.160





注意:要想测试此方法不能通过操作系统认证方式连接到数据库,必须通过TNS,因为前者是通过IPC协议

连接,后者才是通过 TCP/IP 协议连接。





2、如何获得所有远程 Session 的客户端 IP 地址

在 Oracle 数据库中没有直接获取远程 session 客户端 IP 地址的方法。但是存在直接获取当前

session 客户端 IP 地址的方法。通过在数据库中创建 after logon 触发器,再结合使用

DBMS_APPLICATION_INFO.SET_CLIENT_INFO 存储过程,我们可以通过查询 v$session 来获取所有

远程 session 的客户端 IP 地址。





首先,创建如下触发器:









CREATE OR REPLACE TRIGGER login_on AFTER LOGON ON DATABASE

DECLARE

ipinfo VARCHAR2(30);

BEGIN

SELECT SYS_CONTEXT('USERENV','IP_ADDRESS') INTO ipinfo FROM DUAL;

DBMS_APPLICATION_INFO.SET_CLIENT_INFO(ipinfo);

END;

/





然后使用任意的用户远程(TNS)连接到数据库中,然后通过查询以下语句便可查看该 session 的客户端 IP 地址:





21:03:35 system@PROD>conn scott/tiger@prod

Connected.





21:04:05 scott@PROD>col sys_context('userenv','sid') for a40

21:04:18 scott@PROD>select sys_context('userenv','sid') from al;





SYS_CONTEXT('USERENV','SID')

----------------------------------------

125







用 system 用户创建一个 session 连接,在该 session 中来查询 scott 用户创建的 session 的客户端 IP 地址:





21:07:47 sys@PROD>col client_info for a30

21:08:04 sys@PROD>col CLIENT_IDENTIFIER for a30







21:08:17 sys@PROD>select username,sid,serial#,client_info,client_identifier from v$session where sid=125;





USERNAME SID SERIAL# CLIENT_INFO CLIENT_IDENTIFIER

------------------------------ ---------- ---------- ------------------------------ ------------------------------

SCOTT 125 35 192.168.8.160







21:08:43 sys@PROD>select username,sid,serial#,client_info,client_identifier from v$session where sid=18;





USERNAME SID SERIAL# CLIENT_INFO CLIENT_IDENTIFIER

------------------------------ ---------- ---------- ------------------------------ ------------------------------

SCOTT 18 17 192.168.8.100







[oracle@dss admin]$ sqlplus scott/tiger@prod

SQL*Plus: Release 11.2.0.3.0 Proction on Tue Mar 19 21:20:16 2013

Copyright (c) 1982, 2011, Oracle. All rights reserved.

Connected to:

Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - Proction

With the Partitioning, OLAP, Data Mining and Real Application Testing options





21:21:18 scott@PROD>col sys_context('userenv','sid') for a30

21:21:24 scott@PROD>select sys_context('userenv','sid') from al;





SYS_CONTEXT('USERENV','SID')

------------------------------

139







21:08:59 sys@PROD>select username,sid,serial#,client_info,client_identifier from v$session where sid=139;





USERNAME SID SERIAL# CLIENT_INFO CLIENT_IDENTIFIER

------------------------------ ---------- ---------- ------------------------------ ------------------------------

SCOTT 139 163 192.168.8.180













http://blog.csdn.net/xiangsir/article/details/8693734
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
电脑分辨率设置多少合适笔记本电脑分辨率多少最佳 各尺寸笔记本电脑的最佳分辨率 2022年高考480到510分能上山东科技大学吗 朋友借了我一万块钱,现在坐牢了怎么还钱? 天王星和海王星虽然看似一对姊妹星,但还是有区别 ...值得收藏吗?现在分别只都多少钱,照片上有一个铜币的 谁能告诉我这是一枚什么样的铜币,值不值钱? 有谁知道这铜币值不值钱,懂家告诉我一下!谢谢 有谁知道这个铜钱的来历 可以进行异地公积金贷款吗 松下洗衣机通电原因是什么 洗衣机里面带电是什么原因 顺丰快递能到湖北宜昌西陵开发区望州岗村三组吗? 小溪塔顺丰快递的电话是多少? 19年去过德国,现在要办理德国签证还需要去按指模吗 英比联合签按过指纹,去法国签证还需要按指纹吗 福鼎圆通快递公司在哪里 积家Q1738171香港多少钱 如何保持单元格引用的引用不变? 在excel单元格引用中,单元格地址不会随位移 excel中如何将引用位置保持不变? excel单元格引用中,单元格地址不会随位移 ...密码,itunes刷机恢复时提示需关闭“查找我的ipad”,请高手帮忙_百 ... Excel中套用公式后计算出来的结果有个别是错误的,但没有出错提示,是怎... 梦见梦到掉牙齿 喜剧大赛里说的观众是谁啊 一部喜剧是否好笑与否是由观众决定的吗? 为什么看喜剧的时候观众对被捉弄的人没用同情心 公务员考试草稿纸没写名字 考研演草纸没写名字 小溪塔超市有卖减肥药的吗 宜昌为什么要禁电动车??燃油助力车?? 甲硫酸的系统命名 关于生物化学得到判断题 1.ADPG是糖与氨基酸结合的产物 2.如果一生物... 我右手第五掌骨折 现在有点错位 不手术有影响吗 以后可以用力嘛_百度知 ... 掌骨骨折40天了拍片有错位怎么办 第五掌骨骨折如果错位了有什么感觉 手掌的掌骨错位多年还能治愈吗? 右手正斜位片,第4掌骨骨折,断端错位有片子怎么冶疗 举重妖精金福珠男主叫什么 南京夫子庙到1912酒吧街大概多远? 夫子庙到1912酒吧怎么乘车? 微信里浏览陌生人的朋友圈,对方知道吗? 梦见给三轮车打气没打上的预兆 梦见给自行车打气打不进去的预兆 什么是街车摩托车 60度会影响土壤中的钠含量吗 二氧化氮高温与低温平衡常数的关系 用什么方法洗十字绣又能把水润笔洗干净又不会把十字绣不掉色 抖音流量少点赞多什么原因