0

私は 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;
}
4

1 に答える 1