abp運行流程
由於公司現在大量向abp框架+react前后端分離架構轉型,所以有必要分析abp框架是如何在iis運行的,所以才有這篇文章
public class MvcApplication : AbpWebApplication<MyAbpApplicationWebModule>
{
protected override void Application_Start(object sender, EventArgs e)
{
AbpBootstrapper.IocManager.IocContainer.AddFacility<LoggingFacility>(
f => f.UseAbpLog4Net().WithConfig(Server.MapPath("log4net.config"))
);
base.Application_Start(sender, e);
}
}`
當web應用程序啟動,AbpWebApplication<TStartupModule>在AbpBootstrapper構造函數注冊Module,並檢查這個Module是否集成自AbpModule,初始化IocManager,PlugInSources以及日志實例。還注冊了攔截器
private void AddInterceptorRegistrars()
{
ValidationInterceptorRegistrar.Initialize(IocManager);
AuditingInterceptorRegistrar.Initialize(IocManager);
UnitOfWorkRegistrar.Initialize(IocManager);
AuthorizationInterceptorRegistrar.Initialize(IocManager);
}`
由AbpWebApplication.Application_Start初始化abp系統
protected virtual void Application_Start(object sender, EventArgs e)
{
ThreadCultureSanitizer.Sanitize();
AbpBootstrapper.Initialize(); //這里就是初始化abp系統,后面又詳細講到
}
我們注意到AbpWebApplication<TStartupModule>中的TStartupModule有個約束:TStartupModule:AbpModule讓我們來看下這個類的大體定義:
A module definition class is generally located in it's own assembly and implements some action in module events on application startup and shutdown.It also defines depended modules.
意思是在自己的模塊程序集中定義實現了一些在應用程序啟動到結束期間的事件操作,也定義依賴的那些模塊。在源代碼中能看到作者定義了四個事件操作:
- PreInitialize: 應用程序開始時觸發,在依賴注入注冊之前,代碼能放在這里運;
- Initialize: 主要用來依賴注入;
- PostInitialize: 應用程序啟動之后觸發;
- Shutdown: 應用程序結束時觸發
除了這四個周期事件,還有一種重要的操作就是遞歸查找所有依賴模塊類,返回所有的模塊類
public static List<Type> FindDependedModuleTypes(Type moduleType)
這里我就有一個疑問了,定義了這四個周期事件,那么是在哪里調用的呢?
帶着問題查找源代碼,發現在AbpBootstrapper.Initialize方法中注冊了模塊管理類:AbpModuleManager:
/// <summary>
/// Initializes the ABP system.
/// </summary>
public virtual void Initialize()
{
ResolveLogger();
try
{
RegisterBootstrapper();
IocManager.IocContainer.Install(new AbpCoreInstaller());
IocManager.Resolve<AbpPlugInManager>().PlugInSources.AddRange(PlugInSources);
IocManager.Resolve<AbpStartupConfiguration>().Initialize();
_moduleManager = IocManager.Resolve<AbpModuleManager>();
_moduleManager.Initialize(StartupModule);//這里初始話模塊集合以及加載所有模塊類
_moduleManager.StartModules();//這里就調用了模塊定義的周期事件操作
}
...
}
繼續追蹤AbpModuleManager.Initialize(Type startupModule);_moduleManager.StartModules();
在應用程序結束時(在abp系統中體現在AbpBootstrapper.Dispose)
public virtual void Initialize(Type startupModule)
{
_modules = new AbpModuleCollection(startupModule);//初始化模塊集合list
LoadAllModules();//加載所有模塊類
}
public virtual void StartModules()
{
var sortedModules = _modules.GetSortedModuleListByDependency();
sortedModules.ForEach(module => module.Instance.PreInitialize());
sortedModules.ForEach(module => module.Instance.Initialize());
sortedModules.ForEach(module => module.Instance.PostInitialize());
}
/// <summary>
/// Disposes the ABP system.
/// </summary>
public virtual void Dispose()
{
if (IsDisposed)
{
return;
}
IsDisposed = true;
_moduleManager?.ShutdownModules();//調用module.Instance.Shutdown
}
至此,我們就很清楚的知道了abp是在那個時期如何進行依賴注入的,是什么時候注冊插件以及自定義的四個“鈎子事件”
