Jonnyan的原创笔记
alpine
alpine里python安装mssql笔记
Alpine linux如何配置和管理自定义服务
windows
window server2012远程授权重置
window获取本机所有IP
window远程桌面RDP加速方案
远程监控 Win10 资源占用
windows 下 mysql 区分大小写敏感问题
window下navicat无限试用脚本
win11恢复win10右键菜单样式
永久禁止windows更新
强制本地账户安装win10/11
Linux
解决openvpn的CRL has expired笔记
centos7.x配置时间服务器(chrony)
centos7.x下安装wireguard
解决influxdb的log日志输出位置
保存 iptable 规则并开机自动加载 | SA-Logs
kafka笔记
kafka的server.properties 配置文件参数说明
CentOS 和 RedHat 下 8 个最常用的 YUM 库
外网IP查询网站
VirtualBox Ubuntu20/centos7 命令行如何扩容分区磁盘
如何备份sqlite数据库
yum 安装 redis5/mq/consul
centos7.x 安装 docker-ce
zabbix4.2 的 yum+mariadb 方式部署安装
如何在 Linux 中查找最大的 10 个文件
mongodb 备份与还原操作
Linux 高频工具快速教程
yum 安装 influxdb/telegraf
ubuntu 14.04/16.04/18.04 yum 安装 zabbix-agent 教程
逃不掉的 mysql 数据库安装方式大全 yum rpm 源码
VIM 配置入门
find 命令结合 cp bash mv 命令使用的 4 种方式
Tomcat nginx log 日志按天分割切割
linux 和 pycharm 下终端彩色打印输出
centos5/6/7 下 yum 安装 zabbix-agent(被控端)
shell 脚本头,#!/bin/sh 与 #!/bin/bash 的区别.
electerm/tabby在执行screen命令后不显示滚动条
aws ec2 安装caddy2
No usable version of libssl was found
python
python virtualenv笔记
python配置文件INI/TOML/YAML/ENV的区别
python限制函数的执行时间
python里and和or的理解
SQLite is not a toy database | Anton Zhiyanov
四行代码实现 Python 管道 - Aber's blog
systemd管理虚拟环境Django+uwsgi+nginx配置教程
Linux shell命令创建python django用户
nginx子路径下反代运行多个django
django web 应用 runserver 模式下 cpu 占用高解决办法
解决 pip 安装模块报错 Cannot fetch index base URL http://pypi.python.org/simple/
docker
仅在首次启动时在Docker容器中运行命令
Docker多平台架构镜像构建
解决cadvisor监控内存值与docker stats命令值不一致问题
docker 清理指定日期之前的镜像
docker 部署 graylog 使用教程
docker 一键搭建 zerotier-moon 节点
alpine的docker镜像安装mysql/mariadb/redis
dockerfile 多阶段构建参考
Warning: Stopping docker.service, but it can still be activated by: docker.socket
nginx
Nginx限制并发连接数与下载速度
nginx仅允许域名访问禁止IP访问
Nginx 强制跳转 Https
nginx强制跳转https无限301循环问题
万字总结,带你全面系统的认识 Nginx
linux 下编译安装 nginx 完整版
解决 nginx 同端口强制跳转 https 配置 ssl 证书问题
nginx 关闭日志功能 access_log 关闭
基于 nginx 的 token 认证
杂记
小米手机MIUI12安装Google服务
使用sphinx+markdown+readthedocs+github来编写文档
N1由armbian直刷openwrt
N1安装docker版本的openwrt做旁路由
NUC10 i3/i5/i7系列开启局域网wol唤醒
威联通qnap安装nginx
威联通qnap配置开机自启动项
telegram bot python使用示例教程
四款paste临时文本分享平台
docker部署微力同步(verysync)
Android和IOS自部署通知程序
苹果M1如何科学上网
M1 mac iterm2配置lrzsz命令
漫威轮播
网件XR500/R7800刷机
DIY 编译 openwrt 固件
苹果 mac 版微软官方远程连接工具下载 Microsoft Remote Desktop For Mac
wireguard 实现 peer 互联, NAT to NAT
学习本来的样子
解决 aws ec2 的 centos7 设置时区无效
redis 问题优化
N1 如何完美刷入 armbian 系统教程
v2rayN 的 pac 简单规则
博客园 markdown 使用折叠语法和颜色标签
十年感悟之 python 之路
在浏览器输入 URL 回车后发生了什么?
grafana 里 prometheus 查询语法
国内开源镜像站点汇总
解决阿里云部署 office web apps ApplicationFailedException 报错问题
解决 mac 休眠睡眠异常耗电方法
jira 集成 fisheye 代码深度查看工具安装绿色版
阿里云 ecs 开启 x11 图形化桌面
markdown 完整语法规范 3.0 + 编辑工具介绍
pycharm 重置设置,恢复默认设置
[已解决]window 下 Can't connect to MySQL server on'localhost' (10061) 与无法启动 MYSQL 服务”1067 进程意外终止”
解决 xshell6 评估过期, 需采购问题
[已解决]pycharm 报错: AttributeError: module 'pip' has no attribute 'main'
[已解决]windows 下 python3.x 与 python2.7 共存版本 pip 使用报错问题
局域网共享工具总结
云策文档think配置https教程
MIUI12百度输入法小米版使用森林集皮肤办法
Jenkins 构建后通知到飞书
简易的openvpn安装
keychron V1键盘改键教程
caddy2配置SSE单向websock(How to proxy Server Sent Events caddy2)
机器监控告警
zabbix
yum / 编译安装 Zabbix 5.0 LTS
zabbix 监控 AWS-SQS 队列
Zabbix-agent 端配置文件说明
Prometheus+grafana
prometheus+grafana安装和配置
node_exporter主机监控
cadvisor容器监控
redis_exporter监控
rabbitmq_exporter监控
consul_exporter监控
windows_exporter
Open-Falcon
falcon 数据丢失处理方法参考
日志监控告警
graylog
graylog 通过 python 实现钉钉 / 微信 / webhook 告警
loki+grafana
Loki简介
Loki安装
Loki查询语法
grafana面板pannel语法
内网穿透
frp
zerotier
zerotier充当网关实现内网互联,访问其它节点内网
一分钟自建zerotier-plant
nps
anylink
N2N
OmniEdge
本文档发布于https://mrdoc.fun
-
+
首页
Tomcat nginx log 日志按天分割切割
> 本文由 [简悦 SimpRead](http://ksria.com/simpread/) 转码, 原文地址 [www.cnblogs.com](https://www.cnblogs.com/jonnyan/p/9389513.html) 利用 Linux 自带的 logrotate 工具来实现按天切割日志. 下方已 centos 7 系统为例来实践讲解. ### 原理 **Logrotate 是基于 CRON 来运行的,其脚本是 / etc/cron.daily/logrotate,日志轮转是系统自动完成的。** 1. 每晚 cron 后台执行`/etc/cron.daily/`目录下的任务 2. 这会触发`/etc/cron.daily/logrotate`文件,通常这在 linux 安装的时候包含了。 它会执行命令 `/etc/cron.daily/logrotate` 3. `/etc/logrotate.conf` 这个配置文件包含了所有在`/etc/logrotate.d/`的脚本。 4. 这会触发我们下面写的 `/etc/logrotate.d/tomcat-log-cut` 文件。 ### Tomcat 日志分割脚本 (按天) * 1. 在`/etc/logrotate.d/`下面新建一个文件, **文件名随意**, 此处以 tomcat-log-cut 为例. `vim /etc/logrotate.d/tomcat-log-cut` * 2. 脚本内容 ``` /opt/web/apache-tomcat/logs/catalina.out { #此处的 tomcat 路径请自行更换为你自己的 daily # 每天切割 rotate 5 # 保留 5 个备份 dateext # 这个参数很重要!就是切割后的日志文件以当前日期为格式结尾,如 xxx.log-20131216 这样,如果注释掉,切割出来是按数字递增,即 xxx.log-1 这种格式 dateformat .%Y%m%d # 配合 dateext 使用,紧跟在下一行出现,定义文件切割后的文件名,必须配合 dateext 使用,只支持 %Y %m %d %s 这四个参数 #size 100M # 大小到达 size 开始转存 notifempty # 如果是空文件的话,不转储 missingok # 在日志轮循期间,任何错误将被忽略,例如“文件无法找到”之类的错误。 copytruncate # 拷贝原日志文件,并且将其变成大小为0的文件。 } ``` * 3. 重启 tomcat 服务. * 4. 执行下面的命令测试一下. `/usr/sbin/logrotate /etc/logrotate.conf` * 5. 如果没有成功,再执行下面的命令排查问题 `/usr/sbin/logrotate -v -f -d /etc/logrotate.d/tomcat-log-cut` ### logrotate 参数说明 <table><thead><tr><th>参数</th><th>说明</th></tr></thead><tbody><tr><td>compress</td><td>#通过 gzip 压缩转储以后的日志</td></tr><tr><td>nocompress</td><td>#不做 gzip 压缩处理</td></tr><tr><td>create mode owner group</td><td>#轮转时指定创建新文件的属性,如 create 0777 nobody nobody</td></tr><tr><td>nocreate</td><td>#不建立新的日志文件</td></tr><tr><td>delaycompress</td><td>#和 compress 一起使用时,转储的日志文件到下一次转储时才压缩</td></tr><tr><td>nodelaycompress</td><td>#覆盖 delaycompress 选项,转储同时压缩。</td></tr><tr><td>missingok</td><td>#如果日志丢失,不报错继续滚动下一个日志</td></tr><tr><td>ifempty</td><td>#即使日志文件为空文件也做轮转,这个是 logrotate 的缺省选项。</td></tr><tr><td>notifempty</td><td>#当日志文件为空时,不进行轮转</td></tr><tr><td>mail address</td><td>#把转储的日志文件发送到指定的 E-mail 地址</td></tr><tr><td>olddir directory</td><td>#转储后的日志文件放入指定的目录,必须和当前日志文件在同一个文件系统</td></tr><tr><td>noolddir</td><td>#转储后的日志文件和当前日志文件放在同一个目录下</td></tr><tr><td>sharedscripts</td><td>#运行 postrotate 脚本,作用是在所有日志都轮转后统一执行一次脚本。如果没有配置这个,那么每个日志轮转后都会执行一次脚本</td></tr><tr><td>prerotate</td><td>#在 logrotate 转储之前需要执行的指令,例如修改文件的属性等动作;必须独立成行</td></tr><tr><td>postrotate</td><td>#在 logrotate 转储之后需要执行的指令,例如重新启动 (kill -HUP) 某个服务!必须独立成行</td></tr><tr><td>daily</td><td>#指定转储周期为每天</td></tr><tr><td>weekly</td><td>#指定转储周期为每周</td></tr><tr><td>monthly</td><td>#指定转储周期为每月</td></tr><tr><td>rotate count</td><td>#指定日志文件删除之前转储的次数,0 指没有备份,5 指保留 5 个备份</td></tr><tr><td>dateext</td><td>#使用当期日期作为命名格式</td></tr><tr><td>dateformat .%s</td><td>#配合 dateext 使用,紧跟在下一行出现,定义文件切割后的文件名,必须配合 dateext 使用,只支持 %Y %m %d %s 这四个参数</td></tr><tr><td>size(或 minsize) log-size</td><td>#当日志文件到达指定的大小时才转储,log-size 能指定 bytes(缺省) 及 KB (sizek) 或 MB(sizem).</td></tr></tbody></table> 当日志文件 >= log-size 的时候就转储。 以下为合法格式:(其他格式的单位大小写没有试过) size = 5 或 size 5 (>= 5 个字节就转储) size = 100k 或 size 100k size = 100M 或 size 100M ** 值得注意的一个配置是:copytruncate ** copytruncate 如果没有这个选项的话,操作方式:是将原 log 日志文件,移动成类似 log.1 的旧文件, 然后创建一个新的文件。 如果设置了,操作方式:拷贝原日志文件,并且将其变成大小为 0 的文件。 区别是:如果进程, 比如 Tomcat 使用了一个文件写日志,没有 copytruncate 的话,切割日志时, 把旧日志 Catalina.out->Catalina.out.1 ,然后创建新日志 Catalina.out。这时候 tomcat 打开的文件描述符依然时 Catalina.out.1,由于没有信号通知 tomcat 要换日志描述符,所以它会继续向 Catalina.out.1 写日志,这样就不符合我们的要求了。 因为我们想切割日志后,tomcat 自动会向新的 Catalina.out 文件写日志,而不是旧的 Catalina.out.1 文件. **解决方法有两个:** 1. 向上面的 tomcat 切割日志配置,再 postrotate 里面写个脚本 postrotate # 在 logrotate 转储之后需要执行的指令,例如重新启动 (kill -HUP) 某个服务!必须独立成行 ``` [ -s /run/tomcat.pid ] && kill -USR1 `cat /run/tomcat.pid` endscript ``` 这样就是发信号给 tomcat , 让 tomcat 关闭旧日志文件描述符,重新打开新的日志文件描述,并写入日志 2. 使用 copytruncate 参数,向上面说的,配置了它以后,操作方式是把 Catalina.out 复制一份 成为 Catalina.out.1,然后清空 log 的内容,使大小为 0,那此时 log 依然时原来的旧 log,对进程(tomcat)来说,依然打开的是原来的文件描述符,可以继续往里面写日志,而不用发送信号给 tomcat copytruncate 这种方式操作的时候, 拷贝和清空之间有一个时间差,可能会丢失部分日志数据。 nocopytruncate 备份日志文件不过不截断。 本文参考:[https://www.cnblogs.com/276815076/p/7053640.html](https://www.cnblogs.com/276815076/p/7053640.html)(主要) 与 [https://blog.csdn.net/seelye/article/details/79276216](https://blog.csdn.net/seelye/article/details/79276216). 做了整理优化.
Jonny
Feb. 22, 2022, 10:40 p.m.
593
0 条评论
转发文档
收藏文档
上一篇
下一篇
手机扫码
复制链接
手机扫一扫转发分享
复制链接
【腾讯云】爆款2核2G4M云服务器一年45元,企业首购最高获赠300元京东卡
【腾讯云】爆款2核2G4M云服务器一年45元,企业首购最高获赠300元京东卡
Markdown文件
PDF文档
PDF文档(打印)
分享
链接
类型
密码
更新密码