在 Linux 系统中手动滚动日志的方法(在linux系统中以什么访问设备)

admin3年前云主机44

日志滚动log rotation在 Linux 系统上是再常见不过的一个功能了,它为系统监控和故障排查保留必要的日志内容,同时又防止过多的日志造成单个日志文件太大。

日志滚动的过程是这样的:在一组日志文件之中,编号最大的(最旧的)一个日志文件会被删除,其余的日志文件编号则依次增大并取代较旧的日志文件,而较新的文件则取代它作为当前的日志文件。这一个过程很容易就可以实现自动化,在细节上还能按需作出微调。

使用 logrotate 命令可以手动执行日志滚动的操作。本文将要介绍的就是手动进行日志滚动的方法,以及预期产生的结果。

文中出现的示例适用于 Ubuntu 等 Linux 系统,对于其它类型的系统,日志文件和配置文件可能会有所不同,但日志滚动的过程是大同小异的。

为什么需要滚动日志

一般情况下,无需手动旋转日志文件。Linux 系统会每隔一天(或间隔更长的时间)或根据日志文件的大小自动进行一次日志滚动。如果你需要滚动日志以释放存储空间,又或者将某一部分日志从当前的活动中分割出来,这很容易做到,具体要取决于文件滚动规则。

一点背景介绍

在 Linux 系统安装完成后就已经有很多日志文件被纳入到日志滚动的范围内了。另外,一些应用程序在安装时也会为自己产生的日志文件设置滚动规则。一般来说,日志滚动的配置文件会放置在 /etc/logrotate.d。如果你想了解日志滚动的详细实现,可以参考这篇以前的文章。

在日志滚动的过程中,活动日志会以一个新名称命名,例如 log.1,之前被命名为 log.1 的文件则会被重命名为 log.2,依此类推。在这一组文件中,最旧的日志文件(假如名为 log.7)会从系统中删除。日志滚动时文件的命名方式、保留日志文件的数量等参数是由 /etc/logrotate.d 内容介绍中的配置文件决定的,因此你可能会看到有些日志文件只保留少数几次滚动,而有些日志文件的滚动次数会到 7 次或更多。

例如 syslog 在经过日志滚动之后可能会如下所示(注意,行尾的注释部分只是说明滚动过程是如何对文件名产生影响的):

$ ls -l /var/log/syslog*-rw-r----- 1 syslog adm 128674 Mar 10 08:00 /var/log/syslog <== 新文件-rw-r----- 1 syslog adm 2405968 Mar 9 16:09 /var/log/syslog.1 <== 之前的 syslog-rw-r----- 1 syslog adm 206451 Mar 9 00:00 /var/log/syslog.2.gz <== 之前的 syslog.1-rw-r----- 1 syslog adm 216852 Mar 8 00:00 /var/log/syslog.3.gz <== 之前的 syslog.2.gz-rw-r----- 1 syslog adm 212889 Mar 7 00:00 /var/log/syslog.4.gz <== 之前的 syslog.3.gz-rw-r----- 1 syslog adm 219106 Mar 6 00:00 /var/log/syslog.5.gz <== 之前的 syslog.4.gz-rw-r----- 1 syslog adm 218596 Mar 5 00:00 /var/log/syslog.6.gz <== 之前的 syslog.5.gz-rw-r----- 1 syslog adm 211074 Mar 4 00:00 /var/log/syslog.7.gz <== 之前的 syslog.6.gz

你可能会发现,除了当前活动的日志和最新一次滚动的日志文件之外,其余的文件都已经被压缩以节省存储空间。这样设计的原因是大部分系统管理员都只需要查阅最新的日志文件,其余的日志文件压缩起来,需要的时候可以解压查阅,这是一个很好的折中方案。

手动日志滚动

你可以这样执行 logrotate 命令进行手动日志滚动:

$ sudo logrotate -f /etc/logrotate.d/rsyslog

值得一提的是,logrotate 命令使用 /etc/logrotate.d/rsyslog 这个配置文件,并通过了 -f 参数实行“强制滚动”。因此,整个过程将会是:

  • 删除 syslog.7.gz,
  • 将原来的 syslog.6.gz 命名为 syslog.7.gz,
  • 将原来的 syslog.5.gz 命名为 syslog.6.gz,
  • 将原来的 syslog.4.gz 命名为 syslog.5.gz,
  • 将原来的 syslog.3.gz 命名为 syslog.4.gz,
  • 将原来的 syslog.2.gz 命名为 syslog.3.gz,
  • 将原来的 syslog.1.gz 命名为 syslog.2.gz,
  • 但新的 syslog 文件不一定必须创建。

