系统数据监控。
using System; using System.Collections.Generic; using System.Diagnostics; using System.Linq; using System.Text; using System.Threading; using Arch.CFramework.CLoggingAdapter; using Ctrip.Mobile.AppDownload.Utility; namespace Ctrip.Mobile.AppDownload.Service { public class MonitorService : RunningService { public MonitorService() { ElapsedMiliseconds = 3 * 60 * 60 * 1000;//每3小时记录一次。 s_stopwatch.Start(); } public override void LoopLogic() { string info = GetSystemInfo(); //Dashboard is better. LoggingManager.Instance().Info("MoniterService", info, new Dictionary<string, string>() { { "SystemInfo", "SystemInfo" } }); } Stopwatch s_stopwatch = new Stopwatch(); private PerformanceCounter _pc; private static TimeSpan s_lastTotalProcessTime = TimeSpan.Zero; public string GetSystemInfo() { int timeout; int totalThreads; int memory; int workingSetExecludePrivate; int workerThreads; int completionPortThreads; int maxThreadPoolThreads; int maxIOCPThreads; string split = ", "; StringBuilder sbInfo = new StringBuilder(); sbInfo.Append(DateTime.Now.ToString("yyyy-MM-dd hh:mm:ss fff") + split); s_stopwatch.Stop(); Process process = Process.GetCurrentProcess(); if (_pc == null) { _pc = new PerformanceCounter("Process", "Working Set - Private", process.ProcessName); } process.Refresh(); totalThreads = process.Threads.Count; memory = (int)((process.WorkingSet64) / (1024 * 1024)); workingSetExecludePrivate = (int)(_pc.NextValue() / (1024 * 1024)); double elapsedProcessTime = (process.TotalProcessorTime - s_lastTotalProcessTime).TotalMilliseconds; double elapsedSystemTime = s_stopwatch.ElapsedMilliseconds; int cpu = (int)(Math.Round(elapsedProcessTime * 100.0 / elapsedSystemTime / Environment.ProcessorCount)); s_lastTotalProcessTime = process.TotalProcessorTime; s_stopwatch.Restart(); ThreadPool.GetAvailableThreads(out workerThreads, out completionPortThreads); ThreadPool.GetMaxThreads(out maxThreadPoolThreads, out maxIOCPThreads); sbInfo.AppendFormat("CPU: {0}, ", cpu < 100 ? cpu : 100); sbInfo.AppendFormat("worker thread: {0}, ", maxThreadPoolThreads - workerThreads); sbInfo.AppendFormat("cpio : {0}, ", maxIOCPThreads - completionPortThreads); sbInfo.AppendFormat("total Threads: {0}, ", totalThreads); sbInfo.AppendFormat("memory(working): {0}MB, ", memory); sbInfo.AppendFormat("memory(private): {0}MB, ", workingSetExecludePrivate); return sbInfo.ToString(); } } }