Linux下日志文件过大解决方案

不少Linux服务器里的应用程序都是无间断的输出日志,这对于服务器的硬盘是一个很大的考验。良许以前也分享过一篇文章,介绍如何让应用程序在后台执行:linux

linux后台执行命令:&与nohup的用法bash

经过以上方法,应用程序的日志会一直输出到日志文件myout.txt里,这个文件也会不断的增大,一直蚕食服务器硬盘。服务器

可是,咱们都知道,日志对于咱们而言是很是重要的,一量应用程序出现bug,或者服务器宕机,咱们必须经过日志文件来进行debug或进一步分析。因此,日志文件不能简单的一删了之。人工智能

这时,咱们想到,若是能将日志文件切分该多好,这样咱们能够留下重要的日志,而删掉没必要要的日志。下面良许就来详细介绍这种方法。debug

咱们能够天天都进行切分日志的操做,那要这样的话,为了不混淆,咱们切分出来的日志都应该带上日期。固然日期咱们能够经过如下语句获取:日志

current_date=`date -d "-1 day" "+%Y%m%d"`

date -d "-1 day"表示获取前一天的日期,就是说咱们今天操做的话是切割昨天的日志。+%Y%m%d是具体的日期格式,也就是年月日格式,好比:20181005。code

接下来,咱们再切割日志。it

split  -b 65535000 -d -a 4  myout.txt  ./log/log_${current_date}_

其中,65535000是60M,也就是日志文件按60M大小进行切割,可自定义大小。-d -a 4表示文件后缀是4位。咱们将文件切割后要按次序进行编号,好比0000,0001,0002……这个4就表明编号的位数。后台

再以后的./log/log${current_date}就是切割后日志文件的前缀,里面就带入了当前日期。因此,最终的输出格式相似于:log_20181005_0001。date

日志文件切割完以后,就能够将日志文件删除了,不然就失去切割文件的意义了。删除的方法能够用如下方式:

cat /dev/null > nohup.out

将以上这些命令写在一个脚本里,天天运行它,就能够将日志文件切割成若干分,便于咱们排查。完整的代码以下:

#!/bin/bash

current_date=`date -d "-1 day" "+%Y%m%d"`
split -b 65535000 -d -a 4 /home/alvin/myout.txt   /home/alvin/log/log_${current_date}_
cat /dev/null > nohup.out

更多精彩内容,请关注公众号良许Linux,公众内回复1024可免费得到5T技术资料,包括:Linux,C/C++,Python,树莓派,嵌入式,Java,人工智能,等等。公众号内回复进群,邀请您进高手如云技术交流群。

img


公众号:良许Linux

有收获?但愿老铁们来个三连击,给更多的人看到这篇文章