質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.48%

  • Oracle Database 10g

    31questions

    Oracle DatabaseはRDBMSの商品です。具体的な発売商品として知られているのが、 Oracle9i、Oracle10g、Oracle 11gとOracle 12cです。

sqlnet.logにて、TNS-12547が発生する。

受付中

回答 1

投稿 編集

  • 評価
  • クリップ 2
  • VIEW 5,192

hrsi_teratail

score 68

oracle 10g R2 を使用しております。

vb.net .net3.5 を実行しているアプリケーション
より、ODP.NET を使用しORACLEへ接続しております。

下記のログが数秒単位で出力されています。

sqlnet.logにて、TNS-12547
が出力されます。

--


Fatal NI connect error 12547, connecting to:
 (LOCAL=NO)

  VERSION INFORMATION:
    TNS for Solaris: Version 10.2.0.5.0 - Production
    Oracle Bequeath NT Protocol Adapter for Solaris: Version 10.2.0.5.0 - Production
    TCP/IP NT Protocol Adapter for Solaris: Version 10.2.0.5.0 - Production
  Time: 24-3月 -2016 14:28:56
  Tracing not turned on.
  Tns error struct:
    ns main err code: 12547
    TNS-12547: TNS: 接続を失いました。
    ns secondary err code: 12560
    nt main err code: 0
    nt secondary err code: 0

    nt OS err code: 0

発生する原因がよくわかりません。

ご存知のかた教えてください。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • nabe3

    2016/04/07 20:27

    ・このエラーが出るのはどのタイミングですか?(例:sqlplusで接続する時) ・エラーが出る頻度はどの程度ですか?

    キャンセル

回答 1

+1

ODP.NETと言うことで。
OTNのスレッドで似たような問題がありました。
「ORA-12547: TNS:lost contact」が出てもアプリでエラーにならない。
こちらの例では接続プーリングを使用しなくすること(Pooling=False)で解決した、とあります。
まずはこちらを試して変化があるかを確認してはどうでしょうか。
参考ページ:Oracle® Data Provider for .NET開発者ガイド Oracleデータベースへの接続

Oracle Database Net Services リファレンス
SQLNET.INBOUND_CONNECT_TIMEOUT の説明には次のようにあります。

クライアントが指定の時間内に接続を確立し、認証を完了するのに失敗した場合、データベース・サーバーは接続を終了します。
クライアントは「ORA-12547: TNS: 接続を失いました。」または「ORA-12637: パケット受信に失敗しました。」のいずれかのエラー・メッセージを受け取ります。
特定の環境におけるシステムあるいはネットワークの通常の遅延によってクライアントが指定の時間内に接続を完了できない場合は、必要なだけ時間を増やします。

クライアント:sqlnet.ora・・・SQLNET.INBOUND_CONNECT_TIMEOUT
サーバー:listener.ora・・・INBOUND_CONNECT_TIMEOUT_listener_name
どちらも初期値は60秒と長めですが、もしかしたらセキュリティを考慮して
タイムアウト時間が短めに設定されていないか確認をしてみてください。

Oracle Database Net Services リファレンス 5 プロファイル・パラメータ(sqlnet.ora)
Oracle Database Net Services リファレンス 7 リスナー・パラメータ(listener.ora)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/04/11 12:31

    接続プーリングを使用しなくすること(Pooling=False)で現象は発生しなくなりました。ただ接続プーリングは使用したく、問題を解決したいと思っております。

    sqlnet.oraのファイルは存在しないので、デフォルトの60秒
    listener.oraにはINBOUND_CONNECT_TIMEOUT_listener_name は定義されておりませんので、デフォルトの60秒

    だという認識です。



    キャンセル

  • 2016/04/11 22:21

    ネットサービスの設定は上記認識で合っています。

    ODP.NETでの接続文字列に対する接続文字列属性は何が指定されていて、
    どのような設定がされているでしょうか?

    下記に接続文字列属性の一覧表があります。
    (ODP.NETのバージョンが明記されていませんでしたので下記は10.2.0.2の例です。)
    表3-1 サポートされている接続文字列属性
    http://otndnld.oracle.co.jp/document/products/oracle10g/102/doc_cd/win.102/B31247-01/featConnecting.htm#CJAEDBGH

    > Connection Timeoutに達していても、プールに有効な接続がない場合、
    > 接続プーリング・サービスは、接続プール要求がタイムアウトしたことを示す例外を呼び出します。
    この記述が今回のエラーと関連があるのではないかと思いました。
    Connection Timeoutの時間をデフォルトの15秒より長くする、
    プール内の接続の最大数(Max Pool Size)を多くするなど、
    設定をカスタマイズして様子を見てはいかがでしょうか?

    またVB.NET側でコネクションのClose, Disposeをきちんと行っているか、
    漏れはないか確認してみてください。
    con.ConnectionString = ~
    con.Open()
    ~処理~
    con.Close()
    con.Dispose()

    キャンセル

関連した質問

同じタグがついた質問を見る

  • Oracle Database 10g

    31questions

    Oracle DatabaseはRDBMSの商品です。具体的な発売商品として知られているのが、 Oracle9i、Oracle10g、Oracle 11gとOracle 12cです。