IIS应用程序池监控
2018-06-17 20:30:42来源:未知 阅读 ()
最近发现公司运行的web网站应用程序池会突然停止,做的负载均衡(路由负载)又无法监测到IIS应用程序池的情况,就想着通过某一种监控方式监测IIS应用程序池的情况,如果处关闭状态则立刻重新启动.所说的IIS应用程序池监控也只能算是伪监控,不喜勿喷.
运行: winform + windows计划任务
1.首先获取IIS版本号
/// <summary> /// 获取当前计算机相关信息 /// </summary> public static class AcquireComputerInfo { /// <summary> /// 获取当前IIS版本号 /// </summary> /// <param name="domainname"></param> /// <returns></returns> public static string GetIssVersionByDri(string domainname = "") { //try //{ // if (string.IsNullOrEmpty(domainname)) // { // //如果为空 则默认为本地机器 // domainname = "LOCALHOST"; // } // DirectoryEntry getEntity = new DirectoryEntry("IIS://" + domainname + "/W3SVC/INFO"); // string Versions = getEntity.Properties["MajorIISVersionNumber"].Value.ToString(); // return Versions; //} //catch (Exception se) //{ // //说明一点:IIS5.0中没有(int)entry.Properties["MajorIISVersionNumber"].Value;属性,将抛出异常 证明版本为 5.0 // //MessageBox.Show("获取ISS的版本是发生异常信息:" + se.Message); // return "5.0"; //} //RegistryKey表示 Windows 注册表中的项级节点.此类是注册表封装 string issversion = string.Empty; RegistryKey getkey = Registry.LocalMachine.OpenSubKey("software\\microsoft\\inetstp"); if (getkey != null) { issversion = Convert.ToInt32(getkey.GetValue("majorversion", -1)).ToString(); //MessageBox.Show(issversion.ToString()); } return issversion; } /// <summary> /// 获取当前计算机信息 例如:计算机名:aaa,IP:10.10.10.10 /// </summary> /// <returns></returns> public static string GetComputerInfo() { var computerNmae = System.Net.Dns.GetHostName();//获取当前计算机名称 var computerIp = new System.Net.IPAddress(System.Net.Dns.GetHostByName(System.Net.Dns.GetHostName()).AddressList[0].Address).ToString();//获取局域网IP return string.Format("PC_Name: {0},IP: {1}",computerNmae,computerIp); } }
2.查看当前iis上所有的应用程序池的
/// <summary>
/// 检测当前线程池是否正常开启 /// </summary> public void MonitoringISSAppPool() { // string method_Recycle = "Recycle"; //Start开启 Recycle回收 Stop 停止 string method_Start = "Start"; var i = 0; DirectoryEntry appPool = new DirectoryEntry("IIS://localhost/W3SVC/AppPools"); try { foreach (DirectoryEntry item in appPool.Children) { string AppPoolCommand = item.Properties["ManagedPipelineMode"].Value.ToString(); string ManagedRuntimeVersion = item.Properties["ManagedRuntimeVersion"].Value.ToString();//,net版本号 string AppPoolState = item.Properties["AppPoolState"].Value.ToString();//当前状态 if (AppPoolState != "2") { DirectoryEntry findPool = appPool.Children.Find(item.Name, "IIsApplicationPool"); findPool.Invoke(method_Start, null); appPool.CommitChanges(); appPool.Close(); var IIsMsg = string.Format("[{0}],名称:[{1}],NET版本:{2},标识:{3},当前状态:[{4}],时间:{5}\n", PC_Info, item.Name, ManagedRuntimeVersion, item.SchemaClassName, "已启动", DateTime.Now.ToString()); ClsLogHelper.m_CreateWorkLogTxt(item.Name, IIsMsg); } } //lblCount_text.Text = i.ToString(); } catch (Exception ex) { ClsLogHelper.m_CreateErrorLogTxt("MonitoringISSAppPool", string.Format("{0},时间:{1},启动失败", AcquireComputerInfo.GetComputerInfo(), DateTime.Now), ex.Message);//日志记录错误信息 ClsLogHelper.Email("MonitoringISSAppPool", string.Format("{0},时间:{1},启动失败", AcquireComputerInfo.GetComputerInfo(), DateTime.Now)+" "+ ex.Message);//邮件发送错误信息 } }
3.那么剩下就是windows计划任务的工作了,简单配置一下设置触发器时间为每隔1秒中执行一次
到此一个IIS应用程序池伪监控就已经完成,当然在启动应用程序池时,启动失败时还需要记录详细的错误信息,以及将发生错误的服务器名称和IP通过邮件的方式发送给管理员,管理员可以在第一时间知道具体那台服务器IIS出现问题.
日志记录:
通过日志记录我们可以发现在第二条记录中Audi这个应用程序池已经被正常启动.
当然这种小工具只能临时解决IIS应用程序池意外停止的问题,IIS应用程序池意外停止可能有很多原因导致,例如:内存溢出或者代码逻辑问题,要想根本解决就只能安排程序员检查代码了.
不喜勿喷,如果有什么更好的意见或者想法欢迎提出宝贵意见哦....
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- uniGUI 应用程序体系结构(11) 2020-02-04
- Intraweb IIS发布,数据连接问题 2019-12-24
- C# Win32控制台应用程序忽略 Ctrl + C,阻止程序退出 2018-06-21
- 在中间层 .NET 应用程序中通过授权管理器使用基于角色的安全 2018-06-17
- 提高效率!15款最好的 Bug 跟踪应用程序 2018-06-17
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash