需求:在Nginx中过滤出凌晨3:18-6:36的日志信息
1、使用sed方式过滤
注意:此方式开始和结束时间必须要在日志中真实存在,否则会匹配不到内容或匹配到末尾
sed -n '/2022:03:18:/,/2022:06:36:/p' access.log
上面内容匹配完成后要使用grep过滤末尾时间然后合并,因为sed匹配到一条就停止匹配了。会缺少内容。
grep 2022:06:36: access.log|sed '1d'
2、使用awk方式过滤。此方式不会有上面sed的缺陷
awk -F '[/ :]' '$7":"$8>="03:18" && $7":"$8<="06:36"' access.log
3、使用grep方式过滤
grep -E '2022:03:1[8-9]|2022:03:[2-5][0-9]|2022:0[4-5]:[0-5][0-9]|2022:06:[0-2][1-9]|2022:06:3[1-6]' access.log
缺陷:上述方式时间变化匹配规则调整频繁。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。