有的时候咱们为了让某个程序在后台跑,通常都会用nohup ./xxx & 执行让程序后台运行,假设过了一段时间日志就上G了,若是有问题想要查看日志,显然打开文件是一件很麻烦的事,有什么办法能够减少文件大小呢?面试
语法:shell
nohup [command] [args] [&]
说明:nohup 命令运行由 Command 参数和任何相关的 Arg 参数指定的命令,忽略全部挂断信号。在注销后使用 nohup 命令运行后台中的程序。要运行后台中的 nohup 命令,添加 & ( 表示“and”的符号)到命令的尾部,若是不指定重定向,则日志默认输出到当前目录下nohup.out文件中,bash
重定向: nohup ./execute.sh > /home/xxx/log.log 2>&1 & :这样日志会重定向到指定目录下。spa
& : 指在后台运行日志
nohup : 不挂断的运行,注意并无后台运行的功能,,就是指,用nohup运行命令可使命令永久的执行下去,和用户终端没有关系,例如咱们断开SSH链接都不会影响他的运行,注意了nohup没有后台运行的意思;&才是后台运行code
思路:定时将nohup.out切分红,多个小文件,但同时又要使nohup.out不会无限增加下去(通常状况下是程序不能中断的)。blog
a、天天(根据须要设置时间),定时切分前一天的日志,(好比天天大概1g,那么能够么次切分100m左右),it
b、切分完后将nohup.out文件状况,保证新的输出日志会不停的继续输出到nohup.outclass
以上在shell中后台
current_date=`date -d "-1 day" "+%Y%m%d"` split -b 65535000 -d -a 4 nohup.out ./log/log_${current_date}_
这里使用split命令,将nouhup文件按指定大小切分(65535000b 大概60多M吧,能够自定义大小 ),并分红指定格式(-d -a 4以4位数字形式为后缀以从0000开始),最终输出格式为log_20190918_0001
-d 将字符后缀改成数字后缀,后面可加参数表示从哪一个数字开始
-a 指定后缀的长度
-b<字节> : 指定每多少字节切成一个小文件
-C<字节> : 与参数"-b"类似,可是在切 割时将尽可能维持每行的完整性
cat /dev/null > nohup.out
(该命令会瞬间清空nohup.out文件,后续会继续写该文件),将日志定向到/dev/null中
使用重定向输出同样能够这样,只不过换成重定向的文件名便可
将这些命令定义在一个shell文件天天定时运行便可,这样天天日志会被分红若干份,排查也方便,并且若是日志积压过大的话。能够定时删除历史的日志,保留近几天便可。
最终脚本以下:
#!/bin/bash path=$(cd `dirname $0`;pwd) cd $path echo $path current_date=`date -d "-1 day" "+%Y%m%d"` echo $current_date split -b 65535000 -d -a 4 /home/nohup.out /home/log/log_${current_date}_ cat /dev/null > nohup.out