51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 813|回复: 0
打印 上一主题 下一主题

如何在Linux下进行压缩备份日志!

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2022-8-16 14:07:12 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 草帽路飞UU 于 2022-8-19 16:26 编辑

背景
  系统中安装了前置机服务,该服务由银行提供。前置机日志打印的非常详细,同时并未进行压缩处理。这导致的直接后果就是,每天会有5G左右的日志产生。过不了多久就需要手动压缩备份一次。
  当今天系统再次报警磁盘不足时,决定彻底解决该问题。解决的方案也很简单,基于Linux写一个简单的脚本,对日志进行定时压缩备份。大家如果在实践中遇到类似的问题,可以直接基于下面的脚本进行修改、丰富使用。
  具体操作
  执行脚本编写
  首先,创建一个执行日志压缩、备份和删除的脚本,命名backup.sh,并赋予可执行权限,脚本内容如下:

 #!/bin/bash
  cd /log/
  echo '开始压缩...'
  tar -czvf /log/bak/trade.log.`date -d yesterday +%F`.tar.gz trade.log.`date -d yesterday +%F`
  echo '压缩完毕...,执行删除'
  rm -rf trade.log.`date -d yesterday +%F`
  echo '删除完毕.'


  在上述脚本中,先通过cd?命令进入目标目录,在执行命令中会通过echo打印一些日志信息,这个主要用于进行调试。
  执行tar -czvf命令,进行日志的压缩。命令后面第一个参数为压缩之后的文件的名称及存储路径,这里放到bak目录下,第二个参数为待压缩的日志。
  我们重点来介绍一下文件名称中date -d yesterday +%F?的含义。在Linux中,date +"%F"能输出系统的当前日期:
  $ date +"%F"
  2022-08-09


  命令中,date命令是输入日期,后面部分用于格式化。
  但这都是打印出系统的当前时间,如果要获取相对当前时间的某个时间,需要通过-d参数来实现。
  $ date -d yesterday +%F
  2022-08-08


  这里就获得了前一天的日期了。当然,也可以输出后一天的时间,比如:
  $ date -d"yesterday" +"%F %H:%M:%S"
  2022-08-08 21:36:15


  在理解了如何获取系统日期之后,上面的脚本就比较好理解了。
  先通过执行tar -czvf?命令,进行日志的压缩,压缩文件直接存放在bak目录,压缩完毕之后,通过rm -rf命令对日志进行删除。
  在完成上述编辑之后,可以直接执行该脚本,验证一下是否正确,然后就可以通过定时任务来进行配置了。
  定时任务执行
  在完成了脚本的编写并赋予可执行权限之后,就需要基于crontab来进行定时任务的配置。
  执行crontab -e打开定时任务文件编辑界面,输入如下信息:
  30 2 * * * /log/backup.sh

  上面的指令是在说:每天2点30分执行/log/backup.sh脚本。编辑完成,保持退出。那么在每天凌晨2点30分,便会进行脚本的执行。
  这里再拓展一下,上述crontab中对应的表达式含义如下:
  minute   hour   day   month   week   command     顺序:分 时 日 月 周 命令

  根据需要,你可以调整定时任务的执行时间点或周期。
  关于crontab这里再补充一下它的常见指令,方便大家使用:
  crontab -e // 编辑
  crontab -l // 查看
  service crond status
  service crond start// 启动服务
  service crond stop// 关闭服务
  service crond restart// 重启服务
  service crond reload  // 重新载入配置
  cd /var/spool/mail/用户文件 查看执行情况


  小结
  至此,关于Linux下自动日志压缩备份脚本已经完成。虽然非常简单,但却可以极大地释放人力资源,再也不用手动清理了。当然,在实践中,场景不同使用的脚本可能更会更复杂,但基本原理是一致的,大家可根据具体情况来丰富脚本的功能。




分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-11-9 02:20 , Processed in 0.064773 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

快速回复 返回顶部 返回列表