Oracle中獲取主機名和IP地址

Davis_itpub發表於2018-06-27

利用sys_context函式我們可以獲得當前session的hostname和ip address

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

SYS_CONTEXT('USERENV','HOST')
--------------------------------------------------------------
WORKGROUP\IBM-L3YMBNP

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

SYS_CONTEXT('USERENV','IP_ADDRESS')
-----------------------------------------------------------
127.0.0.1

透過sys_context我們只能獲得當前session的資訊,如果要獲得其他session呢?
這個時候我們就用utl_inaddr包來獲取

SQL> select utl_inaddr.get_host_address('IBM-L3YMBNP') from dual;

UTL_INADDR.GET_HOST_ADDRESS('IBM-L3YMBNP')
-------------------------------------------------------------------
9.181.142.152

而且我們還可以獲得sina以及其他web site的ip
SQL> select utl_inaddr.get_host_address('') from dual;

UTL_INADDR.GET_HOST_ADDRESS('')
---------------------------------------------------------------------
218.30.108.55

其原理是:首先獲取域名解析伺服器(resolv.conf),在根據host.conf檔案確定解析順序,因為預設的是hosts檔案優先解析,這個時候會又繼續讀取/etc/hosts檔案。

如果hosts檔案存在解析關係,則返回資訊;如果不存在,則繼續問詢DNS伺服器,獲得解析地址,如果不能解析,則會出錯
SQL> select utl_inaddr.get_host_address('') from dual;
select utl_inaddr.get_host_address('') from dual
       *
ERROR 位於第 1 行:
ORA-29257: 未知的主機
ORA-06512: 在"SYS.UTL_INADDR", line 35
ORA-06512: 在"SYS.UTL_INADDR", line 40
ORA-06512: 在line 1

基本上就是這樣了。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31520497/viewspace-2156829/,如需轉載,請註明出處,否則將追究法律責任。

相關文章