2016-07-28 11 views
0

Oracleデータベースからバルク・データを戻すasp.net Web APIサービス・エンドポイントを作成しています。返されたデータをJSON形式で変換しています。それは罰金働いていたが、突然、私は、文字列の結果でメモリ不足の例外というエラーを取得していますか、それは、ネットワーク・セッションを示している:私は、実行時に予期しないパケット読み取りエラーをメモリ不足例外またはOracle Unexceptedパケット読み取りエラー

public HttpResponseMessage Getdetails([FromUri] string[] id) 
{ 
    using (OracleConnection dbconn = new OracleConnection("DATA SOURCE=J;PASSWORD=C;PERSIST SECURITY INFO=True;USER ID=T")) 
    { 
     var inconditions = id.Distinct().ToArray(); 
     var srtcon = string.Join(",", inconditions); 
     DataSet userDataset = new DataSet(); 
     var strQuery = @"SELECT * from STCD_PRIO_CATEGORY where STPR_STUDY.STD_REF IN(" + srtcon + ")"; 
     OracleCommand selectCommand = new OracleCommand(strQuery, dbconn); 
     OracleDataAdapter adapter = new OracleDataAdapter(selectCommand); 
     DataTable selectResults = new DataTable(); 
     adapter.Fill(selectResults); 
     string result = JsonConvert.SerializeObject(selectResults); 
     string contentDisposition = "inline; filename=ProvantisStudyData.json"; 
     //byte[] byteInfo = Encoding.ASCII.GetBytes(result); 
     HttpResponseMessage response = Request.CreateResponse(HttpStatusCode.OK, result, MediaTypeHeaderValue.Parse("application/json")); 
     response.Content.Headers.ContentDisposition = ContentDispositionHeaderValue.Parse(contentDisposition); 
     //response.Content.Headers.ContentLength = byteInfo.Length; 
     return response; 
    } 
} 

enter image description here

しかし、 Oracle DB内の同じクエリは直接データを返します。それは50,000以上のレコードを返します。エラーは一貫性がなく、結果を返すことがあり、同じフィルターでOut of memory例外またはOracle Unexceptedパケット読み取りエラーを返すことがあります。

+0

これは、ネットワークを介してスラッグするデータの多くです。それがなぜ「突然」起こるのか、時には起こるのかはわかりません。私の推測はネットワークに関連するでしょう。人々が面白い猫のビデオを見ているとき、あなたは問題を抱えています。 –

+0

これは突然発生し、ときどきうまくいくことがあります。 – trx

答えて

1

JSON形式でネットワーク経由で送信された50,000件のレコードは、おそらく12メガバイト(おそらく低位)です。イーサネットではおよそ1キロバイトのパケットがあるので、応答は12 MB/1 KB /パケットで約12,000パケットになります。

データのサイズとエラーの原因を確認するには、エラーが発生しているマシンでWiresharkを使用してネットワークトラフィックを取得するのが良い方法です。これは、失われたネットワークパケット、パケットのサイズなどを表示します。ネットワーク上の何かを指摘することなくサーバー上でクエリを呼び出すことができるという事実。

もう1つの場所は、サーバー上のTNSリスナーのログファイルです。エラーをチェックするのは簡単なことです。コマンドログファイルがどこにあるかlsnrctl statusは言うだろう:

$ lsnrctl status 

LSNRCTL for Linux: Version 12.1.0.2.0 - Production on 28-JUL-2016 19:01:11 
Copyright (c) 1991, 2014, Oracle. All rights reserved. 
Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=example.com)(PORT=1521))) 
STATUS of the LISTENER 
------------------------ 
Version     TNSLSNR for Linux: Version 12.1.0.2.0 - Production 
Start Date    27-JUL-2016 14:33:08 

...

Listener Parameter File /u01/app/oracle/product/12.1.0.2/db_1/network/admin/listener.ora 
Listener Log File   /u01/app/oracle/diag/tnslsnr/plsekatlasexta01/listener/alert/log.xml 
Listening Endpoints Summary... 

を、解決策:

  • あなたはそのチャンクに出力を破ることができるだろうクライアントは別々の要求でリクエストできますか?
  • 一部の列のみが必要な場合は、すべての列を選択していますか?