python实现apahce网站日志分析示例
维护脚本一例,写得有点乱,只是作为一个实例,演示如何快速利用工具快速达到目的:
应用到:shell与python数据交互、数据抓取,编码转换
#coding:utf-8
#!/usr/bin/python
'''
程序说明:apache access.log日志分析
分析访问网站IP 来源情况
日期:2014-01-06 17:01
author:gyh9711
程序说明:应用到:shell与python数据交互、数据抓取,编码转换
'''
import os
import json
import httplib
import codecsLogFile='/var/log/apache2/access.log'
#日志
logMess='/tmp/acc.log'
if os.path.isfile(logMess):
os.system('cp /dev/null %s'% logMess)
file=codecs.open(logMess,'w+',encoding='utf-8')def cmd(cmd):
return os.popen(cmd).readlines()
'''
def getIp(ip):
return json.loads(os.popen("/usr/bin/curl http://ip.taobao.com/service/getIpInfo.php?ip=%s" % ip).readline())['data']
'''
conn = httplib.HTTPConnection('ip.taobao.com')
def getIpCountry(ip):
conn.request('GET','/service/getIpInfo.php?ip=%s' % ip)
r1=conn.getresponse()
if r1.status == 200:
return json.loads(r1.read())['data']
else:
return "Error"
#将access.log文件进行分析,并转为python数组
file.write(u"字段说明:ip 访问次数据 ip国家 城市的 isp号 省份 所在地区\n")
ipDb=[]
for i in cmd('''/usr/bin/awk '{print $1}' %s |sort |uniq -c''' % LogFile):
ip = i.strip().split(' ')
ipDb.append(ip)
#通过taobao 提供接口分析ip地址来源
for i in ipDb:
_tmpD=getIpCountry(i[1])
#格式说明:ip 访问次数据 ip国家 城市的 isp号 省份 所在地区
out="%s%s%s%s%s%s%s"%(i[1].ljust(20),i[0].ljust(10),_tmpD['country'].ljust(20),_tmpD['city'].ljust(16),_tmpD['isp_id'].ljust(16),_tmpD['region'].ljust(16),_tmpD['area'].ljust(16))
print out
file.write("%s\n"%out)conn.close()
file.close()'''
'''
您可能感兴趣的文章:
- python实现apahce网站日志分析示例
- python分析apahce网站日志的例子
- python实现分析apache和nginx日志文件并输出访客ip列表的方法
- 用70行代码实现日志分析程序-python
- 网站数据统计分析之一:日志收集原理及其实现
- python Pycurl 库 —— 实现对网站抓包分析
- 【Python】实现网站备份文件扫描+源码分析
- Python实现多并发访问网站功能示例
- nginx 日志分析,python 实现
- Python实现爬取需要登录的网站完整示例
- python 日志模块示例的详细分析
- 【Python】实现网站常见漏洞扫描+备份扫描+源码分析
- 网站数据统计分析之一:日志收集原理及其实现
- 能分析压缩的日志,且基于文件输入的PYTHON代码实现
- python脚本实现分析dns日志并对受访域名排行
- 【Python】爬行某手机号归属地网站实现'脱裤'+源码分析
- shell脚本实现的网站日志分析统计(可以统计9种数据)
- 网站数据统计分析之一:日志收集原理及其实现
- 网站数据统计分析之日志收集原理及其实现