IIS中 .NET Web Api后台接口监控解决方案

4 篇文章 0 订阅
3 篇文章 0 订阅

一,设置IIS日志文件的生成

1.点击网站可以看见本机所有的托管网站且IIS自动分配了ID(这个ID待会要用到)

2.在IIS中打开需要监控端口的主页--》双击打开日志

1 选择日志格式 这里我们选择w3c 就ok 可以点击选择字段 添加自己所需字段 既然是监控 那肯定少不了 请求的接口(URI资源),发送的字节数(sc-bytes),接收的字节数(cs-bytes),响应时间(time-taken)等 

2 修改存放的路径,文件夹需要给IIS用户添加修改权限(方便读取完信息后移除或删除文件)

3 这里我们是监控接口的访问量,吞吐量和响应速度,所以只需要记录日志文件就好了 

4 计划我这里添加的是每个小时生成一个新的文件 为什么不设置每天嘞 因为我是想监控前几个小时的一个需求 所以要把生成一个文件的频率调高一点 不然你读取和修改这个文件会报错和IIS写日志冲突掉

5 使用本地时间进行文件命名和滚动更新 这里要注意的是IIS生成的日志文件名是使用本地时间 但是文件内的日志生成时间使用的是格林威治时间

6 设置完成后点击应用 就可以在设置的文件夹下看到有日志生成了 IIS还会自动加一个子目录 你IIS下有多少个网站这里就会生成多少个子目录 编号就是前面说的ID

到这里IIS的设置就完成了 

二,使用.Net读取IIS日志文件保存数据库并删除已读取文件

这里直接上代码

public void IISLogImport()
        {
            SqlConnection conn = new SqlConnection("Data Source=xxx,1433;Initial Catalog=xxx;User ID=xxx;Password=xxx;MultipleActiveResultSets=true;");
            conn.Open();
            DirectoryInfo directoryZCAFFT = new DirectoryInfo("D:\\File\\log_IIS");//文件地址
            FileInfo[] arrZCAFFT = directoryZCAFFT.GetFiles("*.log");//筛选一下日志文件
            if (arrZCAFFT.Length == 0) return;
            foreach (FileInfo file in arrZCAFFT)
            {
                if (file.Name.IndexOf(DateTime.Now.ToString("yyMMddHH")) != -1) continue;//如果是当前时间的文件则不进行读取操作
                //整理好的数据
                DataTable newDataT = new DataTable();
                newDataT.Columns.AddRange(new DataColumn[] {
                        new DataColumn("ID",typeof(int)),
                        new DataColumn("DateTime",typeof(DateTime)),
                        new DataColumn("URIStem",typeof(string)),
                        new DataColumn("BytesSent",typeof(Int64)),
                        new DataColumn("BytesReceived",typeof(Int64)),
                        new DataColumn("TimeTaken",typeof(Int64))});
                //打开txt文件 按行读取数据 
                StreamReader sr = new StreamReader(file.FullName, Encoding.UTF8);
                try
                {
                    string line = string.Empty;
                    while ((line = sr.ReadLine()) != null)
                    {
                        if (line[0] != '#')//#开头的都是描述去掉
                        {
                            string[] contents = line.Split(' ');//日志内容的分隔符都是空格 
                            //这里是需要刨掉的请求文件
                            string[] indexs = new string[] { ".txt", ".xml", ".Js", ".asp", ".htm", ".xslt", ".swf", ".cgi", ".html", ".ico", ".gif", ".png", ".js", ".css", "/files/" };
                            
                            string[] vals = (from val in indexs where contents[2].IndexOf(val) != -1 select val).ToArray();
                            //需要刨掉的某些接口
                            string[] indexs2 = new string[] { "/xxx.asmx", "/api/xxx.asmx", "/xxx.asmx/xxx" };

                            string[] vals2 = (from val in indexs2 where contents[2] == val select val).ToArray();
                            //符合条件的添加到dataTable
                            if (vals.Length == 0 && vals2.Length == 0)
                            {
                                DataRow row = newDataT.NewRow();
                                row["DateTime"] = Convert.ToDateTime(contents[0] + " " + contents[1]).AddHours(8);//格林威治时间转本地时间
                                row["URIStem"] = contents[2];
                                row["BytesSent"] = Convert.ToInt64(contents[3]);
                                row["BytesReceived"] = Convert.ToInt64(contents[4]);
                                row["TimeTaken"] = Convert.ToInt64(contents[5]);
                                newDataT.Rows.Add(row);
                            }
                        }
                    }
                    //批量导入数据库 这种方式速度比较快
                    SqlBulkCopy bulkCopy = new SqlBulkCopy(conn);
                    bulkCopy.DestinationTableName = "xxx";
                    bulkCopy.BatchSize = newDataT.Rows.Count;

                    if (newDataT != null && newDataT.Rows.Count != 0)
                    {
                        bulkCopy.WriteToServer(newDataT);
                    }

                }
                catch (Exception e)
                {
                    GeSmartLog.WriteLog("IISLogImport ERROR:" + e.Message + " FileName:" + file.Name);
                }
                //将读取完的数据删除文件
                sr.Close();
                file.Delete();
            }
            //删除7天以前的日志 
            common.ExeSQL2("delete dbo.xxx where DATEADD(DAY,7,[DateTime])<GETDATE()", conn);
            conn.Close();
        }

到这里接口的访问量,吞吐量和响应时间都已经可以统计出来了。这个方法需要在定时器中调用,这样日志文件的维护也基本上不用管了 。

