Как увеличить время выполнения - PullRequest
0 голосов
/ 02 апреля 2020

у меня есть два приложения. net веб-API (версия 4.7.1)
первое приложение вызывает некоторые API из второго приложения
я хочу увеличить время ожидания до 5 минут
я добавляю executeTimeout до первого приложения, но не работает. Это веб-конфигурация моего первого приложения:

 <system.web>
    <compilation debug="false" targetFramework="4.7.1" />
    <httpRuntime targetFramework="4.7.1" executionTimeout="300" />
  </system.web>

я тестирую только с 2 se c
Я не знаю, почему не работает!

xxxxxxxxxxxxxxx

как я называю приложение socond:

public async System.Threading.Tasks.Task<TestResponseOfAccountViewModel> GetAllAccountsAsync(string pClientId, System.Threading.CancellationToken cancellationToken)
        {
            var urlBuilder_ = new System.Text.StringBuilder();
            urlBuilder_.Append(BaseUrl != null ? BaseUrl.TrimEnd('/') : "").Append("/api/Account/GetAllAccounts");

            var client_ = await CreateHttpClientAsync(cancellationToken).ConfigureAwait(false);
            try
            {
                using (var request_ = new System.Net.Http.HttpRequestMessage())
                {
                    var content_ = new System.Net.Http.StringContent(Newtonsoft.Json.JsonConvert.SerializeObject(pClientId, _settings.Value));
                    content_.Headers.ContentType = System.Net.Http.Headers.MediaTypeHeaderValue.Parse("application/json");
                    request_.Content = content_;
                    request_.Method = new System.Net.Http.HttpMethod("POST");
                    request_.Headers.Accept.Add(System.Net.Http.Headers.MediaTypeWithQualityHeaderValue.Parse("application/json"));

                    PrepareRequest(client_, request_, urlBuilder_);
                    var url_ = urlBuilder_.ToString();
                    request_.RequestUri = new System.Uri(url_, System.UriKind.RelativeOrAbsolute);
                    PrepareRequest(client_, request_, url_);

                    var response_ = await client_.SendAsync(request_, System.Net.Http.HttpCompletionOption.ResponseHeadersRead, cancellationToken).ConfigureAwait(false);
                    try
                    {
                        var headers_ = System.Linq.Enumerable.ToDictionary(response_.Headers, h_ => h_.Key, h_ => h_.Value);
                        if (response_.Content != null && response_.Content.Headers != null)
                        {
                            foreach (var item_ in response_.Content.Headers)
                                headers_[item_.Key] = item_.Value;
                        }

                        ProcessResponse(client_, response_);

                        var status_ = ((int)response_.StatusCode).ToString();
                        if (status_ == "200")
                        {
                            var objectResponse_ = await ReadObjectResponseAsync<TestResponseOfAccountViewModel>(response_, headers_).ConfigureAwait(false);
                            return objectResponse_.Object;
                        }
                        else
                        if (status_ != "200" && status_ != "204")
                        {
                            var responseData_ = response_.Content == null ? null : await response_.Content.ReadAsStringAsync().ConfigureAwait(false);
                            throw new EngineException("The HTTP status code of the response was not expected (" + (int)response_.StatusCode + ").", (int)response_.StatusCode, responseData_, headers_, null);
                        }

                        return default(TestResponseOfAccountViewModel);
                    }
                    finally
                    {
                        if (response_ != null)
                            response_.Dispose();
                    }
                }
            }
            finally
            {
                if (client_ != null)
                    client_.Dispose();
            }
        }

1 Ответ

1 голос
/ 02 апреля 2020

Существует несколько тайм-аутов, которые вы установили один из них в web.config, но есть и другой тайм-аут, который нужно установить, например, при выполнении HTTP-запросов / подключений к БД. В вашем случае вам нужно установить время ожидания в HttpClient , возвращаемом из CreateHttpClientAsyn c, например:

client.Timeout = TimeSpan.FromSeconds(seconds)

для увеличения время ожидания во втором вызове приложения

...