oracle instant client,tnsping,tnsnames.ora和ORACLE_HOME
前段时间要远程连接oracle数据库,可是又不想在自己电脑上完整安装oracleclient,于是到oracle官网下载了轻量级clientinstant client。
这玩意没有图形界面,全靠sqlplus远程连接server,所以不占地方,正好满足我这样的追求“简单就好”的强迫症患者需求。
可是呢,可能是server那边没开监听port,我在自己的机子上尝试了各种配置,包含tnsnames.ora,sqlnet.ora等,远程连接均告失败。为了排查问题。我先ping了一下server的外网地址,发现没问题。网上说,光ping还是不够的,还要再tnsping一下。
tnsping,仅仅看名字的话。似乎也是ping的一种。可是,这个工具仅仅包括于完整的oracle客户端里。假设你安装的是instant client。就无法使用tnsping。
我恰好用的就是instant client,是不是非常悲剧?只是。当我到OTN Community逛了一圈之后。我发现tnsping也并不是那么神奇。OTN Community上面有个帖子把tnsping讲得非常透彻。我打算转述于此。原帖在https://community.oracle.com/thread/2434899?
start=0&tstart=0,有兴趣的能够看下。
tnsping所能做的,就是从TNS连接字符串中读取HOST和PORT參数,打开一个套接字连接。然后向监听发送一个ping。监听则以一个pong来响应。tnsping不能让TNS连接字符串中的其它參数生效,不能确定数据库实例和数据库服务的可用性。也不能确定诸如SID, SERVICE_NAME或INSTANCE_NAME等參数是否有效。可见。tnsping从来都不是多么高端的工具,非常多人用它測试TNS连接字符串,它仅仅是被用烂了而已。
instant client没有tnsping工具?不要紧。由于你能够用telnet <host> <port>取代tnsping。 连接測试成功之后。你再断开telnet就可以。
前面一直在说tnsping读取HOST和PORT參数。问题来了:这些參数在哪?要解决问题,就不得不提一个至关重要的配置文件:tnsnames.ora。
tnsnames.ora是一种配置文件,它定义了建立到一个数据库的连接所需的各种地址。
假设你安装了完整的oracleclient,该配置文件应该位于ORACLE_HOME\NETWORK\ADMIN文件夹下。其形式例如以下:
<addressname> =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(Host = <hostname>)(Port = <port>))
)
(CONNECT_DATA =
(SERVICE_NAME = <sid>)
)
)
一个完整的tnsnames.ora演示样例例如以下:
ORA11 =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = ORA11)
)
)
当然。假设你安装的是instant client,这个文件是不存在的,只是,你全然能够自建一个tnsnames.ora放在特定文件夹下。tnsnames.ora在客户端和server端各有一份。这些内容我參考了http://orafaq.com/wiki/Tnsnames.ora,上面还有更加具体的说明。那么,tnsnames.ora究竟起了什么作用?
事实上。这个配置文件有点像我们电脑里面的hosts文件。
这个文件实际上也是一个配置文件,作用就是把一些经常使用网址的域名和它的IP地址建立映射,当你在浏览器中输入一个网址域名,按下回车,系统首先自己主动从hosts文件里寻找该域名相应的IP地址,找到后就打开该地址相应的网页;假设没找到相应的IP地址,系统就把网址提交到DNS域名解析server上,由server解析出相应的IP地址。
hosts文件将便于记忆的网址解析为IP地址,tnsnames.ora则把便于记忆的TNS别名解析为连接字符串。连接字符串的格式通常为“(DISCRIPTION=(ADDRESS=<address details>)(CONNECT_DATA=<database
details>)”。
对照上面给出的tnsnames.ora演示样例。能够看出实际上tnsnames.ora正是包括了这个所谓的连接字符串。所以,当你使用sqlplus远程登录数据库时,你能够有两种方式。
一种方式是把连接字符串全然写出来,例如以下所看到的:
sqlplus scott/tiger@"(DESCRIPTION= (ADDRESS= (PROTOCOL=TCP)(HOST=my-dev.mydomain.com)(PORT=1521)) (CONNECT_DATA= (SID=orcldev) (SERVER=dedicated)))"
还有一种是直接将TNS别名写出来,以上面给出的tnsnames.ora为例:
sqlplus scott/tiger@ORA11
显然,另外一种方式更加简单。尤其在你须要频繁登录数据库的时候。用配置文件无疑会让你的效率大大提升,这个道理就像你为了编译方便而写makefile文件是一样的。
刚才说过,假设你安装的是instant client,它不带tnsping工具。没关系,你仅仅要明确tnsping是干什么的即可。
其实,它仅仅做三件事:1.假设你指定了TNS别名,它将别名解析为连接字符串(假设你登录时直接使用了完整的连接字符串,则跳过此步骤);2.依据连接字符串的HOST參数,測试你要连接的监听器的IP地址。3.依据连接字符串的PORT參数,測试你要连接的监听器的对应port。
显然,除了第1件事以外。第2,3件事你都能够使用telnet
<hostname> <port>取代。
instant client还有个不太方便的地方,刚才也提到过,就是它没有自带tnsnames.ora文件。只是,刚才也说过,你能够自己建立一个tnsnames.ora文件。
那么。oracle客户端如何找到这个文件呢?这就须要你加入一个名为TNS_ADMIN的环境变量,保存tnsnames.ora地址。系统会依据这个变量给出的地址找到相应的tnsnames.ora文件。
最后简单说一下ORACLE_HOME。这个变量表示oracle的安装文件夹,也能够表示一个指向oracle安装文件夹的环境变量。
在windows下。假设想要查看当前的ORACLE_HOME,使用echo命令就可以。要想加入或者设置ORFACLE_HOME环境变量,使用set命令就可以。当然,在注冊表中也能够找到ORACLE_HOME,可能位置是HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE。
更加详细的内容能够參考http://orafaq.com/wiki/ORACLE_HOME。
oracle instant client,tnsping,tnsnames.ora和ORACLE_HOME的更多相关文章
- 如何安装Oracle Instant Client
Oracle Instant Client是Oracle发布的轻量级数据库客户端,下面我们来看看官方的定义: Instant Client allows you to run your applica ...
- Oracle instant client在windows下的安装和使用
安装 * 从oracle官方网站下载instant client文件,一般来说,有basic.sqlplus.odbc.jdbc,就足够用的了: instantclient-basic-win32-1 ...
- Oracle Instant Client(即时客户端) 安装与配置
一.下载 下载地址:http://www.oracle.com/technetwork/database/features/instant-client/index-097480.html 这是Ora ...
- Oracle Instant Client的安装和使用
转自:https://www.cnblogs.com/chinalantian/archive/2011/09/09/2172145.html 根据自己需求到Oracle网站(http://www.o ...
- Oracle Instant Client 安装配置
一.下载 下载地址:http://www.oracle.com/technetwork/database/features/instant-client/index-097480.html 这是Ora ...
- Oracle instant client及pl sql developer的使用
Oracle instant client的使用 最近重装了操作系统,使用的是Windows7 x64的版本,不准备安装Oracle,于是从官网上看到了Instant Client. 兴冲冲下 ...
- win7 PLSQL Developer 10/11/12 连接 Oracle 10/11/12 x64位数据库配置详解(与32位一样,只要注意对应Oracle Instant Client版本) tns 错误和 nls错误
环境win7 x64 PLSQL Developer 10 与 11 Oracle Instant Client 10 与 12 参考http://blog.csdn.net/chen_zw/arti ...
- oracle 网络访问配置tnsnames.ora文件的路径
转自:https://blog.csdn.net/jaray/article/details/22379811 oracle 网络访问配置tnsnames.ora文件的路径 oracle 9i 是: ...
- ORACLE Instant Client 配置
http://www.oracle.com/technetwork/cn/database/features/instant-client/index-092699-zhs.html 在官网下载对应的 ...
随机推荐
- scrapy爬虫框架实例二
本实例主要通过抓取慕课网的课程信息来展示scrapy框架抓取数据的过程. 1.抓取网站情况介绍 抓取网站:http://www.imooc.com/course/list 抓取内容:要抓取的内容是全部 ...
- 《深入理解Java虚拟机》笔记6
class文件由无符号数和表两种类型数据构成.表其实相当于一种结构体,内部又嵌套无符号数或者表. 用u1,u2,u4,u8分别代表一个字节,两个字节,四个字节,八个字节的无符号数. 如图中所示,cla ...
- es服务
#!/bin/bash #chkconfig:2345 20 90 #description: elastic service #processname: elastic ROOT_PATH=/es5 ...
- 在笛卡尔坐标系上描绘函数 y=4x^2-2/4x-3
代码: <!DOCTYPE html> <html lang="utf-8"> <meta http-equiv="Content-Type ...
- SQL Server中按照条件随机返回数据
需求:查询对应关键字的数据,并随机返回一条. 这时,需要一个SQL的那只方法:NEWID(). 用法: [sql]SELECT TOP 1 * FROM Table WHERE TID = 1 ORD ...
- 算法笔记_083:蓝桥杯练习 合并石子(Java)
目录 1 问题描述 2 解决方案 1 问题描述 问题描述 在一条直线上有n堆石子,每堆有一定的数量,每次可以将两堆相邻的石子合并,合并后放在两堆的中间位置,合并的费用为两堆石子的总数.求把所有石子 ...
- 关于HTML、js加密、混淆、源码保护、代码安全,防止解压直接看源码
一直有人问HTML加密混淆怎么做,其实这在业内是早已很多人研究过的课题.假日期间整理一篇文章分享给大家. 我们先理下需求,加密的目的是什么?加密到什么级别?为此我们可以牺牲什么?我们知道这个世界不存在 ...
- recess----3.Controller如何和View关联
上一篇我们讲到,Recess框架里面的controller就是一个典型的MVC框架的controller,它负责处理从浏览器(或其它客户端)过来的request,然后调用引用model里面的方法来进行 ...
- Android 文件存储 和 权限管理
转载请标明出处: :http://blog.csdn.net/huaiyiheyuan/article/details/52473984 android SD卡主要有两种存储方式 Internal . ...
- mac 查看目前哪些进程占用哪些端口
lsof -nP | grep TCP | grep LISTEN lsof -i :TCP