本文主要记录下给予python的nginx日志统计过程,主要原因是最近系统经常遭到未知程序的疯狂爬数据,虽然做了防爬机制,但是还是必须要找出是哪些IP访问次数比较多。想到的办法就是通过分析ngxin日志,从而找出这些IP排行即可。具体方案的操作步骤包括:
- ngxin日志每日切割功能;
- 设置ngxin的日志格式;
- 编写python代码在每日切割之前统计下access.log中的IP访问次数并将统计结果录入MongoDB;
- 编写web查询MongoDB进行统计。
下面按照每个步骤详细说明。
一、nginx日志每日切割功能
该功能主要通过自己编写shell脚本实现,然后将shell脚本通过crontab设置任务周期。
shell脚本如下:
#!/bin/bash ## 零点执行该脚本 ## Nginx 日志文件所在的目录 LOGS_PATH=/usr/local/nginx/logs ## 获取昨天的 yyyy-MM-dd YESTERDAY=$(date -d ”yesterday” +%Y-%m-%d) ## 移动文件 mv ${LOGS_PATH}/access.log ${LOGS_PATH}/access_${YESTERDAY}.log ## 向 Nginx 主进程发送 USR1 信号。USR1 信号是重新打开日志文件 kill -USR1 $(cat /usr/local/nginx/nginx.pid)
加入crontab
0 0 * * * /bin/bash /usr/local/nginx/sbin/cut-log.sh
二、设置ngxin日志格式
打开nginx.conf配置文件,在server段中加入
log_format access '$remote_addr - $remote_user [$time_local] "$request"' '$status $body_bytes_sent "$http_referer"' '"$http_user_agent" $http_x_forwarded_for'; access_log /usr/local/nginx/logs/access.log access;
加入成功后重启ngxin
./nginx -s reload
三、编写python代码在每日切割之前统计下access.log中的IP访问次数并将统计结果录入MongoDB;
下载pymongo,上传到服务器,并安装
# tar zxvf pymongo-1.11.tar.gz # cd pymongo-1.11 # python setup.py install
python连接mongodb样例
$ cat conn_mongodb.py #!/usr/bin/python import pymongo import random conn = pymongo.Connection("127.0.0.1",27017) db = conn.tage #连接库 db.authenticate("tage","123") #用户认证 db.user.drop() #删除集合user db.user.save({'id':1,'name':'kaka','sex':'male'}) #插入一个数据 for id in range(2,10): name = random.choice(['steve','koby','owen','tody','rony']) sex = random.choice(['male','female']) db.user.insert({'id':id,'name':name,'sex':sex}) #通过循环插入一组数据 content = db.user.find() #打印所有数据 for i in content: print i
编写python脚本
#encoding=utf8 import re zuidaima_nginx_log_path="/usr/local/nginx/logs/www.zuidaima.com.access.log" pattern = re.compile(r'^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}') def stat_ip_views(log_path): ret={} f = open(log_path, "r") for line in f: match = pattern.match(line) if match: ip=match.group(0) if ip in ret: views=ret[ip] else: views=0 views=views+1 ret[ip]=views return ret def run(): ip_views=stat_ip_views(zuidaima_nginx_log_path) max_ip_view={} for ip in ip_views: views=ip_views[ip] if len(max_ip_view)==0: max_ip_view[ip]=views else: _ip=max_ip_view.keys()[0] _views=max_ip_view[_ip] if views>_views: max_ip_view[ip]=views max_ip_view.pop(_ip) print "ip:", ip, ",views:", views #总共有多少ip print "total:", len(ip_views) #最大访问的ip print "max_ip_view:", max_ip_view run()
上面程序运行结果:
ip: 221.221.155.53 ,views: 1 ip: 221.221.155.54 ,views: 2 total: 2 max_ip_view: {'221.221.155.54': 2}
更多java架构应用文章,欢迎访问http://arching.wc.lt
相关推荐
物联网系统技术方案主要探讨了构建...总之,这份物联网系统技术方案深入探讨了物联网系统的设计思路和实施策略,覆盖了从需求分析到功能设计,再到关键技术选型的全过程,为企业或组织构建物联网系统提供了全面的参考。
标题中的“大数据离线分析项目(Hadoop)...综上所述,这个大数据离线分析项目涵盖了从数据采集、清洗、存储、分析到展示的全过程,运用了多种技术和工具,旨在从海量用户行为数据中挖掘有价值的信息,助力网站运营决策。
### 物联网系统技术方案知识点...综上所述,该文档详细阐述了一个物联网系统的构建思路和技术实施方案,涵盖了从需求分析到技术选型、从系统设计到实施部署的全过程。这对于理解和构建物联网系统具有重要的参考价值。
- **SQL语句优化**:优化SQL语句,包括语法优化和逻辑优化,避免全表扫描,合理利用索引,结合日志分析找出瓶颈并针对性优化。 - **分区**:当单表数据量增大时,分区可以将数据分散到多个部分,提高查询效率,如...
4. **支付与结算**:系统自动处理支付过程,确保资金安全,并提供收入统计和结算功能。 5. **权限控制**:通过角色和权限分配,实现不同用户群体(如学员、教师、管理员)的不同操作权限。 6. **评论与互动**:...
这份源代码提供了全面的解决方案,帮助学习者理解软件工程的全过程以及如何将理论知识应用于实践。 一、系统分析 在设计任何软件系统之前,都需要进行需求分析。仓库货物管理系统的需求通常包括库存管理(如入库、...
PHP站长工具是网站管理员常用的一种辅助工具,它通常包含了多种功能,例如网站流量统计、SEO优化分析、...通过研究和实践,你可以掌握到从数据采集到数据分析,再到功能实现的全过程,从而提升你的网站运维能力。
这个项目涵盖了Web开发的多个重要环节,对于学习者来说,可以全面了解并实践一个完整的互联网应用从设计到上线的全过程。通过此项目,开发者可以提升自己在前端交互、后端逻辑、数据库管理、服务器部署等方面的能力...
《机房收费系统__概要设计》文档涵盖了机房收费系统设计的核心概念和技术要点,旨在为系统的开发提供清晰的架构蓝图。...在整个设计过程中,需持续关注业务需求的变化,并适时调整设计方案,以适应实际运营的需求。
### 从无到有搭建中小型互联网公司后台服务架构与运维架构 #### 一、引言 随着互联网技术的发展,中小型互联网公司对后台...以上就是从无到有搭建中小型互联网公司后台服务架构与运维架构的全过程。希望对你有所帮助!
7. **统计分析**:后台通常会有数据分析模块,用于统计销售额、访问量、用户行为等,帮助商家优化运营策略。 8. **权限控制**:根据不同的角色(如管理员、普通用户等)分配不同的操作权限,确保系统的安全性和稳定...
这款系统集房源发布、查询、管理于一体,为购房者、租户、中介公司以及开发商提供了全方位的信息服务。 1. **系统特点** - **易用性**:AiJiaCMS设计人性化,操作界面直观,使得非专业技术人员也能轻松上手,进行...
这个"PHPCMSV9制作手册"包含了系统安装、模板制作、功能配置、问题解决等多个方面的内容,旨在帮助用户更好地理解...在实际使用过程中,结合手册提供的解决方案,能快速解决遇到的问题,确保网站的正常运行和持续优化。
- **面向切面编程**:利用AOP实现日志记录、事务管理等功能。 - **声明式事务管理**:简化事务管理的配置和使用。 #### SpringMVC框架 - **请求处理**:使用@Controller注解定义控制器类,@RequestMapping注解映射...