linux清理磁盤空間 - 日志 - journalctl


1.簡單操作

坊間有一句謠言:Linux沒有垃圾文件,只有Windows才有,說的好像外星人和外星人之間溝通不需要語言一樣。

操作系統,顧名思義就是操作各種文件的系統。它不可能沒有日志文件,因為記錄操作歷史日志,可以方便管理。它更不可能不產生臨時文件,就像剪紙一樣,臨時產生一些廢料是再自然不過的事情。

Linux到底有沒有占用空間的垃圾文件,下圖就可以說明。

未清理前發現硬盤根分區空間告急,用du -t 100M /varjournalctl --disk-usage命令一查,發現/var/log/journal日志文件占用了近3G空間,每個日志文件體積高達128M,這些日志文件記錄了很長時間以來的systemd情況,毫無價值,用journalctl --vacuum-size=10M命令將其清理之后,騰出了2.7G的空間。用df命令一查,/根分區果然寬敞了很多。

接下來,我還要探索其他清理Linux垃圾的方法……

 

2.詳情

CentOS系統中有兩個日志服務,分別是傳統的 rsyslog systemd-journal

systemd-journald是一個改進型日志管理服務,可以收集來自內核、系統早期啟動階段的日志、系統守護進程在啟動和運行中的標准輸出和錯誤信息,還有syslog的日志。

該日志服務僅僅把日志集中保存在單一結構的日志文件/run/log中,由於日志是經歷過壓縮和格式化的二進制數據,所以在查看和定位的時候很迅速。

本文轉自米撲博客:Linux 系統 /var/log/journal/ 垃圾日志清理

默認情況下並不會持久化保存日志,只會保留一個月的日志。另外,一些rsyslog無法收集的日志也會被journal記錄到。

rsyslog作為傳統的系統日志服務,把所有收集到的日志都記錄到/var/log/目錄下的各個日志文件中。

常見的日志文件如下:

  /var/log/messages 絕大多數的系統日志都記錄到該文件
  /var/log/secure 所有跟安全和認證授權等日志都會記錄到此文件
  /var/log/maillog 郵件服務的日志
  /var/log/cron crond計划任務的日志
  /var/log/boot.log 系統啟動的相關日志

 

曾經有人說:Linux沒有垃圾文件,Windows才有垃圾文件,實際上不是這樣的,兩者都會有垃圾文件。

操作系統,就是操作各種文件的系統,它不可能沒有日志文件,更不可能不產生臨時文件,就像剪紙一樣,臨時產生一些廢料是再自然不過的事情。

Linux到底有沒有占用空間的垃圾文件,這個看如何判定了,例如好幾年前、幾個月前的日志文件、系統文件,基本沒什么用處,算垃圾文件嗎?

  ls -lhm --full-time /var/log/journal/f9d400c5e1e8c3a8209e990d887d4ac1_bk_20190122/ | sort -k6 | head -n30

  # ls -lhm --full-time /var/log/journal/f9d400c5e1e8c3a8209e990d887d4ac1_bk_20190122/ | sort -k6 | head -n30
total 3.5G
  -rw-r-x---+ 1 root systemd-journal 64M 2018-03-28 01:36:01.010275802 +0800 system@00000000000000000000000000000000-00000000000002ca-000567d28f35cca7.journal
  -rw-r-x---+ 1 root systemd-journal 8.0M 2018-03-28 01:36:01.100275802 +0800 user-65534@4ee96b2fbd8b4a82beee0402402fee03-0000000000005419-000567f7fd08bd2f.journal
  -rw-r-x---+ 1 root systemd-journal 72M 2018-04-02 19:16:41.644934707 +0800 system@00000000000000000000000000000000-0000000000010a47-0005686852f561be.journal
  -rw-r-x---+ 1 root systemd-journal 8.0M 2018-04-02 19:16:41.714934707 +0800 user-65534@4ee96b2fbd8b4a82beee0402402fee03-0000000000011f98-00056872cab77761.journal
  -rw-r-x---+ 1 root systemd-journal 72M 2018-04-08 05:48:01.673026304 +0800 system@00000000000000000000000000000000-0000000000021c40-000568dbb97116ae.journal
  -rw-r-x---+ 1 root systemd-journal 72M 2018-04-13 18:25:01.967846109 +0800 system@00000000000000000000000000000000-0000000000033800-00056949207ae8a1.journal
  -rw-r-x---+ 1 root systemd-journal 72M 2018-04-18 04:12:35.385621922 +0800 system@00000000000000000000000000000000-0000000000045c3e-000569b848f6f86c.journal
查看垃圾文件的方法

未清理前發現硬盤根分區空間告急,用 du -t 100M /var 或 journalctl --disk-usage 命令查看,發現/var/log/journal日志文件占用了近3G空間,每個日志文件體積高達8-128M,這些日志文件記錄了很長時間以來的systemd情況,毫無價值,用journalctl --vacuum-size=10M命令將其清理之后,騰出了2.7G的空間。用df命令一查,/根分區果然寬敞了很多。

 

查看某個目錄的文件大小並排序(單位為MB)

  du -hm --max-depth=1 /var/ | sort -n

  # du -hm --max-depth=1 /var/ | sort -n
  1 /var/adm
  1 /var/crash
  1 /var/db
  1 /var/empty
  1 /var/games
  1 /var/gopher
  1 /var/kerberos
  1 /var/local
  1 /var/nis
  1 /var/opt
  1 /var/preserve
  1 /var/spool
  1 /var/tmp
  1 /var/yp
  131 /var/www
  198 /var/lib
  486 /var/cache
  3695 /var/log
  8513 /var/
清空 /var/log/journal 文件的方法

1、用echo命令,將空字符串內容重定向到指定文件中

  echo "" > system.journal

  說明:此方法只會清空一次,一段時間后還要再次手動清空很麻煩,這里可以用以下命令讓journalctl 自動維護空間

 

2、journalctl 命令自動維護文件大小

1)只保留近一周的日志

  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 --vacuum-time=1w
  Error was encountered while opening journal files: Input/output error
問題分析:日志文件損壞

解決方法:刪除之前的日志,並重啟 journalctl 服務

  mv journal/f9d400c5e1e8c3a8209e990d887d4ac1 journal/f9d400c5e1e8c3a8209e990d887d4ac1_bk_20190122

  systemctl restart systemd-journald.service

查看 /var/log/journal/ 日志目錄如下:

  # ll /var/log/journal/
  drwxr-sr-x 2 root systemd-journal 4096 Jan 22 11:26 f9d400c5e1e8c3a8209e990d887d4ac1
  drwxr-sr-x+ 2 root systemd-journal 12288 Jan 14 15:37 f9d400c5e1e8c3a8209e990d887d4ac1_bk_20190122
 

然后,再執行 journalctl 限制日志的命令:

  # journalctl --vacuum-time=1w
  Vacuuming done, freed 0B of archived journals on disk.
  # journalctl --vacuum-size=500M
  Vacuuming done, freed 0B of archived journals on disk.

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM