LISTENER、TNSNAMES和SQLNET配置文件

本文详细介绍了Oracle数据库的连接验证方式,包括操作系统用户验证、EZCONNECT和TNSNAMES验证。同时,解析了listener.ora、tnsnames.ora和sqlnet.ora三个关键配置文件的用途和内容,如监听器设置、TNS连接名定义和网络连接参数。此外,讨论了local_listener参数的配置以及tnsnames.ora中连接描述符的定义。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

用户连接验证

Oracle数据库中用户有三种常见的登录验证方式:

  • 通过操作系统用户验证:必须是在数据库服务器本地登录,并且操作系统用户必须是oracle用户。此方式不会验证用户名和密码,并且登录数据库后的用户身份是SYS
sqlplus / as sysdba
sqlplus <username>/<wrong_password> as sysdba   # 输错密码也可以登录
  • 通过EZCONNECT连接方式验证:
sqlplus <username>/<password>@<listener_hostname>:<listener_port>/<service_name>
  • 通过TNSNAMES连接方式验证:此方式要求提前在tnsnames.ora中配置好TNS连接名。
sqlplus <username>/<password>@<TNS连接名>

listener.ora

🦈Oracle监听器的配置文件,位置在数据库服务器的$ORACLE_HOME/network/admin/listener.ora。Listener负责监听客户端的连接请求,并管理到连接到数据库服务器的流量。

文件配置

LISTENER =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = oracle19c)(PORT = 1521))
  )

SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
      (GLOBAL_DBNAME = mario)
      (ORACLE_HOME = /u01/app/oracle/product/19.0.0/dbhome_1/)
      (SID_NAME = mario)
    )
  )

ADR_BASE_LISTENER=/u01/app      # 监听器LISTENER的ADR自动诊断文件的位置
DIAG_ADR_ENABLED_LISTENER=OFF   # 是否开启对监听器LISTENER的ADR tracing

其中:

  • HOST:监听器所在本地服务器的主机名,也可以是IP地址。如果是主机名,需要在/etc/hosts文件或者DNS服务器中配置解析。
  • ORACLE_HOME:与oracle操作系统用户的环境变量${ORACLE_HOME}保持一致。
  • GLOBAL_DBNAMESID_NAME:通常与pfile中的db_nameinstance_name、以及oracle操作系统用户的环境变量${ORACLE_SID}保持一致。

监听日志

通过Listener监听日志可以协助排查一些客户端的连接问题。

grep -A5 '2022-04-27' $ORACLE_BASE/diag/tnslsnr/`hostname`/listener/alert/log.xml

local_listener参数

LREG进程只会动态注册(每隔1分钟)端口为1521的监听。如果要给监听器配置1521端口的监听,还需要修改local_listener参数。以配置1523监听端口为例,具体配置过程如下。

在Listener配置文件中添加:

LISTENER2 =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = oracle19c)(PORT = 1522))
  )

在TNS配置文件中添加:

LISTENER2 =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = oracle19c)(PORT = 1522))
  )

修改local_listener参数:

SQL> alter system set local_listener=listener2;

检查监听器状态:

lsnrctl status listener2
lsnrctl status

如果要恢复默认配置只需置空local_listener参数:

SQL> alter system set local_listener='';

tnsnames.ora

🦈TNS配置文件中可以定义一系列连接描述符,用于标识数据库服务的网络位置和服务名。其位置在客户端或者数据库服务端的$ORACLE_HOME/network/admin/tnsnames.ora

文件配置

MARIO =
(DESCRIPTION =
  (ADDRESS = (PROTOCOL = TCP)(HOST = oracle19c)(PORT = 1521))
  (CONNECT_DATA =
    (SERVER = DEDICATED)
    (SERVICE_NAME = mario)
  )
)

其中:

  • 第一行等号前的字符串(这里是MARIO)为定义的TNS连接描述符,用于通过TNS方式连接到数据库。一般不区分大小写。
  • HOST:Oracle数据库服务器(本地或者远程服务器都行)的主机名,也可以是IP地址。如果是主机名,需要在/etc/hosts文件或者DNS服务器中配置解析。
  • SERVICE_NAME:与pfile中的service_names参数保持一致。可以通过show parameter names语句查看。

sqlnet.ora

🦈SQLNET配置文件中定义了一组Oracle Net相关参数。其位置在客户端或者数据库服务端的$ORACLE_HOME/network/admin/sqlnet.ora

文件配置

SQLNET常见的一般配置如下:

# 解析客户端连接字符串所使用方法的先后顺序,默认顺序是:tnsnames > ldap > ezconnect
NAMES.DIRECTORY_PATH=(TNSNAMES,EZCONNECT)

ADR_BASE=/u01/app               # ADR自动诊断仓库文件的位置
DIAG_ADR_ENABLED=OFF            # 是否开启ADR tracing

# 每隔几分钟检查一次客户端和服务器连接是否还处于活跃状态
SQLNET.EXPIRE_TIME=10
# 客户端建立数据库连接的超时时间,默认60s
SQLNET.INBOUND_CONNECT_TIMEOUT=180
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

GottdesKrieges

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值