oracle获取主机服务器IP

--要获取服务器端的IP
14:45:34 SYS@XXX> select utl_inaddr.get_host_address from dual;

GET_HOST_ADDRESS
--------------------------------------------------
10.19.2.XX

--解析域名
14:45:32 SYS@XXX> SELECT UTL_INADDR.get_host_address(‘www.anysql.net‘) from dual;

UTL_INADDR.GET_HOST_ADDRESS(‘WWW.ANYSQL.NET‘)
--------------------------------------------------
173.236.176.151

--根据IP地址反向解析主机名
14:47:14 SYS@XXX> select utl_inaddr.get_host_name(‘173.236.176.151‘) from dual;

UTL_INADDR.GET_HOST_NAME(‘173.236.176.151‘)
--------------------------------------------------
apache2-argon.footprint.dreamhost.com

--获取客户端IP
14:48:48 SYS@XXX> select   SYS_CONTEXT(‘USERENV‘,‘IP_ADDRESS‘) ip_address from dual;

IP_ADDRESS
--------------------------------------------------
10.19.2.XX

--获取客户端主机名
14:48:50 SYS@XXX>  select sys_context(‘userenv‘,‘host‘) from dual;

SYS_CONTEXT(‘USERENV‘,‘HOST‘)
--------------------------------------------------
WORKGROUP\WXX-THINK
 

UTL_INADDR包获取ip等信息的实现原理:

可参考盖神的文章:http://www.eygle.com/archives/2006/10/how_to_getip_address.html

在Linux可使用strace 命令进行相关命令的跟踪,在跟踪信息中获知

Oracle顺序访问了如下文件来完成地址定位:

open("/etc/resolv.conf", O_RDONLY) = 12
open("/etc/host.conf", O_RDONLY) = 12
open("/etc/hosts", O_RDONLY) = 12

首先获取域名解析服务器,在根据host.conf文件确定解析顺序,因为缺省hosts文件优先,又继续读取/etc/hosts文件。

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

14:49:31 SYS@XXX> select UTL_INADDR.get_host_address(‘www.a.com‘) from dual;
select UTL_INADDR.get_host_address(‘www.a.com‘) from dual
       *
第 1 行出现错误:
ORA-29257: 未知的主机 www.a.com
ORA-06512: 在 "SYS.UTL_INADDR", line 19
ORA-06512: 在 "SYS.UTL_INADDR", line 40
ORA-06512: 在 line 1

也就是说,UTL_INADDR的数据获取已经不依赖于数据库信息了,而SYS_CONTEXT的信息获取仍然来自数据库内部。

时间: 2024-10-28 23:46:26

oracle获取主机服务器IP的相关文章

Java获取网络IP

Java获取获取网络IP,浅尝辄止咯- 1 import java.net.InetAddress; 2 import java.net.UnknownHostException; 3 4 /** 5 * 获取网络IP 6 * 1.获取本地的IP地址 7 * 2.获取本机的服务器名称 8 * 3.获取远程服务器的主机IP地址 9 * 4.获取远程服务器的所有主机IP 10 * 11 * 网络编程: 12 * InetAddress 是用来封装IP地址相关信息的类 13 * getLocalHos

Python 之自动获取公网IP

2017年9月30日 0.预备知识 0.1 SQL基础 ubuntu.Debian系列安装: 1 [email protected]:~/python-script# apt-get install mysql-server Redhat.Centos 系列安装: 1 [[email protected] ~]# yum install mysql-server 登录数据库 1 [email protected]:~ $ mysql -uroot -p -hlocalhost 2 Enter p

php获取客户端IP

从Onethink代码里摘出来的 /**  * 获取客户端IP地址  * @param integer $type 返回类型 0 返回IP地址 1 返回IPV4地址数字  * @return mixed  */ function get_client_ip($type = 0) {     $type       =  $type ? 1 : 0;     static $ip  =   NULL;     if ($ip !== NULL) return $ip[$type];     if 

Linux学习之命令行获取公网IP方法详解

本文和大家分享的主要是主要是linux命令行获取公网IP相关内容,一起来看看吧,希望对大家学习linux有所帮助. curl ipinfo.io $ curl ipinfo.io { "ip": "36.10.25.4", "city": "Hangzhou", "region": "Zhejiang", "country": "CN", &quo

获取当前IP地址,跳转到对应城市网站。

index.php文件 1,通过获取当前IP地址, 2,调用新浪AIP,获取到当前城市. 3,将中文转换为拼音后跳转. <?php include './pinyin.php'; //获取当前ip function getIp(){ $onlineip=''; if(getenv('HTTP_CLIENT_IP')&&strcasecmp(getenv('HTTP_CLIENT_IP'),'unknown')){ $onlineip=getenv('HTTP_CLIENT_IP');

python 练习获取当前ip

#!/usr/bin/python from subprocess import Popen,PIPE def getIfconfig():     data = Popen(['ifconfig'], stdout=PIPE)     new_data = data.stdout.read().split('\n\n')     return [i for i in new_data if i] def getIp(data):     dic = {}     for i in data:

nginx 后端获取真实ip

nginx前端配置 server {listen 80;server_name blog.jinchuang.org; access_log logs/blog.access.log;error_log logs/blog.error.log;location / {proxy_pass http://dis ;                    proxy_set_header Host $host;                    proxy_set_header X-Real-I

C#获取局域网IP、MAC地址和端口的初学

首先非常感谢Melou的http://www.cnblogs.com/luoht/archive/2009/12/18/1627431.html的随笔,对于初学C#的我,参考你的随笔对我的学习真是有莫大帮助. C#遍历局域网的几种方法: 1.微软社区上介绍了使用Active Directory 来遍历局域网 首先我们来了解DirectoryEntry类是一个什么类. 命名空间:  System.DirectoryServices程序集:  System.DirectoryServices(在 S

c#中获取服务器IP,客户端IP以及Request.ServerVariables详细说明

客户端ip: Request.ServerVariables.Get("Remote_Addr").ToString(); 客户端主机名: Request.ServerVariables.Get("Remote_Host").ToString(); 客户端浏览器IE: Request.Browser.Browser; 客户端浏览器 版本号: Request.Browser.MajorVersion;// 客户端操作系统: Request.Browser.Platfo