其实在IIS中设置好后,log文件一生成,接口的监控基本上就完成了。因为日志文件就在那里 用C#也好 Python也好 都只是一个数据处理和展示的工作了

Windows全家桶真香 ,如有不对之处还请各路大神指点指点。

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ASP.NET Web API 是一个快速开发框架,用于构建用于Web应用程序的Web服务。它基于ASP.NET和HTTP协议,并充分利用了HTTP特性。 ASP.NET Web API 提供了一种简单明了的方式来创建和发布Web API,使开发人员能够轻松地将数据和服务暴露给客户端应用程序,无论是Web应用程序、移动应用程序还是其他类型的客户端。 ASP.NET Web API 提供了广泛的特性和功能,包括: 1. 灵活的路由配置:通过使用属性路由或传统的路由映射,开发人员可以轻松地定义API的URL结构和访问规则。 2. 内建HTTP支持:ASP.NET Web API完全支持HTTP协议,并提供了与HTTP相关的功能,如GET、POST、PUT、DELETE等HTTP动词和状态码处理。 3. 内容协商:ASP.NET Web API 可以根据客户端的要求,动态选择并返回不同的响应内容类型,如JSON、XML或其他自定义媒体类型。 4. 模型绑定和验证:ASP.NET Web API 提供了强大的模型绑定和验证功能,可以自动将请求数据绑定到相应的模型并进行验证。 5. 信息路由和版本控制:ASP.NET Web API 支持信息路由和版本控制,可以根据不同的请求信息选择不同的版本和实现。 6. 异常处理:ASP.NET Web API 提供了全面的异常处理机制,可以捕获和处理各种异常,并返回友好和有效的错误信息给客户端。 7. 安全性和身份验证:ASP.NET Web API 支持各种身份验证和安全性机制,如基于角色的授权、OAuth 2.0等。 总之,ASP.NET Web API 提供了一个高效、灵活和可扩展的框架,使开发人员能够快速构建和发布Web服务,并能适应不同类型的客户端应用程序。无论是构建企业级应用程序还是移动应用程序,ASP.NET Web API 都能够提供稳定可靠的解决方案。 ### 回答2: ASP.NET WebAPI是一种基于ASP.NET框架的快速开发框架。它主要用于构建和发布RESTful的Web服务,使开发者能够更快速地创建可扩展、可用性高的WebAPI应用程序。 首先,ASP.NET WebAPI提供了开箱即用的特性,使得开发者能够快速地创建基于HTTP协议的API。它支持多种数据格式,如JSON和XML,以及多个身份验证和授权方式,如基于角色和令牌的身份验证,使得开发者可以根据项目需求选择合适的方式来保护API。 其次,ASP.NET WebAPI提供了丰富的路由和绑定特性,使得开发者能够通过简单的配置和属性标记来定义API的路由规则和参数绑定方式。这种灵活性和可配置性使得开发者能够更轻松地处理不同的请求和响应,并提供符合预期的结果。 另外,ASP.NET WebAPI还提供了强大的行为和过滤器特性,例如认证过滤器、授权过滤器和异常过滤器等,使得开发者能够在不同阶段对请求进行处理和验证。同时,开发者还可以通过自定义过滤器来扩展现有特性或添加新的行为和过滤器。 此外,ASP.NET WebAPI还提供了易于测试和部署的特性。开发者可以使用单元测试框架对API进行测试,并通过ASP.NET的集成测试工具进行端到端的测试。同时,ASP.NET WebAPI还支持自托管和IIS托管两种部署方式,使得开发者能够更方便地部署和维护API应用程序。 综上所述,ASP.NET WebAPI是一个功能强大、易于使用和高效的快速开发框架。它提供了丰富的特性和可扩展性,使开发者能够更快速地构建和发布高质量的WebAPI应用程序。 ### 回答3: ASP.NET Web API 是一个用于构建基于HTTP协议的Web服务的框架,它可以让开发人员更快速、更高效地开发Web应用程序。 首先,ASP.NET Web API 提供了快速创建和部署Web服务的能力。通过使用ASP.NET Web API,开发人员可以轻松地创建RESTful风格的API,并将其部署到云端或本地服务器上。与传统的ASP.NET MVC相比,ASP.NET Web API 提供了更简洁、更轻量级的开发体验,让开发人员可以更专注于服务端逻辑的编写。 其次,ASP.NET Web API 提供了丰富的功能和工具,帮助开发人员更快速地构建和调试Web服务。它支持多种数据格式,包括JSON和XML,提供了强大的序列化和反序列化功能,可以轻松地处理来自客户端的请求和响应数据。此外,ASP.NET Web API 还支持组织代码的特性,如路由、过滤器和模型绑定等,让开发人员可以更轻松地组织和管理代码。 最后,ASP.NET Web API 具有良好的可扩展性和灵活性。它可以很容易地和其他ASP.NET 项目集成,如ASP.NET MVC和ASP.NET Core等。开发人员可以利用现有的ASP.NET技术和工具来开发和扩展Web API,并利用ASP.NET的生态系统来提供更丰富的功能和支持。 总之,ASP.NET Web API 是一个快速开发框架,它提供了方便、高效的开发体验,让开发人员可以更快速地构建和部署基于HTTP协议的Web服务。无论是构建RESTful风格的API,还是处理来自客户端的请求和响应数据,ASP.NET Web API 都是一个强大的工具和框架。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值