TNS-01251: Cannot set trace/log directory under ADR

时间:2021-06-09 14:58:08

试图改变监听日志的名称时,报出TNS-01251错误:

$ lsnrctl 

LSNRCTL for Linux: Version 11.2.0.4. - Production on -JUN- ::

Copyright (c) , , Oracle.  All rights reserved.

Welcome to LSNRCTL, type "help" for information.

LSNRCTL> set log_file
Parameter Value: listener_test.log
Connecting to (ADDRESS=(PROTOCOL=tcp)(HOST=)(PORT=))
TNS-: Cannot set trace/log directory under ADR
LSNRCTL>

原因:

Oracle 11g中引入了ADR特性。

如果listener.ora文件中参数DIAG_ADR_ENABLED_listenername设置为on,则会忽略参数log_directory的设置。 trace文件和log文件被创建在ADR_BASE_listener_name指定的路径下。可以通过参数ADR_BASE_listener_name参数指定的位置作为trace和log文件的存放的base目录。

也可以通过在listener.ora中设置,取消ADR特性:

DIAG_ADR_ENABLED_listener_name=OFF 

LOG_DIRECTORY_listener_name = </path/.../>