journalctl 查看系統日志的利器


各位在書寫代碼的時候,對日志再熟悉不過,日志一般輸出方式有兩種,一種是控制台,一種是日志文件。
目前大部分的守護進程,都是由systemd來進行管理的,當我們想看這些守護進程的日志時,該怎么辦呢?這時就用到了journalctl命令。
 
感覺大家用的時候,最常用的命令就是
# 實時滾動顯示某進程的日志信息
sudo journalctl -f _PID=xxx

關於整個systemd的介紹,建議參考網絡介紹,以下拷貝自阮一峰博客

# 查看所有日志(默認情況下 ,只保存本次啟動的日志)
$ sudo journalctl

# 查看內核日志(不顯示應用日志)
$ sudo journalctl -k

# 查看系統本次啟動的日志
$ sudo journalctl -b
$ sudo journalctl -b -0

# 查看上一次啟動的日志(需更改設置)
$ sudo journalctl -b -1

# 查看指定時間的日志
$ sudo journalctl --since="2012-10-30 18:17:16"
$ sudo journalctl --since "20 min ago"
$ sudo journalctl --since yesterday
$ sudo journalctl --since "2015-01-10" --until "2015-01-11 03:00"
$ sudo journalctl --since 09:00 --until "1 hour ago"

# 顯示尾部的最新10行日志
$ sudo journalctl -n

# 顯示尾部指定行數的日志
$ sudo journalctl -n 20

# 實時滾動顯示最新日志
$ sudo journalctl -f

# 查看指定服務的日志
$ sudo journalctl /usr/lib/systemd/systemd

# 查看指定進程的日志
$ sudo journalctl _PID=1

# 查看某個路徑的腳本的日志
$ sudo journalctl /usr/bin/bash

# 查看指定用戶的日志
$ sudo journalctl _UID=33 --since today

# 查看某個 Unit 的日志
$ sudo journalctl -u nginx.service
$ sudo journalctl -u nginx.service --since today

# 實時滾動顯示某個 Unit 的最新日志
$ sudo journalctl -u nginx.service -f

# 合並顯示多個 Unit 的日志
$ journalctl -u nginx.service -u php-fpm.service --since today

# 查看指定優先級(及其以上級別)的日志,共有8級
# 0: emerg
# 1: alert
# 2: crit
# 3: err
# 4: warning
# 5: notice
# 6: info
# 7: debug
$ sudo journalctl -p err -b

# 日志默認分頁輸出,--no-pager 改為正常的標准輸出
$ sudo journalctl --no-pager

# 以 JSON 格式(單行)輸出
$ sudo journalctl -b -u nginx.service -o json

# 以 JSON 格式(多行)輸出,可讀性更好
$ sudo journalctl -b -u nginx.serviceqq
 -o json-pretty

# 顯示日志占據的硬盤空間
$ sudo journalctl --disk-usage

# 指定日志文件占據的最大空間
$ sudo journalctl --vacuum-size=1G

# 指定日志文件保存多久
$ sudo journalctl --vacuum-time=1years

 


免責聲明!

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



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