惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

T
Threatpost
V
Vulnerabilities – Threatpost
TaoSecurity Blog
TaoSecurity Blog
C
Cybersecurity and Infrastructure Security Agency CISA
P
Proofpoint News Feed
G
GRAHAM CLULEY
S
Securelist
P
Palo Alto Networks Blog
MongoDB | Blog
MongoDB | Blog
A
Arctic Wolf
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
WordPress大学
WordPress大学
Project Zero
Project Zero
T
Threat Research - Cisco Blogs
L
Lohrmann on Cybersecurity
C
Cyber Attacks, Cyber Crime and Cyber Security
F
Fortinet All Blogs
博客园 - 叶小钗
B
Blog RSS Feed
C
Cisco Blogs
Google DeepMind News
Google DeepMind News
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
Apple Machine Learning Research
Apple Machine Learning Research
G
Google Developers Blog
K
Kaspersky official blog
D
Docker
Latest news
Latest news
Cisco Talos Blog
Cisco Talos Blog
T
Tor Project blog
Cyberwarzone
Cyberwarzone
Security Latest
Security Latest
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
D
Darknet – Hacking Tools, Hacker News & Cyber Security
Spread Privacy
Spread Privacy
Microsoft Azure Blog
Microsoft Azure Blog
C
Check Point Blog
J
Java Code Geeks
Simon Willison's Weblog
Simon Willison's Weblog
T
Tenable Blog
Recent Announcements
Recent Announcements
T
Tailwind CSS Blog
H
Help Net Security
L
LINUX DO - 热门话题
T
The Exploit Database - CXSecurity.com
Jina AI
Jina AI
S
SegmentFault 最新的问题
MyScale Blog
MyScale Blog
NISL@THU
NISL@THU
美团技术团队
腾讯CDC

博客园 - Yunanw

应用SQLServer For XML 生成XML避免在C# 拼字符串 某些版本的IIS可能有SessionID混淆的Bug 小觑数据库(SqlServer)查询语句执行过程 C#中Finally的一个不太常见的用法 通过表达式树实现的ObjectMapper 实际一个多态(或弱类型)ConfigurationElementCollection 通过P/Invoke调用32位C++ DLL时,一定要将平台改为X86 坑爹的面试题 在Windows2008 IIS7上部署.net 1.1 用Python 实现刷钻网上抢任务,并实现一个简单的限制使用时间的功能 Python几行代码打印出网卡的Mac地址 放大招,解决前同事签出TFS文件的问题 飞猪传书 Linq To xml 查询时需要注意的一点。 - Yunanw 自定义WinForm 下ListBox的行高 重新装载VS的模板 咱也搞一个TransactionScope QQ斗地主记牌器(只支持角色版) - Yunanw - 博客园 实现支持会话的WebClient
使用LogParser分析网站运行情况(比较简单)
Yunanw · 2009-06-15 · via 博客园 - Yunanw

使用LogParser分析网站运行情况(比较简单)

问题的提出

         在经过若干天的辛苦劳动,你的网站终于上线了,虽然你的用户没有任何报怨,似乎你的程序也没有任何Bug。但是它真的像你想的那样运行的这么好吗?每天有多少个IP地址访问你的网站?你的网站经常被访问的页面哪些?这些页面载入需要花费多少时间?哪些页面是最慢的?

IIS日志

         幸运的是,如果你使用IIS的话,IIS会为每一次请求记录下日志。查询IIS日志的方法如下(由于我机器是IIS7,图片是Google到的,图片来源见上面的水印,谢谢作者):打开IIS管理,点网站,右键选属性,然后出现下面对话框,选网站属性。

 

你可以通过上面的方法修改IIS日志的记录时间,记录的内容,保存的路径等信息。默认情况下IIS已经为你记录下了大部分有用的信息。,

LogParser简介

         虽然有了IIS日志,但是我们如果在浩如烟海的日志中提取出我们需要的信息呢?幸运的是微软早就为我们准备好了一个不错的工具----LogParserLogParser功能非常的强大,不但可以分析IIS日志,还可以分析系统事件日志,CSVXML等格式日志,同时LogParser还支持编程接口,LogParser的帮助文档里自带了一个使用C#查询系统日志的例子。

    下面给出LogParser下载地址

LogParser的使用

         下载,安装完成后执行LogPaser,会打开一个类似于命令行的窗口。我们先来执行一个最简单的查询

       查找访问量最大的前10个页面

         LogParser的输入窗口输入

LogParser “Select top 10  cs-uri-stem , count(cs-uri-stem) as hits from D:"147"W3SVC1"ex090531.log  Where TO_LOWERCASE(EXTRACT_EXTENSION(cs-uri-stem)) =‘aspx’ group by cs-uri-stem Order by hits DESC”

我来解释一下这句话的意思:LogParser的查询语法是一种类型于Sql的语法,SQL语法很接近,但是不完全一样.

Select Top 10 这个不用解释了,SQL语法一样,取出前十个符合条件的记录.

cs-uri-stem 是日志中的一列,表示用户请求的URI部分(不包括查询字符串)

Count SQL中的意义相同

AS SQL中一样,也是取别名

From 后面可以跟一个完整文件名,也可以跟一个 D:"147"W3SVC1"*.log 这样的文件名,甚至还可以一些特定的词 如后跟” System” 表示查询系统日志

Where SQL

TO_LOWERCASE LogParser提供的函数,用于将字符串转为小写

EXTRACT_EXTENSION 也是LogParser中提供的函数,用于从字符串中提取扩展名(是不是很贴心?)

后面的Group by Ordery By 以及 DESC都和SQL一样了

       查找网站内运行最慢的10个页面

由于Time-Taken项目在IIS日志里是默认不记录的,你需要在查询之前在IIS里设置记录Time-Taken

LogParser “Select top 10  cs-uri-stem , max(time-taken) as t from D:"147"W3SVC1"ex090531.log  Where TO_LOWERCASE(EXTRACT_EXTENSION(cs-uri-stem)) =‘aspx’ group by cs-uri-stem Order by t DESC”

查找所有返回404的请求

LogParser “Select  cs-uri-stem ,count(cs-uri-stem) as hits  from D:"147"W3SVC1"ex090531.log where  sc-status=’404’ group by cs-uri-stem Order by hits DESC”

使用C#调用LogParser