这个文件类似于 unix 的 hosts 文件,提供的 tnsname 到主机名或者 ip 的对应,只有当 sqlnet.ora 中类似 NAMES.DIRECTORY_PATH=(TNSNAMES) 这样,也就是客户端解析连接字符串的顺序中有 TNSNAMES 是,才会尝试使用这个文件。
一、例子
ORCL =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521))
)
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
)
)
二、 TNS参数说明
- PROTOCOL:客户端与服务器端通讯的协议,一般为TCP,该内容一般不用改。
- HOST:数据库侦听所在的机器的机器名或IP地址,数据库侦听一般与数据库在同一个机器上,所以当我说数据库侦听所在的机器一般也是指数据库所在的机器。在UNIX或WINDOWS下,可以通过在数据库侦听所在的机器的命令提示符下使用hostname命令得到机器名,或通过ipconfig(for WINDOWS) or ifconfig(for UNIX)命令得到IP地址。需要注意的是,不管用机器名或IP地址,在客户端一定要用ping命令ping通数据库侦听所在的机器的机器名,否则需要在 hosts文件中加入数据库侦听所在的机器的机器名的解析。
- PORT:数据库侦听正在侦听的端口,可以察看服务器端的listener.ora文件或在数据库侦听所在的机器的命令提示符下通过lnsrctl status [listener name]命令察看。此处Port的值一定要与数据库侦听正在侦听的端口一样。
- SERVICE_NAME:在服务器端,用system用户登陆后,sqlplus> show parameter service_name命令察看。
- 可选参数
- FAILOVER
- LOAD_BALANCE
- RECV_BUF_SIZE
- SDU
- SEND_BUF_SIZE
- SOURCE_ROUTE
- TYPE_OF_SERVICE(如rdb)