Python语言技术文档

微信小程序技术文档

php语言技术文档

jsp语言技术文档

asp语言技术文档

C#/.NET语言技术文档

html5/css技术文档

javascript

点击排行

您现在的位置:首页 > 技术文档 > Python自动化运维

python实现apahce网站日志分析示例

来源:中文源码网    浏览:262 次    日期:2024-05-02 22:57:17
【下载文档:  python实现apahce网站日志分析示例.txt 】


python实现apahce网站日志分析示例
维护脚本一例,写得有点乱,只是作为一个实例,演示如何快速利用工具快速达到目的:应用到:shell与python数据交互、数据抓取,编码转换
复制代码 代码如下:#coding:utf-8#!/usr/bin/python'''程序说明:apache access.log日志分析 分析访问网站IP 来源情况 日期:2014-01-06 17:01 author:gyh9711 程序说明:应用到:shell与python数据交互、数据抓取,编码转换'''import osimport jsonimport httplibimport codecs
LogFile='/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()
'''
'''

相关内容