Jonnyan的原创笔记
alpine
alpine里python安装mssql笔记
Alpine linux如何配置和管理自定义服务
windows
window server2012远程授权重置
window获取本机所有IP
window远程桌面RDP加速方案
远程监控 Win10 资源占用
windows 下 mysql 区分大小写敏感问题
window下navicat无限试用脚本
win11恢复win10右键菜单样式
永久禁止windows更新
强制本地账户安装win10/11
sqlserver(2012)在线清理tempdb
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
jsonargsrecommended: json arguments recommended for entrypoint to prevent unintended behavior related to os signals (line 30)
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-14百度输入法小米版使用森林集皮肤办法
Jenkins 构建后通知到飞书
简易的openvpn安装
keychron V1键盘改键教程
caddy2配置SSE单向websock(How to proxy Server Sent Events caddy2)
cleanmymacx 一直要求输入密码问题解决
Mac配置鼠须管输入法(Rime)
sorry this adobe app is not available(mac版本的Photoshop)
caddy2配置websocks
解决 all DNS requests failed, first error: dns: bad rdata
小米hyperos系统关闭5G信号开关
tg每日自动签到
简单的路由器系统
telegram被封号怎么办
机器监控告警
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
tailscale(推荐三)
N2N
nps
anylink
OmniEdge
quickvlan(昆浪智能)
本文档发布于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
2022年2月22日 22:40
1167
0 条评论
转发文档
收藏文档
上一篇
下一篇
手机扫码
复制链接
手机扫一扫转发分享
复制链接
如遇文档失效,可评论告知,便后续更新!
【腾讯云】2核2G云服务器新老同享 99元/年,续费同价
【阿里云】2核2G云服务器新老同享 99元/年,续费同价(不要✓自动续费)
【腾讯云】2核2G云服务器新老同享 99元/年,续费同价
【阿里云】2核2G云服务器新老同享 99元/年,续费同价(不要✓自动续费)
Markdown文件
Word文件
PDF文档
PDF文档(打印)
分享
链接
类型
密码
更新密码
有效期