欢迎来到天天文库
浏览记录
ID:1323129
大小:64.00 KB
页数:8页
时间:2017-11-10
《oracle监听配置文件》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、Oracle监听配置文件最近看到好多人说到tns或者数据库不能登录等问题,就索性总结了下面的文档。首先来说Oracle的网络结构,往复杂处说能加上加密、LDAP等等。这里不做讨论,重点放在基本的网络结构也就是我们最常用的这种情况。l三个配置文件重点:三个文件的作用和使用。listener.ora、sqlnet.ora、tnsnames.ora,都是放在$ORACLE_HOMEetworkadmin目录下。sqlnet.ora作用类似于linux或者其他unix的nsswitch.conf文件,通过这个文件来决定怎么样找一个连接中出现的连接字符串。例如我们客户端输入sqlplussys/o
2、racle@orcl假如我的sq14lnet.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查找o
3、rcl的记录。括号中还有其他选项,如LDAP等并不常用。附注:没有SQLNET.AUTHENTICATION_SERVICES=(NTS)这条语句,用户登录时就不经过OS认证,而需要通过用户名/密码认证登录。#------------------------Tnsnames.ora——客户端这个文件类似于unix的hosts文件,提供的tnsname到主机名或者ip的对应。只有当sqlnet.ora中类似NAMES.DIRECTORY_PATH=(TNSNAMES)这样,也就是客户端解析连接字符串的顺序中有TNSNAMES时,才会尝试使用这个文件。例子中有两个,ORCL对应的本机,SALES对
4、应的另外一个IP地址,里边还定义了使用专用服务器还是共享服务器模式进行连接,一句一句的说…/*你所要连接的时候输入得TNSNAME*/ORCL=(DESCRIPTION=(ADDRESS_LIST=/*下面是这个TNSNAME对应的协议,主机和端口;127.0.0.1表示本地IP*/(ADDRESS=(PROTOCOL=TCP)(HOST=127.0.0.1)(PORT=1521)))(CONNECT_DATA=/*使用专用服务器模式去连接需要跟服务器的模式匹配,如果没有就根据服务器的模式自动调节*/(SERVER=DEDICATED)/*对应service_name,使用showparame
5、terservice_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)))#----------------------客户端完了我们来看服务器端。listener.ora——服务器listener监听器进程的配置文件。关于listener进程就不多说了,
6、接受远程对数据库的接入申请并转交给oracle的服务器进程。所以如果不是使用远程连接,listener进程就不是必需的,同样的如果关闭listener进程并不会影响已经存在的数据库连接。Listener.ora文件的例子:#listener.oraNetworkConfigurationFile:#E:%ORACLE_HOME%NETWORKADMINlistener.ora#GeneratedbyOracleconfigurationtools.#下面定义LISTENER进程为哪个实例提供服务#这里是ORCL,并且它对应的ORACLE_HOME和GLOBAL_DBNAME#其中GLO
7、BAL_DBNAME不是必需的除非使用HOSTNAME做数据库连接SID_LIST_LISTENER=(SID_LIST=(SID_DESC=(GLOBAL_DBNAME=boway)(ORACLE_HOME=E:oracleproduct10.1.0Db_2)(SID_NAME=ORCL)))#监听器的名字,一台数据库可以有不止一个监听器#再向下面是监听器监听的协议,IP和端口,这里使用
此文档下载收益归作者所有