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

系统 Linux
很多Linux服务器里的应用程序都是无间断的输出日志,这对于服务器的硬盘是一个很大的考验。

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

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

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

[[342638]]

但是,我们都知道,日志对于我们而言是非常重要的,一量应用程序出现bug,或者服务器宕机,我们必须通过日志文件来进行debug或进一步分析。所以,日志文件不能简单的一删了之。

这时,我们想到,如果能将日志文件切分该多好,这样我们可以留下重要的日志,而删掉不必要的日志。下面良许就来详细介绍这种方法。

我们可以每天都进行切分日志的操作,那要这样的话,为了避免混淆,我们切分出来的日志都应该带上日期。当然日期我们可以通过以下语句获取:

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

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

接下来,我们再切割日志。

  1. 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。

日志文件切割完之后,就可以将日志文件删除了,否则就失去切割文件的意义了。删除的方法可以用以下方式:

  1. cat /dev/null > nohup.out 

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

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

本文授权转载自公众号「良许Linux」。良许,世界500强外企Linux开发工程师,公众号里分享大量Linux干货,欢迎关注!

 

责任编辑:赵宁宁 来源: 今日头条
相关推荐

2015-07-27 16:56:24

LinuxQQ

2013-08-13 19:49:20

CA Technolo云计算移动化

2022-07-29 10:26:02

物联网智慧城市

2012-06-04 13:34:54

航空IBM解决方案

2010-09-13 14:26:04

sql server日

2012-05-10 18:20:05

戴尔

2013-07-03 14:43:44

戴尔软件

2012-05-28 11:38:59

2010-08-19 10:01:19

IE6margin

2010-11-03 14:49:54

惠普企业解决方案

2010-06-04 17:58:09

MySQL远程连接

2009-08-07 10:36:18

linux命令乱码linux命令行乱码Linux操作系统

2010-02-22 10:29:11

WCF上传文件

2009-07-28 08:49:37

2010-09-06 15:37:13

Windows服务器数据保护Websense

2010-02-05 15:54:37

IBM Power

2022-05-01 20:25:03

火山引擎内容运营

2010-09-09 10:11:11

无线网络故障

2022-02-16 22:30:51

嵌入式软件开发工具

2018-08-01 14:34:22

新华三
点赞
收藏

51CTO技术栈公众号