私は ASP.NET C# で Web サイトを持っていますが、ある場所で実行速度が非常に遅いです。プロファイラーを使用して調べたところ、GetResponse と GetRequest の 2 つの遅い箇所がありました。サードパーティのシステムに接続してカレンダーの空き状況を取得しているので、POST を介してサードパーティと通信しています。対応する ASP クラシックがあり、高速に見えますが、簡単にプロファイリングする方法がありません。
いくつかのことにもよりますが、約 440 バイトのバイト エンコードされた XML 文字列を送信していますが、戻り値は 2k 未満です。関連するルーチンのほとんどをここに含めます。GetEmptyWebProxy
読んだときに役立つ場合に備えて、デフォルトのプロキシをに設定してみました。
リクエスト/レスポンスの処理に 2 ~ 5 秒かかります。上司がカバを数えているのでプレッシャーがかかっており、Classic バージョンで実際の統計を取得できないため、現時点ではすべて認識です。
私の質問はこれです - 私はできる限り速く動いていますか、それは獣の性質ですか、それともこの通信をスピードアップするために何かできることはありますか? どんな助けでも大歓迎です。
ここにいくつかのコードがあります:
protected void UpdateInventory(DateTime _SelectedDate)
{
// build request object
Envelope _Request = new Envelope();
_Request.Body = new Body();
_Request.Body.QueryEvents = new QueryEvents();
_Request.Header = new Header();
//setup search criteria for API request
_Request.Body.QueryEvents.EventRangeBeginDate = _SelectedDate.ToString(_DTFormat);
_Request.Body.QueryEvents.EventRangeEndDate = _SelectedDate.AddDays(1).ToString(_DTFormat);
_Request.Body.QueryEvents.EventTypeID = _EventTypeId;
_Request.Header.SourceID = "BackOffice";
_Request.Header.MessageID = 0;
_Request.Header.MessageType = "QueryEvents";
_Request.Header.TimeStamp = LocaleHelper.LocalNow.ToString(_DTFormat);
_Request.Header.EchoData = "BO Calendar";
// send API request
HttpStatusCode _Status = GetGatewayInventory(_Request);
}
protected HttpStatusCode GetGatewayInventory(Envelope _InvRequest)
{
// set up return value
HttpStatusCode _RetVal = HttpStatusCode.Unused;
// initialize global inventory object
_Inventory = new Envelope();
// serialize request object into XML
XmlSerializer _Serializer = new XmlSerializer(_InvRequest.GetType());
MemoryStream _Stream = new MemoryStream();
_Serializer.Serialize(_Stream, _InvRequest);
XmlDocument _Doc = new XmlDocument();
_Stream.Position = 0;
_Doc.Load(_Stream);
// remove unneeded info.
XmlNode _Node = _Doc.SelectSingleNode("/Envelope");
XmlElement _ENode = (XmlElement)_Node;
_ENode.RemoveAttribute("xmlns:xsi");
_ENode.RemoveAttribute("xmlns:xsd");
// clean up
string _XmlStr = _Doc.InnerXml.Replace("\"1.0\"", "'1.0'");
byte[] _Bytes = System.Text.Encoding.ASCII.GetBytes(_XmlStr);
// send string to gateway
// set web request
string _GWHost = _GatewayHostLive;
HttpWebRequest _req = (HttpWebRequest)WebRequest.Create(_GWHost);
IWebProxy myProxy = GlobalProxySelection.GetEmptyWebProxy();
GlobalProxySelection.Select = myProxy;
_req.Proxy = myProxy;
_req.Method = "POST";
_req.ContentLength = _Bytes.Length;
_req.ContentType = "text/xml; encoding='utf-8'";
Stream _RequestStream = _req.GetRequestStream();
_RequestStream.Write(_Bytes, 0, _Bytes.Length);
_RequestStream.Close();
using (HttpWebResponse _Resp = (HttpWebResponse)_req.GetResponse())
{
_RetVal = _Resp.StatusCode;
if (_Resp.StatusCode == HttpStatusCode.OK)
{
Stream _respStream = _Resp.GetResponseStream();
XmlTextReader _xmlreader = new XmlTextReader(_respStream);
XmlDocument _RespXml = new XmlDocument();
_RespXml.Load(_xmlreader);
_xmlreader.Close();
// deserialize back into object
StringReader _sr = new StringReader(_RespXml.InnerXml);
XmlSerializer _XmlSr = new XmlSerializer(_Inventory.GetType());
XmlReader _Inreader = new XmlTextReader(_sr);
_Inventory = (Envelope)_XmlSr.Deserialize(_Inreader);
StripExtrasIfOnlyShowFirstAvailable(_Inventory, CountTotalTickets());
grd_EventTimes.DataSource = _Inventory.Body.Events.Event;
grd_EventTimes.DataBind();
grd_EventTimes.Visible = true;
if (_Inventory.Body.Events.Event.Count > 0)
lbl_GatewayId.Text = "GN: " + _Inventory.Body.Events.Event[0].EventName + " ID:" + _EventTypeId ;
}
_Resp.Close();
}
// exit and return value
return _RetVal;
}