asp.net core 系列 9 三種運行環境和IIS發布


一.在asp.net core中使用多個環境

  ASP.NET Core 配置是基於運行時環境, 使用環境變量。ASP.NET Core 在應用啟動時讀取環境變量ASPNETCORE_ENVIRONMENT,並將該值存儲在 IHostingEnvironment.EnvironmentName 中。ASPNETCORE_ENVIRONMENT 可設置為任意值,但框架支持三個值:Development、Staging 和 Production。 如果發布項目未設置 ASPNETCORE_ENVIRONMENT,則默認為 Production (本機vs中項目Properties\launchSettings.json中environmentVariables默認設置的是Development,如果禁用environmentVariables,那默認則為Production)。

  下面是Startup. Configure中的默認實現,本機默認配置的是Development環境。

     //如果是Development環境
     if (env.IsDevelopment())
     {
          //當捕獲同步和異步系統。管道中的異常實例,並生成HTML錯誤響應。
          app.UseDeveloperExceptionPage();
     }
     else
     {
          //如果不是Development環境,向管道中添加一個中間件,用於捕獲異常、記錄異常並進行重置
          app.UseExceptionHandler("/Home/Error");
          app.UseHsts();
      }
1.1 Development 模式

       開發環境可以啟用不應該在生產中公開的功能, 例如ASP.NET Core 模板在開發環境中啟用了開發人員異常頁(app.UseDeveloperExceptionPage())。當出現異常時,顯示錯誤頁信息如下圖所示:

  本地計算機開發環境可以在項目的 Properties\launchSettings.json 文件中設置。 在 launchSettings.json 中設置的環境值替代在系統環境中設置的值。新建的mvc項目默認配置如下:

{
  "iisSettings": {
    "windowsAuthentication": false, 
    "anonymousAuthentication": true, 
    "iisExpress": {
      "applicationUrl": "http://localhost:30081",
      "sslPort": 44349
    }
  },
  "profiles": {
    "IIS Express": {
      "commandName": "IISExpress",
      "launchBrowser": true,
      "environmentVariables": {
        "ASPNETCORE_ENVIRONMENT": "Development"
      }
    },
    "MyNetCoreStudy_MVC": {
      "commandName": "Project",
      "launchBrowser": true,
      "applicationUrl": "https://localhost:5001;http://localhost:5000",
      "environmentVariables": {
        "ASPNETCORE_ENVIRONMENT": "Development"
      }
    }
  }
}

launchSettings.json 中的 applicationUrl 屬性可指定服務器 URL 的列表。 在列表中的 URL 之間使用分號。注意:launchSettings.json只用於本機在vs 中開發使用,在開發中可以選擇三種之中任意一種的環境模式。當項目發布后,發布后(iis做反向代理),發布的文件中並不會有launchSettings.json文件。

  如果不用vs來啟動應用程序,使用 dotnet run 命令來 啟動應用程序時,使用具有 "commandName": "Project" 的第一個配置文件。 commandName 的值指定要啟動的 Web 服務器。 commandName 可為以下任一項:IIS Express、IIS、Project(啟動 Kestrel 的項目)。

  當使用dotnet run 啟動應用時:1會讀取 launchSettings.json中的environmentVariables;2是會顯示打印出host 環境。

 

  1.2  Production  模式

         Production 環境應配置為最大限度地提高安全性、性能和應用可靠性。 不同於開發環境的一些通用設置包括:

    (1) 緩存

    (2) 客戶端資源被捆綁和縮小,並可能從 CDN (網絡分發)提供。

    (3) 已禁用診斷錯誤頁。

    (4) 已啟用友好錯誤頁。

    (5) 已啟用生產記錄和監視。

 

二. 環境設置

   在項目中為測試設置特定環境通常很有用。 如果未設置環境,默認值為 Production,這會禁用大多數調試功能。設置環境的方法取決於操作系統。例如將asp.net core razor項目發布后,部署到IIS上,訪問OtherPages/page1時出現異常。此時默認是Production 環境變量,會顯示了error頁面信息, 表示已啟用友好錯誤頁。如下圖所示 :

  

  2.1  修改環境變量

  上面講到,設置環境的方法取決於操作系統:有Azure 應用服務、Windows、macOS、Linux等。每種操作系統上設置環境變量的方法不同,這里不在介紹,具體參考文檔。這里就先只介紹在Windows操作系統上以iis做反向代理的配置環境變量。

  在Windows操作系統上配置環境變量方法有很多。當發布后,文件中有一個web.config。這里就介紹下在web.config中設置 ASPNETCORE_ENVIRONMENT 環境變量。使用 web.config 設置 ASPNETCORE_ENVIRONMENT 環境變量后,它的值會替代系統級設置。

