常言道,多喝熱水,重啟試試。有時候當應用工作不正常,重啟也許能解決問題。但是程式員通常接觸不到伺服器系統許可權。而運維人員和公司流程經常人為製造麻煩阻止我們去重啟應用。老實的程式員不善言辭交際,只能放棄重啟,乾看程式碼,加班猝死。其實,我們可以在程式碼裡給自己留一個重啟應用的方法,教教他們別惹程式員的道理。
IApplicationLifetime
ASP.NET Core 有個很牛逼的介面,叫做IApplicationLifetime。它能用來處理網站啟動後,以及停止網站的任務。
這個介面提供了3個Cancellation Token,允許安排Action委託來處理應用啟動和關閉的事件:
public void Configure(IApplicationBuilder app, IHostingEnvironment env, IApplicationLifetime appLifetime)
{
appLifetime.ApplicationStarted.Register(() =>
{
_logger.LogInformation(“Moonglade started.”);
});
appLifetime.ApplicationStopping.Register(() =>
{
_logger.LogInformation(“Moonglade is stopping…”);
});
appLifetime.ApplicationStopped.Register(() =>
{
_logger.LogInformation(“Moonglade stopped.”);
});
// … 其他程式碼
}
ApplicationStarted 發生在應用啟動成功以後,也就是Startup.Configure()方法結束後。
ApplicationStopped 發生在程式正在完成正常退出的時候,所有請求都被處理完成。程式會在處理完這貨的Action委託程式碼以後退出。
ApplicationStopping 發生在程式正在執行退出的過程中,此時還有請求正在被處理。應用程式也會等到這個事件完成後,再退出。
我的例子裡,給這3個事件都記了日誌,以便觀察它們的行為。
讓網站自盡
IApplicationLifetime 除了剛才的3個事件,還有一個StopApplication() 方法,可以幹掉當前的 ASP.NET Core 應用程式。程式自殺的時候會依次執 ApplicationStopping 和 ApplicationStopped 的程式碼。正是基於這個,我們才能做到程式設計方式重啟ASP.NET網站。
安排重啟動作
最方便的重啟網站的方式就是訪問一個特定的URL啦。以ASP.NET Core MVC網站為例,我們可以這樣玩:
依賴註入
註入一個IApplicationLifetime到Controller裡。比如我部落格後臺的AdminController:
public class AdminController : MoongladeController
{
IApplicationLifetime applicationLifetime;
public AdminController(MoongladeDbContext context,
ILogger logger,
IOptions settings,
IConfiguration configuration,
IHttpContextAccessor accessor, IApplicationLifetime appLifetime)
: base(context, logger, settings, configuration, accessor)
{
applicationLifetime = appLifetime;
}
// …
}
自殺開關
定義一個Action,用來停止當前ASP.NET Core網站:
[HttpGet(“blow-me-up”)]
public IActionResult BlowMeUp()
{
applicationLifetime.StopApplication();
return new EmptyResult();
}
現在,只要訪問 blow-me-up 這個URL,網站就會自殺:
並且我們能看到正確的日誌輸出
重新啟動ASP.NET Core網站特別簡單,在IIS等host環境下,只要發一個新的request就能自動重啟!也就是重新訪問一下我們的網站即可~
今天就介紹這些內容。祝大家程式設計快樂,遇到問題先喝熱水再重啟,一定能解決 🙂