Django实战-分析日志
- 2019 年 10 月 5 日
- 筆記
Django网络应用开发的5项基础核心技术包括模型(Model)的设计,URL 的设计与配置,View(视图)的编写,Template(模板)的设计和Form(表单)的使用。
在前一小节中,使用 log 记录访问日志,将用户请求的信息通过中间件存入 django 配置的 log 文件中。

一、分析日志任务
① 通过读取上一小节中日志统计的 log 内容,将分析请求次数、最大值、最小值、平均值
# 读取统计的 log 内容 data_file = os.path.join(settings.BASE_DIR, "log", "statistics.log") if not os.path.exists(data_file): logger.warning("file not exists. file=[%s]" % data_file) return
② 打开统计的 log 文件
result = {} with open(data_file, "r") as data_file: for line in data_file: # 去掉前后换行符 line = line.strip() # 用空格作为分割 content = line.split(" ")[2] content_list = content.split(settings.STATISTICS_SPLIT_FLAG) # 取出时间,用等号作为分割,取后面一项,前面和后面的中括号去掉 log_time = int(content_list[0].split("=")[1][1:-1]) path = content_list[1].split("=")[1][1:-1] full_path = content_list[2].split("=")[1][1:-1] cost = float(content_list[3].split("=")[1][1:-1]) # 记录数据 # path: value_list if path not in result.keys(): result[path] = [] result[path].append(cost)
③ 最大值、最小值、平均值
# 最大值、最小值、平均值 report_content = [] for k, v_list in result.items(): # 请求次数,时间的次数 count = len(v_list) # 最大值 v_max = max(v_list) # 最小值 v_min = min(v_list) # 平均值 v_avg = sum(v_list) * 1.00 / count # k 请求地址,从右边40 content = "%-40s COUNT: %d MAX_TIME: %.4f(s) MIN_TIME: %.4f(s) AVG_TIME: %.4f(s)" % (k, count, v_max, v_min, v_avg) report_content.append(content)
