TNS-03505问题解决总结

Jun 07, 2016 pm 05:23 PM
データベース

最近部署项目,Linux系统使用非oracle用户测试(比如test)tnsping orcl出现如下提示信息:TNS-03505: Failed to resolve name

最近部署项目,,Linux系统使用非Oracle用户测试(比如test)tnsping orcl出现如下提示信息:
 
TNS Ping Utility for Linux: Version 11.2.0.1.0 - Production on 04-DEC-2012 14:29:28
 
Copyright (c) 1997, 2009, Oracle.  All rights reserved.
 
Used parameter files:
 
/opt/oracle/product/11g/network/admin/sqlnet.ora
 
TNS-03505: Failed to resolve name
 
乍一看,问题出现原因清楚明了。就是orcl服务名无法解析。但是我在本局域网使用其它windows系统中的pl/sql可以连接。
 
因为对Linux系统认知甚少,所以一头雾水。去网搜一下很多,大约有这么几种解决方案:
 
一是文件配置错误;
 
二是sqlnet.ora文件中NAMES.DIRECTORY_PATH设置问题;
 
三是lsnrctl status 监听错误或者sqlplus版本问题。 
 
第一种情况意思就是说在tnsnames.ora这个文件中我配置的orcl有问题,大部人说前面不能有空格,我的本来就没有;再就是listener.ora有一个标准的写法,如下:
 
SID_LIST_LISTENER =
 
  (SID_LIST =
 
    (SID_DESC =
 
      (SID_NAME = PLSExtProc)
 
      (ORACLE_HOME = /oracle/product/10.2.0/db_1)
 
      (PROGRAM = extproc)
 
    )
 
    (SID_DESC =
 
      (GLOBAL_DBNAME = orcl)
 
      (ORACLE_HOME = /oracle/product/10.2.0/db_1)
 
      (SID_NAME = orcl)
 
    )
 
  )
 
LISTENER =
 
  (DESCRIPTION_LIST =
 
    (DESCRIPTION =
 
      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))
 
      (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
 
)
 
)
 
第二种情况说的是通过客户端访问数据库服务器顺序。我也是从这个帖子发现我的问题的,我的linux用户test没有访问tnsname.ora这个文件的权限。
 
第三种情况说的是监听服务没起来。这个很容易就能查别,使用lsnrctl status即可知道。

通过解决这么一个问题,我总结一下思路:

首先:查询监听状态。因为我的可以通过其它客户端访问,所以不会是监听的问题。
 
其次:使用oracle用户,测试tnsping orcl。一般情况下肯定通。非oracle用户并且不属于oracle用户所属组的查看是否有权限。没有权限使用: chmod o+r tnsname.ora即可。
 
最后:版本兼容性的问题。

linux

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Go 言語はデータベースの追加、削除、変更、クエリ操作をどのように実装しますか? Go 言語はデータベースの追加、削除、変更、クエリ操作をどのように実装しますか? Mar 27, 2024 pm 09:39 PM

Go 言語はデータベースの追加、削除、変更、クエリ操作をどのように実装しますか?

PHP で MySQLi を使用してデータベース接続を確立するための詳細なチュートリアル PHP で MySQLi を使用してデータベース接続を確立するための詳細なチュートリアル Jun 04, 2024 pm 01:42 PM

PHP で MySQLi を使用してデータベース接続を確立するための詳細なチュートリアル

MySQL と PL/SQL の類似点と相違点の比較 MySQL と PL/SQL の類似点と相違点の比較 Mar 16, 2024 am 11:15 AM

MySQL と PL/SQL の類似点と相違点の比較

Hibernate はポリモーフィック マッピングをどのように実装しますか? Hibernate はポリモーフィック マッピングをどのように実装しますか? Apr 17, 2024 pm 12:09 PM

Hibernate はポリモーフィック マッピングをどのように実装しますか?

iOS 18では、紛失または破損した写真を復元するための新しい「復元」アルバム機能が追加されます iOS 18では、紛失または破損した写真を復元するための新しい「復元」アルバム機能が追加されます Jul 18, 2024 am 05:48 AM

iOS 18では、紛失または破損した写真を復元するための新しい「復元」アルバム機能が追加されます

MySQL データベース管理システムの基本原理の分析 MySQL データベース管理システムの基本原理の分析 Mar 25, 2024 pm 12:42 PM

MySQL データベース管理システムの基本原理の分析

HTML がデータベースを読み取る方法の詳細な分析 HTML がデータベースを読み取る方法の詳細な分析 Apr 09, 2024 pm 12:36 PM

HTML がデータベースを読み取る方法の詳細な分析

PHP を使用してデータベース内の中国語の文字化けを処理するためのヒントと実践 PHP を使用してデータベース内の中国語の文字化けを処理するためのヒントと実践 Mar 27, 2024 pm 05:21 PM

PHP を使用してデータベース内の中国語の文字化けを処理するためのヒントと実践

See all articles