Oracle中获取主机名和IP地址

  • Post author:
  • Post category:其他


1、利用sys_context函数我们可以获得当前session的hostname和ip address:

select sys_context('userenv','host') from dual;

SYS_CONTEXT(‘USERENV’,’HOST’)

——————————————————————————–

WORKGROUP\DRAGON-PC

select sys_context('userenv','ip_address') from dual;

SYS_CONTEXT(‘USERENV’,’IP_ADDR

——————————————————————————–

10.105.16.63

2、通过sys_context我们只能获得当前session的信息,如果要获得其他session,我们就用utl_inaddr包来获取。但是,我没有测试成功。

select utl_inaddr.get_host_address('DRAGON-PC') from dual;

而且我们还可以获得sina以及其他web site的ip

SQL> select utl_inaddr.get_host_address(‘www.sina.com.cn’) from dual;

UTL_INADDR.GET_HOST_ADDRESS(‘WWW.SINA.COM.CN’)

———————————————————————

218.30.108.55

其原理是:首先获取域名解析服务器(resolv.conf),在根据host.conf文件确定解析顺序,因为缺省的是hosts文件优先解析,这个时候会又继续读取/etc/hosts文件。

如果hosts文件存在解析关系,则返回信息;如果不存在,则继续问询DNS服务器,获得解析地址,如果不能解析,则会出错

ORA-29257: 未知的主机 DRAGON-PC

ORA-06512: 在 “SYS.UTL_INADDR”, line 19

ORA-06512: 在 “SYS.UTL_INADDR”, line 40

ORA-06512: 在 line 1



版权声明:本文为wym2006110322原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。