前面简单介绍了关于 listener 的概念,接下来进行一些实操
1、netmgr
netmgr(Net Manager)分为几个配置模块
(1)profile:对应于sqlnet.ora文件,可以设置客户端、服务器端
(2)Service Naming:对应tnsname.ora文件,配置客户端的本地网络名称解析
(3)Listeners:对应listener.ora文件,配置服务端监听器
2、netca
netmgr包含netca的所有操作功能,使用netca同样可以实现,这取决个人习惯。
监听配置、本地网络服务名配置是使用最多的功能,下面简单介绍使用图形界面的配置过程:
(1)listener配置:
输入监听器名称,创建好DB后会默认运行LISTENER的监听。
默认协议为 TCP/IP
选择监听器的端口,默认端口1521已经被LISTENER使用,这里输入另一个端口
端口冲突时会出现以下提示,虽然不影响继续配置,但是在没有解决端口冲突问题前不能启动该监听
(2)本地网络服务名 tnsname 配置
、
这里的服务名在前面有讲过,默认服务名与SID一致。但Oracle推荐使用与SID不同的名称作为 Service_name。
为了更好的理解服务名与监听的关系,这里故意留一个坑,哈哈!
这里的ip就是服务端地址,当然可以写主机名
配置完成后需要测试一下,保证以上配置的有效性
出现ORA-12514,这是因为上面输入的服务名 ORCL 没有在数据库中做定义,不能被监听器所识别,由此可见服务名的正确性是保证监听器与数据库完成通信的必要条件
修改以上错误,测试通过
为此次配置的本地网络服务输入一个名称
3、相关配置文件
那么上面配置工作完成后,输出的相关文件在哪里可以查找呢?
首先这里说明的是Linux平台环境,不同的
平台、数据库版本下文件存放路径与有一定区别。
(1)listener.ora 监听配置文件
路径:$ORACLE_HOME/network/admin
文件名:listener.ora
ORCL =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.20.50)(PORT = 1522))
)
)
对应的监听名、主机名、端口号都可以查看
(2)tnsname.ora 本地网络服务配置文件
路径与上面的监听配置文件相同
$ORACLE_HOME/network/admin
文件名:tnsnames.ora
ORCL =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.20.50)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = ORCL)
)
)
上面包含tns别名ORCL、主机地址以及服务名
4、监听常用命令
(1)帮助 LSNRCTL> help
(2)启停 lsnrctl start/stop
(2)状态查看 lsnrctl status
(4)常用设置 LSNRCTL> set
(5)指定监听器跟踪信息的位置 LSNRCTL> trc_file
......
5、测试本地网络服务配置的连通性
tnsping只是发送连接包至服务器端监听上,所以即使listener正常,客户端也不一定能连接到数据库服务器。tnsping主要检查的是远程监听是否启动在相应的IP地址和端口上,并不验证监听中的实例服务(数据库是否可用)。
为了说明这点,下面进行一个测试:
(1)监听状态
[oracle@RHEL admin]$ lsnrctl status
Service "db" has 1 instance(s).
Instance "db", status READY, has 1 handler(s) for this service...
(2)本地网络服务配置
ORCL =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.20.50)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = ORCL)
)
)
[oracle@RHEL admin]$ tnsping ORCL
Attempting to contact (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.20.50)(PORT = 1521))) (CONNECT_DATA = (SERVICE_NAME = ORCL)))
OK (10 msec)
可以看到监听状态与客户端网络配置中的 service_name 并不同,但tnsping依然正常,所以tnsping只检测监听配置中主机ip地址及端口有效性。
但是当客户端登录数据库时会出现 ORA-12514 错误:
[oracle@RHEL~]$ sqlplus system/123456@ORCL
ERROR:
ORA-12514: TNS:listener does not currently know of service requested in connect
descriptor
解决该问题的方法也就是检查实例服务是否与监听配置、客户端网络配置的服务命是否一致
Oracle网络服务基础(二)之监听器与TNS配置管理
来源:这里教程网
时间:2026-03-03 16:21:35
作者:
编辑推荐:
下一篇:
相关推荐
-
雷神推出 MIX PRO II 迷你主机:基于 Ultra 200H,玻璃上盖 + ARGB 灯效
2 月 9 日消息,雷神 (THUNDEROBOT) 现已宣布推出基于英
-
制造商 Musnap 推出彩色墨水屏电纸书 Ocean C:支持手写笔、第三方安卓应用
2 月 10 日消息,制造商 Musnap 现已在海外推出一款 Oce
热文推荐
- Oracle网络服务基础(二)之监听器与TNS配置管理
Oracle网络服务基础(二)之监听器与TNS配置管理
26-03-03 - ORACLE 数据库业务用户密码重置慎用特殊字符
ORACLE 数据库业务用户密码重置慎用特殊字符
26-03-03 - oracle优化之生产系统不改代码解决SQL性能问题的几种方法
oracle优化之生产系统不改代码解决SQL性能问题的几种方法
26-03-03 - Oracle网络服务基础(一)之监听器概念
Oracle网络服务基础(一)之监听器概念
26-03-03 - Oracle 21c新特性预览与日常管理相关的几个新特性
Oracle 21c新特性预览与日常管理相关的几个新特性
26-03-03 - ora-00279 ora-00289 ora-00280
ora-00279 ora-00289 ora-00280
26-03-03 - 深入解析 oracle drop table内部原理
深入解析 oracle drop table内部原理
26-03-03 - Oracle 9i 11g历史库升级迁移数据至19c CDB
Oracle 9i 11g历史库升级迁移数据至19c CDB
26-03-03 - Oracle 19c Database Configure the HTTPS Port for EM Express
- Oracle 19c Database Management Tools
Oracle 19c Database Management Tools
26-03-03
