一. IIS部署數據庫
好比在MVC框架中集成了Quartz.Net定時調度,此時該調度系統會隨着MVC框架被掛在IIS下,IIS會進程回收,因此大部分開發都會遇到Quartz掛在IIS下一段時間很差用。windows
補充:IIS能夠設置定時自動回收,默認回收是1740分鐘,也就是29小時。IIS自動回收至關於服務器IIS重啓,應用程序池內存清空,全部數據被清除,至關於IIS重啓,在度量快速開發平臺服務器端,爲了減少數據庫負擔,內存中暫存了不少信息,不適合頻繁的回收,由於回收會形成服務器端全部存在內存中的數據丟失,若是沒有及時保存到數據庫中,可能致使程序出現問題。而若是系統使用高峯時期,並不適合回收,回收可能致使幾十秒IIS無響應,對於正在工做的人員來講,是一種很很差的體驗,會覺得是網絡或者掉線等問題。服務器
解決方案:關閉該項目在IIS上對應的進程池的回收機制。網絡
如何關閉進程池的回收機制:選中IIS中部署的項目對應的進程池,點擊【高級設置】,裏面有5個核心參數:框架
① 發生配置更改時禁止回收:若是爲True,應用程序池在發生配置更改時將不會回收。運維
② 固定時間間隔(分鐘):超過設置的時間後,應用程序池回收,設置爲:0 意味着應用程序池不回收。系統默認設置的時間是1740(29小時)。函數
③ 禁用重疊回收:若是爲true,將發生應用程序池回收,以便在建立另外一個工做進程以前退出現有工做進程測試
④ 請求限制:應用程序池在回收以前能夠處理的最大請求數。若是值爲0,則表示應用程序池能夠處理的請求數沒有限制。ui
⑤ 生成回收事件日誌條目:每發生一次指定的回收事件時便產生一個事件日誌條目。spa
總結:即便能夠將IIS進程池回收關掉,仍然不建議把Quartz掛到IIS下,長時間不回收,會存在內存溢出的問題。
二. C/S程序直接運行
咱們能夠用控制檯的形式或者Winform的形式單獨作一套定時調度系統,與主框架分類,也便於維護,能夠直接將exe程序或者Winform窗體程序在服務器上運行。
總結:該方法不存在回收的問題,但直接在服務器上運行,容易不當心被運維人員關掉了。
對於專業一點的人員來講,該方案,直接運行程序太Low了,因此一般是將exe程序發不成windows服務,經過服務的開啓和關閉來 維護。
三. 藉助topshelf來進行的windows服務部署
官網:http://topshelf-project.com/ , 這是一種通用的發佈服務的方式,步驟以下:
1. 經過NuGet下載 Topshelf 的程序集
2. 配置QuartzService類,充當定時任務的服務端程序
①:構造函數中執行定時調度任務
②:Start()方法控制調度的開啓 (必填)
③:Stop()方法控制調度的關閉 (必填)
④:Pause()方法暫停調度 (選填)
⑤:Continue()方法繼續調度 (選填)
⑥:Shutdown() 關閉 (須要支持)
3. 在主程序中經過topshelf代碼調用: HostFactory.Run 詳見主程序。(在裏面能夠設置服務的名稱、描述等)
4. 經過指令進行服務發佈和卸載(查看windows服務:services.msc)
①:經過cmd命令定位到bin文件目錄下(以管理員身份運行)
(eg: 先輸入 d: 切換到D盤,再執行下面的命令 cd D:\06-個人開發之路\DotNet體系\04-DotNet專題篇\01-Quartz.Net定時調度\01-Code\MyQuarzt\QuartzDemo\bin\Debug )
②:QuartzDemo.exe help: 查看指令
QuartzDemo.exe install: 安裝服務
QuartzDemo.exe install start : 安裝服務且開啓
QuartzDemo.exe uninstall :卸載服務
截止此處,大功告成,能夠看到D盤中多了一個txt文件,每隔3s多一條數據
下面分享整個過程的代碼部署的相應截圖:
(1). Quartz代碼和TopSelf調用代碼:
1 public class QuartzService 2 { 3 IScheduler scheduler = null; 4 /// <summary> 5 /// 定時調度業務 6 /// </summary> 7 public QuartzService() 8 { 9 //1.建立做業調度池(Scheduler) 10 scheduler = StdSchedulerFactory.GetDefaultScheduler(); 11 12 //2.建立一個具體的做業即job (具體的job須要單獨在一個文件中執行) 13 var job = JobBuilder.Create<HelloJob5>().Build(); 14 15 //3.建立並配置一個觸發器即trigger 3s執行一次 16 var trigger = TriggerBuilder.Create().WithSimpleSchedule(x => x.WithIntervalInSeconds(3) 17 .RepeatForever()).Build(); 18 //4.將job和trigger加入到做業調度池中 19 scheduler.ScheduleJob(job, trigger); 20 } 21 /// <summary> 22 /// 開啓任務 23 /// </summary> 24 public void Start() 25 { 26 scheduler.Start(); 27 } 28 /// <summary> 29 /// 關閉任務 30 /// </summary> 31 public void Stop() 32 { 33 //true:表示該Sheduler關閉以前須要等如今全部正在運行的工做完成才能關閉 34 //false:表示直接關閉 35 scheduler.Shutdown(true); 36 } 37 /// <summary> 38 /// 暫停調度 39 /// </summary> 40 public void Pause() 41 { 42 scheduler.PauseAll(); 43 } 44 /// <summary> 45 /// 繼續調度 46 /// </summary> 47 public void Continue() 48 { 49 scheduler.ResumeAll(); 50 } 51 52 }
1 HostFactory.Run(x => //1 2 { 3 x.Service<QuartzService>(s => //2 4 { 5 s.ConstructUsing(name => new QuartzService()); //3 6 //開啓和關閉 必選項 7 s.WhenStarted(tc => tc.Start()); //4 8 s.WhenStopped(tc => tc.Stop()); //5 9 10 // optional pause/continue methods if used 11 // 暫停和繼續 選填 12 s.WhenPaused(tc => tc.Pause()); 13 s.WhenContinued(tc => tc.Continue()); 14 15 //// optional, when shutdown is supported 16 //s.WhenShutdown(tc => tc.Shutdown()); 17 18 }); 19 x.RunAsLocalSystem(); //6 20 x.SetDescription("測試藉助TopSelf將Quartz發佈成服務"); //7 21 x.SetDisplayName("QuartzService"); //8 22 x.SetServiceName("QuartzService2"); //9 23 });
(2). 定位到指定路徑,並進行相應的服務部署
a. 不少指令
b. 安裝服務並開啓
查看服務列表:
查看服務運行結果:
刪除服務:
三. 藉助window服務類
這裏不詳細介紹(網上一堆一堆的),推薦採用上面的TopShelf的服務發佈方式。