netcore保持活動狀態超時設置

用.netcore 2.2+ 創建WebApi項目,服務器爲k8s+docker+linux環境。

上線初期,由於調用方調用次數較少,會出現這麼一個情況,每隔幾分鐘再次調用,第1次接口都會變慢,繼續調用速度又變快了。根據以往的經驗,這個情況有點像似 IIS裏應用程序池被回收造成的。而.netcore採用kestrel作爲邊緣服務器,沒有應用程序池回收這一說法,但是應該是類似的原因。

看官方文檔,發現Kestrel有個選項屬性 “保持活動狀態超時”,即爲KeepAliveTimeout  ,默認爲2分鐘,項目的這個情況是否是這個 選項造成的呢?根據官方文檔,修改代碼,將

保持活動狀態超時 KeepAliveTimeout  設置爲10分鐘試一試。

 代碼如下:

在Program.cs裏

 

public class Program
    {
        public static void Main(string[] args)
        {
             System.Threading.ThreadPool.SetMinThreads(200, 200); 
            CreateWebHostBuilder(args).Build().Run();
        }

        public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
            WebHost.CreateDefaultBuilder(args).
            ConfigureLogging((context, loggingbuilder) =>
            {
                //該方法需要引入Microsoft.Extensions.Logging名稱空間

                loggingbuilder.AddFilter("System", LogLevel.Warning); //過濾掉系統默認的一些日誌
                loggingbuilder.AddFilter("Microsoft", LogLevel.Warning);//過濾掉系統默認的一些日誌
                //var path = Directory.GetCurrentDirectory() + "\\log4net.config"; 
                //不帶參數:表示log4net.config的配置文件就在應用程序根目錄下,也可以指定配置文件的路徑
                loggingbuilder.SetMinimumLevel(LogLevel.Debug);
                loggingbuilder.AddLog4Net("Config/log4net.config");
            })
              .UseStartup<Startup>()
            .ConfigureKestrel((context, serverOptions) =>
              {
                  //爲整個應用設置併發打開的最大 TCP 連接數,默認情況下,最大連接數不受限制 (NULL)
                  serverOptions.Limits.MaxConcurrentConnections = 100;
                  //對於已從 HTTP 或 HTTPS 升級到另一個協議(例如,Websocket 請求)的連接,有一個單獨的限制。 連接升級後,不會計入 MaxConcurrentConnections 限制
                  serverOptions.Limits.MaxConcurrentUpgradedConnections = 100; 
                  //獲取或設置保持活動狀態超時。 默認值爲 2 分鐘。
                  serverOptions.Limits.KeepAliveTimeout = TimeSpan.FromMinutes(10);
                //  serverOptions.Limits.RequestHeadersTimeout = TimeSpan.FromMinutes(1);
              });
    }

 

測試下來,感覺不怎麼管用。有誰能知道這個 KeepAliveTimeout  是幹嘛的嗎?

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章