前段时间要远程连接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的更多相关文章

  1. 如何安装Oracle Instant Client

    Oracle Instant Client是Oracle发布的轻量级数据库客户端,下面我们来看看官方的定义: Instant Client allows you to run your applica ...

  2. Oracle instant client在windows下的安装和使用

    安装 * 从oracle官方网站下载instant client文件,一般来说,有basic.sqlplus.odbc.jdbc,就足够用的了: instantclient-basic-win32-1 ...

  3. Oracle Instant Client(即时客户端) 安装与配置

    一.下载 下载地址:http://www.oracle.com/technetwork/database/features/instant-client/index-097480.html 这是Ora ...

  4. Oracle Instant Client的安装和使用

    转自:https://www.cnblogs.com/chinalantian/archive/2011/09/09/2172145.html 根据自己需求到Oracle网站(http://www.o ...

  5. Oracle Instant Client 安装配置

    一.下载 下载地址:http://www.oracle.com/technetwork/database/features/instant-client/index-097480.html 这是Ora ...

  6. Oracle instant client及pl sql developer的使用

    Oracle instant client的使用   最近重装了操作系统,使用的是Windows7 x64的版本,不准备安装Oracle,于是从官网上看到了Instant Client.   兴冲冲下 ...

  7. 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 ...

  8. oracle 网络访问配置tnsnames.ora文件的路径

    转自:https://blog.csdn.net/jaray/article/details/22379811 oracle 网络访问配置tnsnames.ora文件的路径 oracle 9i  是: ...

  9. ORACLE Instant Client 配置

    http://www.oracle.com/technetwork/cn/database/features/instant-client/index-092699-zhs.html 在官网下载对应的 ...

随机推荐

  1. 转:一位10年Java工作经验的架构师聊Java和工作经验

    黄勇( 博客),从事近十年的 JavaEE 应用开发工作,现任阿里巴巴公司系统架构师.对分布式服务架构与大数据技术有深入研究,具有丰富的 B/S 架构开发经验与项目实战经验,擅长敏捷开发模式.国内开源 ...

  2. 破解IDEA Ultimate2017 测试

    转载:http://blog.csdn.net/linyanqing21/article/details/72594352 IntelliJ Idea 2017 免费激活方法: 1.到网站 http: ...

  3. iis服务器配置 url rewrite 模块

    从网上找了一下,原来微软IIS官方网站给IIS7及以后续版本提供了个URL重写组件. 下载地址:https://www.iis.net/downloads/microsoft/url-rewrite ...

  4. Linux 服务器环境启动

    1.PHP 关闭php killall php-fpm php重启 /usr/local/php/sbin/php-fpm & 或者 /usr/local/php/sbin/php-fpm { ...

  5. php 基于cookie的sessIon机制

    session_start()是session机制的开始,它有一定概率开启垃圾回收,因为session是存放在文件中,PHP自身的垃圾回收是无效的,SESSION的回收是要删文件的,这个概率是根据ph ...

  6. Android中为你的应用程序添加桌面快捷方式

    public void ShortCut(View view){ createDeskShortCut(this,getString(R.string.short_cut),R.drawable.up ...

  7. 怎样删除Weblogic Domain?

    转自:http://blog.csdn.net/biplusplus/article/details/7433558 旁白 由于没有现成的配置工具可以做这件事,我们需要手工来删除. 正题 以下方法适用 ...

  8. C++ Primer笔记2_四种类型转换_异常机制

    1.类型转换 命名的强制类型转换: 有static_cast.dynamic_cast.const_cast.reinterpret_cast static_cast: 编译器隐式运行的不论什么类型转 ...

  9. SQLSERVER常用计数器

    复制下面全部--开始--运行--profmon.exe--性能监视器--粘贴计数器列表 <OBJECT ID="DISystemMonitor1" WIDTH="1 ...

  10. PKCS7 的 attached 和 detached 方式的数字签名

    搜遍了整个网络,都没有详细的说明.只在一个页面上有介绍,还模棱两可的,地址是:http://docs.oracle.com/cd/E19398-01/820-1228/gfnmj/index.html ...