<aspNetCore processPath="dotnet" arguments=".\MyNetCoreStudy.dll" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout" hostingModel="InProcess">
        <environmentVariables>
          <environmentVariable name="ASPNETCORE_ENVIRONMENT" value="Development" />
        </environmentVariables>
      </aspNetCore>

此時iis上該項目就是Development開發環境了,再次訪問OtherPages/page1時出現異常,此時會捕獲同步和異步系統。管道中的異常實例,並生成HTML錯誤響應。詳細異常信息如下圖所示:

  

三. 發布到IIS上步驟

  下面簡單講下發布到IIS上的步驟實現:

    (1) 安裝好IIS,網上很多參考資料。

    (2)下載dotnet-hosting-2.2.1-win.exe 用於在iis上處理對web服務器的請求。下載地址介紹:

    https://docs.microsoft.com/zh-cn/aspnet/core/host-and-deploy/iis/index?view=aspnetcore-2.2#install-the-net-core-hosting-bundle

  在里面找到“當前 .NET Core 托管捆綁包安裝程序(直接下載)”這里進去可以下載到當前版本(aspnetcore-2.2),安裝后,在iis模塊中能看到AspNetCoreModuleV2。對應發布項目中web.config的<handlers>處理。

     <handlers>
        <add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModuleV2" resourceType="Unspecified" />
      </handlers>

    (3) 在vs中右擊項目發布,選擇"iis Ftp" 點擊發布。 選擇“文件系統”, 目標位置可以選擇當前電腦位置如: D:\DonetCoreStudy\IIS

     (4) 在iis這邊,添加網站      

    (5) 在應用程序池中對項目(MyNetCoreStudy)  選擇無托管代碼。

     這樣發布到iis上就成功了。

      (6) 發布后打開頁面,如果出現數據庫連接不上,在發布時要選擇,如下圖所示:

   還有就是連接配置改成sa的用戶名和密碼登錄,sqlserver服務的登錄為本地服務

   

 

     (7) iis調試,發布后打開網頁,在vs 2019中附加進程后,無法進入斷點調試,解決是發布為debug模式,如下圖所示:

      

 

四. 基於環境的 Startup 類

   最后在講下Startup 類約定。當 ASP.NET Core 應用啟動時,會啟動Startup類。 應用程序可以為不同的環境,單獨定義 Startup 類。可以定義例如: StartupDevelopment類、StartupProduction類,Startup類。當程序運行時會選擇相應的 Startup 類。 程序會優先考慮名稱后綴與當前環境相匹配的類。如果是Developmen環境則程序進入StartupDevelopment類,如果是Production環境則程序進入StartupProduction類。如果找不到匹配的 Startup{EnvironmentName},就會使用 Startup 類。

  基於環境的 Startup 類實現代碼如下:

public class StartupDevelopment
    {
        public void ConfigureServices(IServiceCollection services)
        {
            // ...
        }

        public void Configure(IApplicationBuilder app, IHostingEnvironment env)
        {
            // ...
        }
    }

    // Startup class to use in the Production environment
    public class StartupProduction
    {
        public void ConfigureServices(IServiceCollection services)
        {
            //...
        }

        public void Configure(IApplicationBuilder app, IHostingEnvironment env)
        {
            // ...
        }
    }
        
// Fallback Startup class
// Selected if the environment doesn't match a Startup{EnvironmentName} class
public class Startup
{
    public void ConfigureServices(IServiceCollection services)
    {
        //...
    }

    public void Configure(IApplicationBuilder app, IHostingEnvironment env)
    {
        //...
    }
}
/// <summary>
/// 根據環境變量,動態加載Startup的程序集類
/// </summary>
/// <param name="args"></param>
/// <returns></returns>
public static IWebHostBuilder CreateWebHostBuilder(string[] args)
{
     var assemblyName = typeof(Startup).GetTypeInfo().Assembly.FullName;

     return WebHost.CreateDefaultBuilder(args)
     .UseStartup(assemblyName);
}

參考文獻

官方資料:asp.net core 環境

歡迎添加個人微信號:Like若所思。

歡迎關注我的公眾號,不僅為你推薦最新的博文,還有更多驚喜和資源在等着你!一起學習共同進步!


 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM