热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

Oracle配置文件详解listener.ora,sqlnet.ora,tnames.ora

三个配置文件listener.ora、sqlnet.ora、tnsnames.ora,都是放在$oracle_homenetworkadmin目录下。重点:三个文件的作用和使

三个配置文件 listener.ora、sqlnet.ora、tnsnames.ora,都是放在$oracle_home\network\admin目录下。 重点:三个文件的作用和使

三个配置文件
listener.ora、sqlnet.ora、tnsnames.ora,都是放在$Oracle_home\network\admin目录下。

重点:三个文件的作用和使用

sqlnet.ora-----作用类似于linux或者其他unix的nsswitch.conf文件,通过这个文件来决定怎么样找一个连接中出现的连接字符串,
例如我们客户端输入
sqlplus sys/oracle@orcl
假如我的sqlnet.ora是下面这个样子

sqlnet.authentication_services= (nts)
names.directory_path= (tnsnames,hostname)

那么,客户端就会首先在tnsnames.ora文件中找orcl的记录.如果没有相应的记录则尝试把orcl当作一个主机名,通过网络的途径去解析它的ip地址然后去连接这个ip上global_dbname=orcl这个实例,当然我这里orcl并不是一个主机名
如果我是这个样子

names.directory_path= (tnsnames)

那么客户端就只会从tnsnames.ora查找orcl的记录
括号中还有其他选项,如ldap等并不常用。

tnsnames.ora------这个文件类似于unix 的hosts文件,提供的tnsname到主机名或者ip的对应,只有当sqlnet.ora中类似
names.directory_path= (tnsnames) 这样,也就是客户端解析连接字符串的顺序中有tnsnames是,才会尝试使用这个文件。

例子中有两个,orcl 对应的本机,sales对应的另外一个ip地址,里边还定义了使用主用服务器还是共享服务器模式进行连接,一句一句说

#你所要连接的时候输入得tnsname
orcl =
(description =
(address_list =
#下面是这个tnsname对应的主机,端口,协议
(address = (protocol = tcp)(host = 127.0.0.1)(port = 1521))
)
(connect_data =
#使用专用服务器模式去连接需要跟服务器的模式匹配,,如果没有就根据服务器的模式
#自动调节
(server = dedicated)
#对应service_name,sqlplus>;show parameter service_name;
#进行查看
(service_name = orcl)
)
)
#下面这个类似
sales =
(description =
(address_list =
(address = (protocol = tcp)(host = 192.168.188.219)(port = 1521))
)
(connect_data =
(server = dedicated)
(service_name = sales)
)
)


推荐阅读
author-avatar
孤独中残存的幸福_627
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有