## 18.4 systemd-journald.service 簡介
過去只有 rsyslogd 的年代中,由于 rsyslogd 必須要開機完成并且執行了 rsyslogd 這個 daemon 之后,登錄文件才會開始記錄。所以,核心還得要自己產生一個 klogd 的服務, 才能將系統在開機過程、啟動服務的過程中的信息記錄下來,然后等 rsyslogd 啟動后才傳送給它來處理~
現在有了 systemd 之后,由于這玩意兒是核心喚醒的,然后又是第一支執行的軟件,它可以主動調用 systemd-journald 來協助記載登錄文件~ 因此在開機過程中的所有信息,包括啟動服務與服務若啟動失敗的情況等等,都可以直接被記錄到 systemd-journald 里頭去!
不過 systemd-journald 由于是使用于內存的登錄文件記錄方式,因此重新開機過后,開機前的登錄文件信息當然就不會被記載了。 為此,我們還是建議啟動 rsyslogd 來協助分類記錄!也就是說, systemd-journald 用來管理與查詢這次開機后的登錄信息,而 rsyslogd 可以用來記錄以前及現在的所以數據到磁盤文件中,方便未來進行查詢喔!

**Tips** 雖然 systemd-journald 所記錄的數據其實是在內存中,但是系統還是利用文件的型態將它記錄到 /run/log/ 下面! 不過我們從前面幾章也知道, /run 在 CentOS 7 其實是內存內的數據,所以重新開機過后,這個 /run/log 下面的數據當然就被刷新,舊的當然就不再存在了!
### 18.4.1 使用 journalctl 觀察登錄信息
那么 systemd-journald.service 的數據要如何叫出來查閱呢?很簡單!就通過 journalctl 即可!讓我們來瞧瞧這個指令可以做些什么事?
```
[root@study ~]# journalctl [-nrpf] [--since TIME] [--until TIME] _optional
選項與參數:
默認會秀出全部的 log 內容,從舊的輸出到最新的訊息
-n :秀出最近的幾行的意思~找最新的信息相當有用
-r :反向輸出,從最新的輸出到最舊的數據
-p :秀出后面所接的訊息重要性排序!請參考前一小節的 rsyslogd 信息
-f :類似 tail -f 的功能,持續顯示 journal 日志的內容(實時監測時相當有幫助!)
--since --until:設置開始與結束的時間,讓在該期間的數據輸出而已
_SYSTEMD_UNIT=unit.service :只輸出 unit.service 的信息而已
_COMM=bash :只輸出與 bash 有關的信息
_PID=pid :只輸出 PID 號碼的信息
_UID=uid :只輸出 UID 為 uid 的信息
SYSLOG_FACILITY=[0-23] :使用 syslog.h 規范的服務相對序號來調用出正確的數據!
范例一:秀出目前系統中所有的 journal 日志數據
[root@study ~]# journalctl
-- Logs begin at Mon 2015-08-17 18:37:52 CST, end at Wed 2015-08-19 00:01:01 CST. --
Aug 17 18:37:52 study.centos.vbird systemd-journal[105]: Runtime journal is using 8.0M (max
142.4M, leaving 213.6M of free 1.3G, current limit 142.4M).
Aug 17 18:37:52 study.centos.vbird systemd-journal[105]: Runtime journal is using 8.0M (max
142.4M, leaving 213.6M of free 1.3G, current limit 142.4M).
Aug 17 18:37:52 study.centos.vbird kernel: Initializing cgroup subsys cpuset
Aug 17 18:37:52 study.centos.vbird kernel: Initializing cgroup subsys cpu
.....(中間省略).....
Aug 19 00:01:01 study.centos.vbird run-parts(/etc/cron.hourly)[19268]: finished 0anacron
Aug 19 00:01:01 study.centos.vbird run-parts(/etc/cron.hourly)[19270]: starting 0yum-hourly.cron
Aug 19 00:01:01 study.centos.vbird run-parts(/etc/cron.hourly)[19274]: finished 0yum-hourly.cron
# 從這次開機以來的所有數據都會顯示出來!通過 less 一頁頁翻動給管理員查閱!數據量相當大!
范例二:(1)僅顯示出 2015/08/18 整天以及(2)僅今天及(3)僅昨天的日志數據內容
[root@study ~]# journalctl --since "2015-08-18 00:00:00" --until "2015-08-19 00:00:00"
[root@study ~]# journalctl --since today
[root@study ~]# journalctl --since yesterday --until today
范例三:只找出 crond.service 的數據,同時只列出最新的 10 筆即可
[root@study ~]# journalctl _SYSTEMD_UNIT=crond.service -n 10
范例四:找出 su, login 執行的登錄文件,同時只列出最新的 10 筆即可
[root@study ~]# journalctl _COMM=su _COMM=login -n 10
范例五:找出訊息嚴重等級為錯誤 (error) 的訊息!
[root@study ~]# journalctl -p err
范例六:找出跟登錄服務 (auth, authpriv) 有關的登錄文件訊息
[root@study ~]# journalctl SYSLOG_FACILITY=4 SYSLOG_FACILITY=10
# 更多關于 syslog_facility 的數據,請參考 18.2.1 小節的內容啰!
```
基本上,有 journalctl 就真的可以搞定你的訊息數據啰!全部的數據都在這里面耶~再來假設一下,你想要了解到登錄文件的實時變化, 那又該如何處置呢?現在,請開兩個終端機,讓我們來處理處理!
```
# 第一號終端機,請使用下面的方式持續偵測系統!
[root@study ~]# journalctl -f
# 這時系統會好像卡住~其實不是卡住啦!是類似 tail -f 在持續的顯示登錄文件信息的!
# 第二號終端機,使用下面的方式隨便發一封 email 給系統上的帳號!
[root@study ~]# echo "testing" | mail -s 'tset' dmtsai
# 這時,你會發現到第一號終端機竟然一直輸出一些訊息吧!沒錯!這就對了!
```
如果你有一些必須要偵測的行為,可以使用這種方式來實時了解到系統出現的訊息~而取消 journalctl -f 的方法,就是 [crtl]+c 啊!
### 18.4.2 logger 指令的應用
上面談到的是叫出登錄文件給我們查閱,那換個角度想,“如果你想要讓你的數據儲存到登錄文件當中”呢?那該如何是好? 這時就得要使用 logger 這個好用的家伙了!這個家伙可以傳輸很多信息,不過,我們只使用最簡單的本機信息傳遞~ 更多的用法就請您自行 man logger 啰!
```
[root@study ~]# logger [-p 服務名稱.等級] "訊息"
選項與參數:
服務名稱.等級 :這個項目請參考 rsyslogd 的本章后續小節的介紹;
范例一:指定一下,讓 dmtsai 使用 logger 來傳送數據到登錄文件內
[root@study ~]# logger -p user.info "I will check logger command"
[root@study ~]# journalctl SYSLOG_FACILITY=1 -n 3
-- Logs begin at Mon 2015-08-17 18:37:52 CST, end at Wed 2015-08-19 18:03:17 CST. --
Aug 19 18:01:01 study.centos.vbird run-parts(/etc/cron.hourly)[29710]: starting 0yum-hourly.cron
Aug 19 18:01:01 study.centos.vbird run-parts(/etc/cron.hourly)[29714]: finished 0yum-hourly.cron
Aug 19 18:03:17 study.centos.vbird dmtsai[29753]: I will check logger command
```
現在,讓我們來瞧一瞧,如果我們之前寫的 backup.service 服務中,如果使用手動的方式來備份,亦即是使用 "/backups/backup.sh log" 來執行備份時, 那么就通過 logger 來記錄備份的開始與結束的時間!該如何是好呢?這樣作看看!
```
[root@study ~]# vim /backups/backup.sh
#!/bin/bash
if [ "${1}" == "log" ]; then
logger -p syslog.info "backup.sh is starting"
fi
source="/etc /home /root /var/lib /var/spool/{cron,at,mail}"
target="/backups/backup-system-$(date +%Y-%m-%d).tar.gz"
[ ! -d /backups ] && mkdir /backups
tar -zcvf ${target} ${source} &> /backups/backup.log
if [ "${1}" == "log" ]; then
logger -p syslog.info "backup.sh is finished"
fi
[root@study ~]# /backups/backup.sh log
[root@study ~]# journalctl SYSLOG_FACILITY=5 -n 3
Aug 19 18:09:37 study.centos.vbird dmtsai[29850]: backup.sh is starting
Aug 19 18:09:54 study.centos.vbird dmtsai[29855]: backup.sh is finished
```
通過這個玩意兒,我們也能夠將數據自行處置到登錄文件當中啰!
### 18.4.3 保存 journal 的方式
再強調一次,這個 systemd-journald.servicd 的訊息是不會放到下一次開機后的,所以,重新開機后,那之前的記錄通通會遺失。 雖然我們大概都有啟動 rsyslogd 這個服務來進行后續的登錄文件放置,不過如果你比較喜歡 journalctl 的存取方式,那么可以將這些數據儲存下來喔!
基本上,systemd-journald.service 的配置文件主要參考 /etc/systemd/journald.conf 的內容,詳細的參數你可以參考 man 5 journald.conf 的數據。 因為默認的情況下面,配置文件的內容應該已經符合我們的需求,所以這邊鳥哥就不再修改配置文件了。只是如果想要保存你的 journalctl 所讀取的登錄文件, 那么就得要創建一個 /var/log/journal 的目錄,并且處理一下該目錄的權限,那么未來重新啟動 systemd-journald.service 之后, 日志登錄文件就會主動的復制一份到 /var/log/journal 目錄下啰!
```
# 1\. 先處理所需要的目錄與相關權限設置
[root@study ~]# mkdir /var/log/journal
[root@study ~]# chown root:systemd-journal /var/log/journal
[root@study ~]# chmod 2775 /var/log/journal
# 2\. 重新啟動 systemd-journald 并且觀察備份的日志數據!
[root@study ~]# systemctl restart systemd-journald.service
[root@study ~]# ll /var/log/journal/
drwxr-sr-x. 2 root systemd-journal 27 Aug 20 02:37 309eb890d09f440681f596543d95ec7a
```
你得要注意的是,因為現在整個日志登錄文件的容量會持續長大,因此你最好還是觀察一下你系統能用的總容量喔!避免不小心文件系統的容量被灌爆! 此外,未來在 /run/log 下面就沒有相關的日志可以觀察了!因為移動到 /var/log/journal 下面來啰!
其實鳥哥是這樣想的,既然我們還有 rsyslog.service 以及 logrotate 的存在,因此這個 systemd-journald.service 產生的登錄文件, 個人建議最好還是放置到 /run/log 的內存當中,以加快存取的速度!而既然 rsyslog.service 可以存放我們的登錄文件, 似乎也沒有必要再保存一份 journal 登錄文件到系統當中就是了。單純的建議!如何處理,依照您的需求即可喔!
- 鳥哥的Linux私房菜:基礎學習篇 第四版
- 目錄及概述
- 第零章、計算機概論
- 0.1 電腦:輔助人腦的好工具
- 0.2 個人電腦架構與相關設備元件
- 0.3 數據表示方式
- 0.4 軟件程序運行
- 0.5 重點回顧
- 0.6 本章習題
- 0.7 參考資料與延伸閱讀
- 第一章、Linux是什么與如何學習
- 1.1 Linux是什么
- 1.2 Torvalds的Linux發展
- 1.3 Linux當前應用的角色
- 1.4 Linux 該如何學習
- 1.5 重點回顧
- 1.6 本章習題
- 1.7 參考資料與延伸閱讀
- 第二章、主機規劃與磁盤分區
- 2.1 Linux與硬件的搭配
- 2.2 磁盤分區
- 2.3 安裝Linux前的規劃
- 2.4 重點回顧
- 2.5 本章習題
- 2.6 參考資料與延伸閱讀
- 第三章、安裝 CentOS7.x
- 3.1 本練習機的規劃--尤其是分區參數
- 3.2 開始安裝CentOS 7
- 3.3 多重開機安裝流程與管理(Option)
- 3.4 重點回顧
- 3.5 本章習題
- 3.6 參考資料與延伸閱讀
- 第四章、首次登陸與線上求助
- 4.1 首次登陸系統
- 4.2 文字模式下指令的下達
- 4.3 Linux系統的線上求助man page與info page
- 4.4 超簡單文書編輯器: nano
- 4.5 正確的關機方法
- 4.6 重點回顧
- 4.7 本章習題
- 4.8 參考資料與延伸閱讀
- 第五章、Linux 的文件權限與目錄配置
- 5.1 使用者與群組
- 5.2 Linux 文件權限概念
- 5.3 Linux目錄配置
- 5.4 重點回顧
- 5.5 本章練習
- 5.6 參考資料與延伸閱讀
- 第六章、Linux 文件與目錄管理
- 6.1 目錄與路徑
- 6.2 文件與目錄管理
- 6.3 文件內容查閱
- 6.4 文件與目錄的默認權限與隱藏權限
- 6.5 指令與文件的搜尋
- 6.6 極重要的復習!權限與指令間的關系
- 6.7 重點回顧
- 6.8 本章習題:
- 6.9 參考資料與延伸閱讀
- 第七章、Linux 磁盤與文件系統管理
- 7.1 認識 Linux 文件系統
- 7.2 文件系統的簡單操作
- 7.3 磁盤的分區、格式化、檢驗與掛載
- 7.4 設置開機掛載
- 7.5 內存交換空間(swap)之創建
- 7.6 文件系統的特殊觀察與操作
- 7.7 重點回顧
- 7.8 本章習題 - 第一題一定要做
- 7.9 參考資料與延伸閱讀
- 第八章、文件與文件系統的壓縮,打包與備份
- 8.1 壓縮文件的用途與技術
- 8.2 Linux 系統常見的壓縮指令
- 8.3 打包指令: tar
- 8.4 XFS 文件系統的備份與還原
- 8.5 光盤寫入工具
- 8.6 其他常見的壓縮與備份工具
- 8.7 重點回顧
- 8.8 本章習題
- 8.9 參考資料與延伸閱讀
- 第九章、vim 程序編輯器
- 9.1 vi 與 vim
- 9.2 vi 的使用
- 9.3 vim 的額外功能
- 9.4 其他 vim 使用注意事項
- 9.5 重點回顧
- 9.6 本章練習
- 9.7 參考資料與延伸閱讀
- 第十章、認識與學習BASH
- 10.1 認識 BASH 這個 Shell
- 10.2 Shell 的變量功能
- 10.3 命令別名與歷史命令
- 10.4 Bash Shell 的操作環境:
- 10.5 數據流重導向
- 10.6 管線命令 (pipe)
- 10.7 重點回顧
- 10.8 本章習題
- 10.9 參考資料與延伸閱讀
- 第十一章、正則表達式與文件格式化處理
- 11.1 開始之前:什么是正則表達式
- 11.2 基礎正則表達式
- 11.3 延伸正則表達式
- 11.4 文件的格式化與相關處理
- 11.5 重點回顧
- 11.6 本章習題
- 11.7 參考資料與延伸閱讀
- 第十二章、學習 Shell Scripts
- 12.1 什么是 Shell scripts
- 12.2 簡單的 shell script 練習
- 12.3 善用判斷式
- 12.4 條件判斷式
- 12.5 循環 (loop)
- 12.6 shell script 的追蹤與 debug
- 12.7 重點回顧
- 12.8 本章習題
- 第十三章、Linux 帳號管理與 ACL 權限設置
- 13.1 Linux 的帳號與群組
- 13.2 帳號管理
- 13.3 主機的細部權限規劃:ACL 的使用
- 13.4 使用者身份切換
- 13.5 使用者的特殊 shell 與 PAM 模塊
- 13.6 Linux 主機上的使用者訊息傳遞
- 13.7 CentOS 7 環境下大量創建帳號的方法
- 13.8 重點回顧
- 13.9 本章習題
- 13.10 參考資料與延伸閱讀
- 第十四章、磁盤配額(Quota)與進階文件系統管理
- 14.1 磁盤配額 (Quota) 的應用與實作
- 14.2 軟件磁盤陣列 (Software RAID)
- 14.3 邏輯卷軸管理員 (Logical Volume Manager)
- 14.4 重點回顧
- 14.5 本章習題
- 14.6 參考資料與延伸閱讀
- 第十五章、例行性工作調度(crontab)
- 15.1 什么是例行性工作調度
- 15.2 僅執行一次的工作調度
- 15.3 循環執行的例行性工作調度
- 15.4 可喚醒停機期間的工作任務
- 15.5 重點回顧
- 15.6 本章習題
- 第十六章、程序管理與 SELinux 初探
- 16.1 什么是程序 (process)
- 16.2 工作管理 (job control)
- 16.3 程序管理
- 16.4 特殊文件與程序
- 16.5 SELinux 初探
- 16.6 重點回顧
- 16.7 本章習題
- 16.8 參考資料與延伸閱讀
- 第十七章、認識系統服務 (daemons)
- 17.1 什么是 daemon 與服務 (service)
- 17.2 通過 systemctl 管理服務
- 17.3 systemctl 針對 service 類型的配置文件
- 17.4 systemctl 針對 timer 的配置文件
- 17.5 CentOS 7.x 默認啟動的服務簡易說明
- 17.6 重點回顧
- 17.7 本章習題
- 17.8 參考資料與延伸閱讀
- 第十八章、認識與分析登錄文件
- 18.1 什么是登錄文件
- 18.2 rsyslog.service :記錄登錄文件的服務
- 18.3 登錄文件的輪替(logrotate)
- 18.4 systemd-journald.service 簡介
- 18.5 分析登錄文件
- 18.6 重點回顧
- 18.7 本章習題
- 18.8 參考資料與延伸閱讀
- 第十九章、開機流程、模塊管理與 Loader
- 19.1 Linux 的開機流程分析
- 19.2 核心與核心模塊
- 19.3 Boot Loader: Grub2
- 19.4 開機過程的問題解決
- 19.5 重點回顧
- 19.6 本章習題
- 19.7 參考資料與延伸閱讀
- 第二十章、基礎系統設置與備份策略
- 20.1 系統基本設置
- 20.2 服務器硬件數據的收集
- 20.3 備份要點
- 20.4 備份的種類、頻率與工具的選擇
- 20.5 鳥哥的備份策略
- 20.6 災難復原的考慮
- 20.7 重點回顧
- 20.8 本章習題
- 20.9 參考資料與延伸閱讀
- 第二十一章、軟件安裝:源代碼與 Tarball
- 20.1 開放源碼的軟件安裝與升級簡介
- 21.2 使用傳統程序語言進行編譯的簡單范例
- 21.3 用 make 進行宏編譯
- 21.4 Tarball 的管理與建議
- 21.5 函數庫管理
- 21.6 檢驗軟件正確性
- 21.7 重點回顧
- 21.8 本章習題
- 21.9 參考資料與延伸閱讀
- 第二十二章、軟件安裝 RPM, SRPM 與 YUM
- 22.1 軟件管理員簡介
- 22.2 RPM 軟件管理程序: rpm
- 22.3 YUM 線上升級機制
- 22.4 SRPM 的使用 : rpmbuild (Optional)
- 22.5 重點回顧
- 22.6 本章習題
- 22.7 參考資料與延伸閱讀
- 第二十三章、X Window 設置介紹
- 23.1 什么是 X Window System
- 23.2 X Server 配置文件解析與設置
- 23.3 顯卡驅動程序安裝范例
- 23.4 重點回顧
- 23.5 本章習題
- 23.6 參考資料與延伸閱讀
- 第二十四章、Linux 核心編譯與管理
- 24.1 編譯前的任務:認識核心與取得核心源代碼
- 24.2 核心編譯的前處理與核心功能選擇
- 24.3 核心的編譯與安裝
- 24.4 額外(單一)核心模塊編譯
- 24.5 以最新核心版本編譯 CentOS 7.x 的核心
- 24.6 重點回顧
- 24.7 本章習題
- 24.8 參考資料與延伸閱讀