listener.ora 、sqlnet.ora 、tnsnames.ora的关系以及手工配置举例

01.解决问题:TNS或者数据库不能登录。  
02.最简单有效方法:使用oracle系统提供的工具 netca 配置(把原来的删除掉重新配置)  
03.$netca  
04. 
05.俺仍有的疑问: 如何指定'listener.ora'存放的目录?不要默认目录($ORACLE_HOME/network/admin)  
06.方法1: 在 '.profile' 中加入(例)  
07.TNS_ADMIN=/f01/oracle11/app/oracle/product/8.0.6/network/admin  
08.export TNS_ADMIN  
09.    
10.  首先来说Oracle的网络结构,往复杂处说能加上加密、LDAP等等。。这里不做讨论,重点放在基本的网络结构也就是我们最常用的这种情况  
11.    
12.  三个配置文件  
13.    
14.  listener.ora、sqlnet.ora、tnsnames.ora ,都是放在$ORACLE_HOME\network\admin目录下。  
15.    
16.  --begin 重点:三个文件的作用和使用  
17.    
18.  #-----------------------    
19.  sqlnet.ora(客户及服务器端) --作用类似于linux或者其他unix的nsswitch.conf文件,通过这个文件来决定怎么样找一个连接中出现的连接字符串,  
20.    
21.  例如我们客户端输入  
22.    
23.  sqlplus sys/oracle@orcl  
24.    
25.  假如我的sqlnet.ora是下面这个样子  
26.    
27.  SQLNET.AUTHENTICATION_SERVICES= (NTS)  
28.    
29.  NAMES.DIRECTORY_PATH= (TNSNAMES,HOSTNAME)  
30.    
31.  那么,客户端就会首先在tnsnames.ora文件中找orcl的记录.如果没有相应的记录则尝试把orcl当作一个主机名,通过网络的途径去解析它的ip地址然后去连接这个ip上GLOBAL_DBNAME=orcl这个实例,当然我这里orcl并不是一个主机名  
32.    
33.  如果我是这个样子  
34.    
35.  NAMES.DIRECTORY_PATH= (TNSNAMES)  
36.    
37.  那么客户端就只会从tnsnames.ora查找orcl的记录  
38.    
39.  括号中还有其他选项,如LDAP等并不常用。  
40.    
41.  #------------------------    
42.  Tnsnames.ora(客户及服务器端) --这个文件类似于unix 的hosts文件,提供的tnsname到主机名或者ip的对应,只有当sqlnet.ora中类似  
43.    
44.  NAMES.DIRECTORY_PATH= (TNSNAMES) 这样,也就是客户端解析连接字符串的顺序中有TNSNAMES是,才会尝试使用这个文件。  
45.    
46.  例子中有两个,ORCL 对应的本机,SALES对应的另外一个IP地址,里边还定义了使用主用服务器还是共享服务器模式进行连接,一句一句说  
47.    
48.  #你所要连接的时候输入得TNSNAME  
49.    
50.  ORCL =  
51.    
52.  (DESCRIPTION =  
53.    
54.  (ADDRESS_LIST =  
55.    
56.  #下面是这个TNSNAME对应的主机,端口,协议  
57.    
58.  (ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521))  
59.    
60.  )  
61.    
62.  (CONNECT_DATA =  
63.    
64.  #使用专用服务器模式去连接需要跟服务器的模式匹配,如果没有就根据服务器的模式  
65.    
66.  #自动调节  
67.    
68.  (SERVER = DEDICATED)  
69.    
70.  #对应service_name,SQLPLUS>show parameter service_name;  
71.    
72.  #进行查看  
73.    
74.  (SERVICE_NAME = orcl)  
75.    
76.  )  
77.    
78.  )  
79.    
80.  #下面这个类似  
81.    
82.  SALES =  
83.    
84.  (DESCRIPTION =  
85.    
86.  (ADDRESS_LIST =  
87.    
88.  (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.8)(PORT = 1521))  
89.    
90.  )  
91.    
92.  (CONNECT_DATA =  
93.    
94.  (SERVER = DEDICATED)  
95.    
96.  (SERVICE_NAME = sales)  
97.    
98.  )  
99.    
100.  )  
101.    
102.  #----------------------    
103.  listener.ora(服务器端) --listener监听器进程的配置文件  
104.    
105.  关于listener进程就不多说了,接受远程对数据库的接入申请并转交给oracle的服务器进程。所以如果不是使用的远程的连接,listener进程就不是必需的,同样的如果关闭listener进程并不会影响已经存在的数据库连接。  
106.    
107.  Listener.ora文件的例子  
108.    
109.  #listener.ora Network Configuration File: #E:\oracle\product\10.1.0\Db_2\NETWORK\ADMIN\listener.ora  
110.    
111.  # Generated by Oracle configuration tools.  
112.    
113.  #下面定义LISTENER进程为哪个实例提供服务  
114.    
115.  #这里是ORCL,并且它对应的ORACLE_HOME和GLOBAL_DBNAME  
116.    
117.  #其中GLOBAL_DBNAME不是必需的除非使用HOSTNAME做数据库连接  
118.    
119.  SID_LIST_LISTENER =  
120.    
121.  (SID_LIST =  
122.    
123.  (SID_DESC =  
124.    
125.  (GLOBAL_DBNAME = boway)  
126.    
127.  (ORACLE_HOME = E:\oracle\product\10.1.0\Db_2)  
128.    
129.  (SID_NAME = ORCL)  
130.    
131.  )  
132.    
133.  )  
134.    
135.  #监听器的名字,一台数据库可以有不止一个监听器  
136.    
137.  #再向下面是监听器监听的协议,ip,端口等,这里使用的tcp1521端口,并且使#用的是主机名  
138.    
139.  LISTENER =  
140.    
141.  (DESCRIPTION =  
142.    
143.  (ADDRESS = (PROTOCOL = TCP)(HOST = boway)(PORT = 1521))  
144.    
145.  )  
146.    
147.  上面的例子是一个最简单的例子,但也是最普遍的。一个listener进程为一个instance(SID)提供服务。  
148. 
149.    --end 重点:三个文件的作用和使用  
150. 
151.    --===================================================================  
152.    
153.  监听器的操作命令  
154.    
155.  $ORACLE_HOME/bin/lsnrctl start,其他诸如stop,status等。具体敲完一个lsnrctl后看帮助。  
156.    
157.  上面说到的三个文件都可以通过图形的配置工具来完成配置  
158.    
159.  $ORACLE_HOME/netca 向导形式的  
160.    
161.  $ORACLE_HOME/netmgr  
162.    
163.  本人比较习惯netmgr,  
164.    
165.  profile 配置的是sqlnet.ora也就是名称解析的方式  
166.    
167.  service name 配置的是tnsnames.ora文件  
168.    
169.  listeners配置的是listener.ora文件,即监听器进程  
170.    
171.  具体的配置可以尝试一下然后来看一下配置文件。  
172.    
173.  这样一来总体结构就有了,是当你输入sqlplus sys/oracle@orcl的时候  
174.    
175.  1. 查询sqlnet.ora看看名称的解析方式,发现是TNSNAME  
176.    
177.  2. 则查询tnsnames.ora文件,从里边找orcl的记录,并且找到主机名,端口和service_name  
178.    
179.  3. 如果listener进程没有问题的话,建立与listener进程的连接。  
180.    
181.  4. 根据不同的服务器模式如专用服务器模式或者共享服务器模式,listener采取接下去的动作。默认是专用服务器模式,没有问题的话客户端就连接上了数据库的server process。  
182.    
183.  5. 这时候网络连接已经建立,listener进程的历史使命也就完成了。  
184. 
185.#---------------  
186.    
187.  几种连接用到的命令形式  
188.    
189.  1.sqlplus / as sysdba 这是典型的操作系统认证,不需要listener进程  
190.    
191.  2.sqlplus sys/oracle 这种连接方式只能连接本机数据库,同样不需要listener进程  
192.    
193.  3.sqlplus sys/oracle@orcl 这种方式需要listener进程处于可用状态。最普遍的通过网络连接。  
194.    
195.  以上连接方式使用sys用户或者其他通过密码文件验证的用户都不需要数据库处于可用状态,操作系统认证也不需要数据库可用,普通用户因为是数据库认证,所以数据库必需处于open状态。  
196.    
197.  然后就是  
198.    
199.  #-------------  
200.    
201.  平时排错可能会用到的  
202.    
203.  1.lsnrctl status查看服务器端listener进程的状态  
204.    
205.  LSNRCTL> help  
206.    
207.  The following operations are available  
208.    
209.  An asterisk (*) denotes a modifier or extended command:  
210.    
211.  start stop status  
212.    
213.  services version reload  
214.    
215.  save_config trace change_password  
216.    
217.  quit exit set*  
218.    
219.  show*  
220.    
221.  LSNRCTL> status  
222.    
223.  2.tnsping 查看客户端sqlnet.ora和tnsname.ora文件的配置正确与否,及对应的服务器的listener进程的状态。  
224.    
225.  C:\>tnsping orcl  
226.    
227.  TNS Ping Utility for 32-bit Windows: Version 10.1.0.2.0 - Production on 16-8月 -  
228.    
229.  2005 09:36:08  
230.    
231.  Copyright (c) 1997, 2003, Oracle. All rights reserved.  
232.    
233.  Used parameter files:  
234.    
235.  E:\oracle\product\10.1.0\Db_2\network\admin\sqlnet.ora  
236.    
237.  Used TNSNAMES adapter to resolve the alias  
238.    
239.  Attempting to contact (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)  
240.    
241.  (HOST = 127.0.0.1)(PORT = 1521))) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_  
242.    
243.  NAME = orcl)))  
244.    
245.  OK (20 msec)  
246.    
247.  3.  
248.    
249.  SQL>show sga 查看instance是否已经启动  
250.    
251.  SQL> select open_mode from v$database; 查看数据库是打开还是mount状态。  
252.    
253.  OPEN_MODE  
254.    
255.  ----------  
256.    
257.  READ WRITE  
258.    
259.  #-----------------  
260.    
261.  使用hostname访问数据库而不是tnsname的例子  
262.    
263.  使用tnsname访问数据库是默认的方式,但是也带来点问题,那就是客户端都是需要配置tnsnames.ora文件的。如果你的数据库服务器地址发生改变,就需要重新编辑客户端这个文件。通过hostname访问数据库就没有了这个麻烦。  
264.    
265.  需要修改  
266.    
267.  服务器端listener.ora  
268.    
269.  #监听器的配置文件listener.ora  
270.    
271.  #使用host naming则不再需要tnsname.ora文件做本地解析  
272.    
273.  # listener.ora Network Configuration File: d:\oracle\product\10.1.0\db_1\NETWORK\ADMIN\listener.ora  
274.    
275.  # Generated by Oracle configuration tools.  
276.    
277.  SID_LIST_LISTENER =  
278.    
279.  (SID_LIST =  
280.    
281.  (SID_DESC =  
282.    
283.  # (SID_NAME = PLSExtProc)  
284.    
285.  (SID_NAME = orcl)  
286.    
287.  (GLOBAL_DBNAME = boway)  
288.    
289.  (ORACLE_HOME = d:\oracle\product\10.1.0\db_1)  
290.    
291.  # (PROGRAM = extproc)  
292.    
293.  )  
294.    
295.  )  
296.    
297.  LISTENER =  
298.    
299.  (DESCRIPTION_LIST =  
300.    
301.  (DESCRIPTION =  
302.    
303.  (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC))  
304.    
305.  )  
306.    
307.  (DESCRIPTION =  
308.    
309.  (ADDRESS = (PROTOCOL = TCP)(HOST = boway)(PORT = 1521))  
310.    
311.  )  
312.    
313.  )  
314.    
315.  客户端sqlnet.ora 如果确认不会使用TNSNAME访问的话,可以去掉TNSNAMES  
316.    
317.  # sqlnet.ora Network Configuration File: d:\oracle\product\10.1.0\db_1\NETWORK\ADMIN\sqlnet.ora  
318.    
319.  # Generated by Oracle configuration tools.  
320.    
321.  SQLNET.AUTHENTICATION_SERVICES= (NTS)  
322.    
323.  NAMES.DIRECTORY_PATH= (HOSTNAME)  
324.    
325.  Tnsnames.ora文件不需要配置,删除也无所谓。  
326.    
327.  下面就是网络和操作系统的配置问题了,怎么样能够解析我的主机名的问题了  
328.    
329.  可以通过下面的方式连接  
330.    
331.  sqlplus sys/oracle@boway  
332.    
333.  这样的话,会连接boway这台服务器,并且listener来确定你所要连接的service_name。  
334. 
335.-------------------------------------------------------------------------------  
336.from:http://www.ixdba.net/hbcms/article/ec/231.html  
337.总结:  
338.1:监听文件listener.ora  tnsnames.ora中关于host的配置建议都用ip来表示,  
339.2:如果监听不能启动或者启动后不能正常使用,  
340.(1)首先确认你的OS的hostname,执行hostname命令,尝试ping "hostname",看是否能通,  
341.(2)然后检查监听的listener.ora ,tnsnames.ora这两个配置文件中关于host的信息是否是用主机名表示的。  
342.(3)如果是,更改到新的主机名,然后把新的主机名加入系统的hosts文件,linux下为/etc/hosts;  
343.然后ping 新主机名,应该能通的。  
344.(4)如果全部是用ip表示的,那么直接将新的主机名加入系统的hosts文件即可。  
345.然后ping 新主机名,也应该能通的。  
346. 
347.3:如果第二步还是解决不了问题,  
348. 
349.(1)检查启动的oracle的instance信息,select * fromv$instance;  
350.然后查看本级系统的主机名,两者应该是相等的。  
351.(2)如果查询出来的是老的主机名,尝试"ping老主机名"应该不通,  
352.通过listener也应该是连结不上;  
353.(3)如果是新的主机名,如果"ping新主机名"不通,  
354.请修改/etc/hosts文件增加新主机名,确认能ping通,然后重启oracle  
355. 
356.4:注意tns和listener文件的设置。  
357. 
358.具体操作步骤:  
359. 
360.1)修改hostname为<a href="http://www.sohu.com">www.sohu.com</a>  
361.2)修改/etc/hosts,去掉原来的主机名的行,增加该行  
362.   192.168.60.253 <a href="http://www.sohu.com/"><span style="background-color: rgb(240, 240, 240);">www.sohu.com</span></a> 



[sql] view plaincopy
01.3)重启数据库,查询instance信息  
02.   select * from v$instance;  
03.   得到新的HOST_NAME为<a href="http://www.sohu.com/"><span style="background-color: rgb(240, 240, 240);">www.sohu.com</span></a> 



[sql] view plaincopy
01.4)修改listener.ora,把HOST改成新的主机名  
02.5)修改tnsname.ora,修改对应的HOST为新的主机名  
03.6)重启listener  
04.然后connect oracle/oracle@standby应该可以成功的。 

你可能感兴趣的:(tnsnames.ora)