linux自动清理日志的方法分享1.做自动部署系统时精简linux清楚日志命令的一个脚本,主要功能是清理所有目录linux清楚日志命令的日志
2.根据给定日志目录,删除时间 结合crontab进行清理日志,清理完成后,后在/var/log/deltelog/ 生成按照月的清理日志
3.扩展,因为脚本采用mtime(最后修改时间)进行删除,所以可以适用于删除过期备份等,不受文件名称的限制
shell小窍门
find –type f –print 时会根据换行或者空格来输出查找的文件,在不同的sh下有不同的`反应,如果不做处理结合xargs 进行删除 更改操作,会有影响
所以需要增加 –print0 用 null来 作为边界符号,才敢结婚 xargs –o 来格式化输入
使用find 的时候 遵循最小结果集原则,find解析式从左到右,所有确保你在最左边的过滤符号能够过滤最大数据
你可以根据你的需要增加到crontab中
shell脚本
复制代码 代码如下:
#!/bin/sh
###########################
# log blog.duplicatedcode.com
# in_day_num: like 1 2 is2day ago logs
# in_log_path like tomcat log home
###########################
in_log_path=${1}
in_day_num=${2}
tmp__log=/var/log/log/"`date%Y%m`.log"
Log()
{
inner_num=${1}
#find log
echo "[`date`]startlogs---"$tmp__log
find ${in_log_path} -type f -mtime ${inner_num} -print0 | xargs -0 rm -rf
echo "[`date`]endlogs---"$tmp__log
}
init()
{
mkdir -p /var/log/log/
}
main()
{
init
if [ -z ${in_log_path} ];then
echo "[`date`]error log_path not init---"$tmp__log
return
fi
inner_day_num= 7
if [[ -n ${in_day_num} ]][[ ${in_day_num} -ge 1 ]] ; then
${inner_day_num}=${in_day_num}
fi
Log ${inner_day_num}
}
main
linux定时清理nohup命令下产生的日志nohup命令 将程序以忽略挂起信号的方式运行起来,被运行的程序的输出信息将不会显示到终端 。一般用于将程序的输出、报错信息重定向到一个指定路径的指定文件 。
语法 :nohup [command] [args] []
nohup命令 最后要带个作为结束
例:nohup python XXX.pyabc/def/XXX.log 21
args: 0 – stdin (standard input),1 – stdout (standard output),2 – stderr (standard error) ;
21是将标准错误(2)重定向到标准输出(1) , 标准输出(1)再被重定向输入到文件,即XXX.log中 。
nohup命令的缺点:日志文件文件越来越大,占内存且查看麻烦 。因为这个日志文件和程序是共生死的 , 因为只要程序运行起来 , 就一直对log文件进行读写,直接删除XXX.log会导致程序也被结束了 。
目前想到的一些相关方法如下,并未完全解决问题 。
参考: linux下nohup日志输出过大问题解决方案
split命令:
参数:-b:值为每一输出档案的大小 , 单位为 byte 。
-C:每一输出档中 , 单行的最大 byte 数 。
-d:使用数字作为后缀 。默认这个数字后缀是两位的,例如00,01,11. -a: 指定位数 , 例如 -a 4表示后缀是四位的 。
-l:值为每一输出档的列数大小 。
PREFIX:代表前导符 , 可作为切割文件的前导文件 。
例如:
可以用split命令把很大的日志文件分成多个小文件 , 分割完成后 原文件不变。不会影响nohup运行的程序 。
缺点:split文件分割依赖手动,当程序出故障或调试时 , 将日志分割以便查看最新的日志信息 。没法定时做到定时自动清理 。
首先介绍find命令的参数
参考: linux find命令详解
在这里主要用到的是这几个参数:
-atime n查找系统中最后n*24小时访问的文件
-ctime n查找系统中最后n*24小时被改变文件状态的文件
-mtime n查找系统中最后n*24小时被改变文件数据的文件
n: n天前; -n: n天之内
find命令还可以和下一条命令连用(xargs或exec)
或
注:{}表示find到的东西;{}和 \;之间要有一个空格
我感觉exec不是很好用,怪怪的
cat dev/null
在 Linux 中,null 设备基本上被用来丢弃某个进程不再需要的输出流,或者作为某个输入流的空白文件,这些通常可以利用重定向机制来达到 。
所以 /dev/null 设备文件是一个特殊的文件 , 它将清空送到它这里来的所有输入,而它的输出则可被视为一个空文件 。另外,你可以通过使用 cat 命令显示 /dev/null 的内容然后重定向输出到某个文件 , 以此来达到清空该文件的目的 。通过使用cat /dev/null,文件大小为0字节 。
用cat删除文件:
但是我发现对于nohup的程序的日志,这样是无效的 。因为nohup的程序持续不断地在读写日志文件,此时无法重定向,我试了几次,日志文件都压根没动 。
crontab用于设置定时任务
参考:linux crontab定时执行shell脚本
crontab命令被用来提交和管理用户的需要周期性执行的任务,与windows下的计划任务类似,当安装完成操作系统后,默认会安装此服务工具,并且会自动启动crond进程,crond进程每分钟会定期检查是否有要执行的任务,如果有要执行的任务,则自动执行该任务 。
语法
crontab(选项)(参数)
选项
-e:编辑该用户的计时器设置;
-l:列出该用户的计时器设置;
-r:删除该用户的计时器设置;
-u用户名称:指定要设定计时器的用户名称 。
参数
crontab文件:指定包含待执行任务的crontab文件 。
首先crontab -e,就会进入vi编辑界面 。然后直接把新的命令输进去就行了 。
minutehourdaymonthweekcommand /XXX/XXX.log 顺序:分 时 日 月 周
minute: 表示分钟,可以是从0到59之间的任何整数 。
hour:表示小时,可以是从0到23之间的任何整数 。
day:表示日期,可以是从1到31之间的任何整数 。
month:表示月份,可以是从1到12之间的任何整数 。
week:表示星期几,可以是从0到7之间的任何整数,这里的0或7代表星期日 。
/n表示每个n的单位执行一次
command:要执行的命令,可以是系统命令,也可以是自己编写的脚本文件 。
意为每周的1:00执行 , 且输出重定向到黑洞目录 。
Linux系统 /var/log/journal/ 垃圾日志清理查看某个目录的文件大小并排序 (单位为MB)
清空 /var/log/journal 文件的方法
1、用echo命令 , 将空字符串内容重定向到指定文件中
echo ""system.journal
2、journalctl 命令自动维护文件大小
1)只保留近一周的日志
【linux清楚日志命令 linux 清日志】 journalctl --vacuum-time=1w
2)只保留500MB的日志
journalctl --vacuum-size=500M
3)直接删除 /var/log/journal/ 目录下的日志文件
rm -rf /var/log/journal/f9d400c5e1e8c3a8209e990d887d4ac1
问题与分析解决
执行 journalctl时报错:Error was encountered while opening journal files: Input/output error
问题分析:日志文件损坏
解决方法:删除之前的日志,并重启 journalctl 服务
然后,再执行 journalctl 限制日志的命令:
在Linux下如何清除系统日志 使用过Windows的人都知道,在使用windows系统的.过程中系统会变得越来越慢 。而对于Windows下饱受诟病的各种垃圾文件都需要自己想办法删除,不然系统将会变得越来越大,越来越迟钝!windows怎么清理垃圾相信大家都知道的,那么linux下怎么清理系统垃圾呢?
Linux的文件系统比Windows的要优秀,不会产生碎片,对于长时间运行的服务器来说尤为重要,而且Linux系统本身也不会像Windows一样产生大量的垃圾文件 。不知道这个说法有没有可信度!至少我们可以确定的是linux系统的文件系统是比较优秀的!
错误
rm -f logfile
原因
应用已经打开文件句柄 , 直接删除会造成:
1.应用无法正确释放日志文件和写入
2.显示磁盘空间未释放
正确
cat /dev/nulllogfile
把一下代码保存为.sh后缀脚本来运行即可清除Linux系统日志
#!/bin/sh
cat /dev/null/var/log/syslog
cat /dev/null/var/adm/sylog
cat /dev/null/var/log/wtmp
cat /dev/null/var/log/maillog
cat /dev/null/var/log/messages
cat /dev/null/var/log/openwebmail.log
cat /dev/null/var/log/maillog
cat /dev/null/var/log/secure
cat /dev/null/var/log/httpd/error_log
cat /dev/null/var/log/httpd/ssl_error_log
cat /dev/null/var/log/httpd/ssl_request_log
cat /dev/null/var/log/httpd/ssl_access_log
另外清理linux系统垃圾还有以下命令
sudo apt-get autoclean 清理旧版本的软件缓存
sudo apt-get clean 清理所有软件缓存
sudo apt-get autoremove 删除系统不再使用的孤立软件
linux日志清理脚本清理不掉linux是一个很能自动产生文件的系统linux清楚日志命令,日志、邮件、备份等 。虽然现在硬盘廉价,linux清楚日志命令我们可以有很多硬盘空间供这些文件浪费 , 让系统定时清理一些不需要的文件很有一种爽快的事情 。不用你去每天惦记着是否需要清理日志,不用每天收到硬盘空间不足的报警短信,想好好休息的话,让我们把这个事情交给机器定时去执行吧 。
二、 分析日志
查看日志路径和日志命名规则linux清楚日志命令:
要清理这个目录下面如此命名规则的日志 。
三、方法
这时我想的肯定是希望能写一个脚本把这些日志清除掉,但不是删除掉 。那么现在需要实现3步:
1.找到所有项目的log的位置
2.清除或者删除log内容
3.定时执行脚本
删除和清空日志命令:
find 对应目录 -mtime天数 -name "文件名" -exec rm -rf {} \;
实例命令:
find /opt/soft/log/ -mtime7 -name "*.log" -exec rm -rf {} \;
说明:
将/opt/soft/log/目录下所有7天前带".log"的文件删除 。具体参数说明如下:
find:linux的查找命令,用户查找指定条件的文件;
/opt/soft/log/:想要进行清理的任意目录;
-mtime:标准语句写法;
7:查找7天前的文件 , 这里用数字代表天数;
"*.log":希望查找的数据类型,"*.jpg"表示查找扩展名为jpg的所有文件,"*"表示查找所有文件,这个可以灵活运用,举一反三;
-exec:固定写法;
rm -rf:强制删除文件,包括目录;
{} \; :固定写法,一对大括号 空格 \ ;
清空方法:
find /opt/soft/log/ -mtime7 -name "*.log" -type f -print -exec truncate -s 0 {} \;-将符合这样一个条件的文件查到出来并赋予它0M的大小 。
-type f -print: 将符合的文件打印出来
truncate -s 0 aa.txt:意思是将aa.txt的大小变成0M,即把aa.txt的内容清空了
linux清楚日志命令的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux 清日志、linux清楚日志命令的信息别忘了在本站进行查找喔 。
推荐阅读
- 华为鸿蒙系统怎么改为安卓,华为鸿蒙系统怎么变为安卓系统
- 怎么连接sql服务器,连接sql服务器用哪个工具
- 郑州旅游度假区直播带货,郑州旅游产品
- go核心代码c语言 go语言核心编程pdf
- 新媒体公司行业现状如何,新媒体公司行业现状如何分析
- 视频器下载,视频下载器下载手机版
- 棋牌游戏2017新规的简单介绍
- python的魔鬼函数 python 魔术变量
- 显卡驱动器怎么查找,显卡的驱动在哪里看