设为首页 收藏本站
查看: 1116|回复: 0

[经验分享] Python统计web应用的每个连接使用情况

[复制链接]

尚未签到

发表于 2018-8-6 07:17:23 | 显示全部楼层 |阅读模式
#_*_ coding:utf-8 _*_  
# auth: xinsir
  
# date: 2017/10/02
  
# version:3.0
  
import systemmongo,os
  
# 写一个方法,判断文件是否存在.返回布尔值
  
def judgment_file(FileName):
  
    if os.path.exists( FileName ):
  
        return True
  
    else:
  
        return False
  
# 写一个方法,把字符串切割成列表,return list
  
def SplitStr(StrName, Format,):
  
    return StrName.split(Format)
  

  
# 读取日志文件,获取文件中的所有包含action的记录,并写入到新的log文件中
  
def read_file(file, new_file,):
  
    ReadPosition = 0
  
    LastLine = 0
  
    FileSize = 0
  
    FileDic = {}
  
    # 打开两个文件,一个是日志文件,一个是临时文件,把日志文件进行更改后,以字典的格式序列化到日志文件中
  
    with open(file, 'r') as log_file, open(new_file, 'w') as new_log_file:
  
        # 查看文件总长多少,写入临时文件
  
        FileSizeNew = os.path.getsize(file)
  
        log_file.seek(ReadPosition)
  
        if FileSize < FileSizeNew:
  
            for (num, line) in enumerate(log_file):
  
                if '.action' in line.strip():
  
                    new_line = line.strip().split(sep='\" \"')
  
                    ListFirstValue = SplitStr(new_line[0], '\"')
  
                    ListMostValue = SplitStr(new_line[-1], '\"')
  
                    del new_line[0]
  
                    del new_line[-1]
  
                    new_line.insert(0, ListFirstValue[1])
  
                    new_line.append(ListMostValue[0])
  
                    Method = str(new_line[3]).split()[0]
  
                    request = str(new_line[3]).split()[1]
  
                    HttpVersion = str(new_line[3]).split()[2]
  
                    if '?' in request:
  
                        Uri = request.split(sep='?')[0]
  
                        Query_string = request.split(sep='?')[1]
  
                    else:
  
                        Uri = request.split( sep='?' )[0]
  
                        Query_string = ''
  
                    if '.action' in Uri:
  
                        # if LogFileStatus :
  
                        FileDic[num + 1 + LastLine] = {
  
                                                       'remote_addr': new_line[0],
  
                                                       'host': new_line[1],
  
                                                       'time_local': new_line[2],
  
                                                       'request': request,
  
                                                       'uri':Uri,
  
                                                       'query_string':Query_string,
  
                                                       'eethod': Method,
  
                                                       'HttpVersion': HttpVersion,
  
                                                       'body_bytes_sent': new_line[4],
  
                                                       'http_referer': new_line[5],
  
                                                       'http_user_agent': new_line[6],
  
                                                       'http_x_forwarded_for': new_line[7],
  
                                                       'server_addr': new_line[8],
  
                                                       'status': new_line[9],
  
                                                       'request_time': new_line[10],
  
                                                       }
  
                    else:
  
                        print('静态请求不做记录!')
  
                        continue
  
                    IsNot = systemmongo.SechMongo(
  
                        'http://' + FileDic[num + 1 + LastLine]['host'] + FileDic[num + 1 + LastLine]['uri'])
  
                    if IsNot:
  
                        systemmongo.Update(
  
                            'http://' + FileDic[num + 1 + LastLine]['host'] + FileDic[num + 1 + LastLine]['uri'])
  
                        print('更新记录成功:''http://' + FileDic[num + 1 + LastLine]['host'] + FileDic[num + 1 + LastLine]['uri'])
  
                    else:
  
                        print('action请求不存在!不做记录!')
  
                else:
  
                    print('静态请求不做处理!')
  
        else:
  
            print('日志文件没有发生改变!')
  
        new_log_file.write(str(FileDic))
  
        log_file.close()
  
        new_log_file.close()
  
if __name__ == '__main__':
  
    LOGPATH_new = '../nginxlog/b.txt'
  
    for fpathe, dirs, fs in os.walk('E:\python工程\jlj-nginx-log-web\jlj-nginx-log-web\\nginxlog\log'):
  
        #循环目录下的所有日志文件
  
        for f in fs:
  
            LOGPATH = os.path.join(fpathe, f)
  
            read_file(LOGPATH, LOGPATH_new)

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-547262-1-1.html 上篇帖子: python—subprocess、glob和shlex模块 下篇帖子: python编码规范
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表