你可以按照下面的几条命令执行操作,以确保文件的属主和权限正确:

$ sudo touch /var/log/syslog$ sudo chown syslog:adm /var/log/syslog$ sudo chmod 640 /var/log/syslog

你也可以把以下这一行内容添加到 /etc/logrotate.d/rsyslog 当中,由 logrotate 来帮你完成上面三条命令的操作:

create 0640 syslog adm

整个配置文件的内容是这样的:

/var/log/syslog{rotate 7dailymissingoknotifemptycreate 0640 syslog adm <==delaycompresscompresspostrotate/usr/lib/rsyslog/rsyslog-rotateendscript}

下面是手动滚动记录用户登录信息的 wtmp 日志的示例。由于 /etc/logrotate.d/wtmp 中有 rotate 2 的配置,因此系统中只保留了两份 wtmp 日志文件。

滚动前:

$ ls -l wtmp*-rw-r----- 1 root utmp 1152 Mar 12 11:49 wtmp-rw-r----- 1 root utmp 768 Mar 11 17:04 wtmp.1

执行滚动命令:

$ sudo logrotate -f /etc/logrotate.d/wtmp

滚动后:

$ ls -l /var/log/wtmp*-rw-r----- 1 root utmp 0 Mar 12 11:52 /var/log/wtmp-rw-r----- 1 root utmp 1152 Mar 12 11:49 /var/log/wtmp.1-rw-r----- 1 root adm 99726 Feb 21 07:46 /var/log/wtmp.report

需要知道的是,无论发生的日志滚动是自动滚动还是手动滚动,最近一次的滚动时间都会记录在 logrorate 的状态文件中。

$ grep wtmp /var/lib/logrotate/status"/var/log/wtmp" 2020-3-12-11:52:57

总结

到此这篇关于在 Linux 系统中手动滚动日志的文章就介绍到这了,更多相关linux 滚动日志内容请搜索站长源码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持站长源码网!《在 Linux 系统中手动滚动日志的方法(在linux系统中以什么访问设备)》来自互联网同行内容,若有侵权,请联系我们删除!

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

windows11系统

Windows11系统——开启新时代的操作系统Windows11系统是微软于2021年发布的全新操作系统。它具有更加强大的性能、更加流畅的界面、更加智能的功能等一系列革命性的升级,是微软数年来最重要的...

智能化虚拟企业的未来:探讨数字化转型与智能化升级的新趋势

随着数字化和智能化的快速发展,智能化虚拟企业正在成为一种新的商业模式。本文将探讨数字化转型与智能化升级的新趋势,阐述智能化虚拟企业的未来发展方向。文章主要分为四个方面:一、智能化虚拟企业的概念和优势;...

怎么选择台湾服务器的配置?台湾服务器出租怎么选择?

服务器大家一定都不陌生,服务器是一种大型的计算机,它的运行速度更快,带宽更宽,所谓台湾服务器,就是主机设置的台湾的服务器,那么怎么选择台湾服务器的配置?台湾服务器是什么台湾服务器和内地服务器本身没有什...

商助短信:打造高效沟通,提升商业价值

一、定位精准企业想要取得成功,首要的就是找到适合自己的营销定位。商助短信通过用户行为数据挖掘和消费者画像,对某一产品或服务的目标用户做出精准定位,确定针对性营销策略,并制定相应的短信营销计划。其次,商...

php开源博客源码

PHP开源博客源码随着互联网的发展,越来越多的人开始在网络上记录自己的生活点滴,分享自己的知识和想法,博客因此而诞生,并迅速流行起来。随着时间的推移,各种开源的博客源码也应运而生,今天我们就来了解一下...

信创服务器品牌:领先科技,稳定高效

一、技术创新作为一家领先科技的企业,信创服务器品牌在技术创新方面做出了很多努力。首先,其服务器的独特设计,可帮助提高服务器的性能和可靠性。此外,信创服务器采用先进的云计算技术,在提高性能的同时,也能降...