1. 程式人生 > >systemd-analyze – 在Linux中查詢系統啟動效能統計資訊

systemd-analyze – 在Linux中查詢系統啟動效能統計資訊

您是否在使用 systemd 系統和服務管理器,並且您的 Linux 系統需要較長時間才能啟動,或者您希望檢視系統啟動效能的報告? 如果是的話,你已經登陸了正確的地方。

在本文中,我們將向您展示如何使用systemd-analyze來分析 Linux 系統啟動效能統計資訊, systemd是 systemd 中用於系統管理的眾多實用程式之一。

另請參閱 : 如何在遠端 Linux 伺服器上控制系統服務

要獲得系統啟動時間的概述,我們可以執行systemd-analyze命令而不帶任何引數,如下所示。 它將列出每個服務啟動需要多長時間的資訊,其中包括啟動時核心,initrd 和使用者空間佔用的時間。

  1. # systemd-analyze
  2. Startup finished in 884ms (kernel) + 3.861s (initrd) + 48.356s (userspace) = 53.102s

如果要檢視所有正在執行的單位的列表,按其初始化時間排序(最高時間位於最前面),blame 子命令用於此目的。 執行後面的命令後,使用[Enter]檢視列表中的更多服務,然後q退出。

  1. # systemd-analyze blame
找出每個單位的時間開始
  1. 16.159s mariadb.service
  2. 12.178s libvirtd.service
  3. 10.298s tuned.service
  4. 9.836s postfix.service
  5. 8.704s lsws.service
  6. 7.352s lscpd.service
  7. 4.988s [email protected]
  8. 4.779s NetworkManager-wait-online.service
  9. 4.577s lvm2-monitor.service
  10. 4.439s ModemManager.service
  11. 4.413s polkit.service
  12. 4.280s dev-sda1.device
  13. 4.225s systemd-udev-settle.service
  14. 3.957s firewalld.service
  15. 3.227s rhel-dmesg.service
  16. 3.221s abrt-ccpp.service
  17. 3.142s rsyslog.service
  18. 3.053s avahi-daemon.service
  19. 3.042s pure-ftpd.service
  20. 2.249s gssproxy.service
  21. 2.212s NetworkManager.service
  22. 1.889s proc-fs-nfsd.mount
  23. 1.780s systemd-tmpfiles-setup-dev.service
  24. 1.451s sshd.service
  25. 1.267s rhel-readonly.service
  26. 1.035s sysstat.service
  27. 1.001s rpc-statd-notify.service
  28. 910ms systemd-logind.service
  29. 739ms kdump.service
  30. 738ms network.service
  31. ...

從上面的輸出中可以看出,每臺裝置都是基於所花費的時間進行排序的,您可以簡單地找出哪些服務在啟動和分析問題時花費的時間較長。

接下來,我們還可以使用 critical-chain 子命令檢視預設目標或指定單元列表的時間關鍵鏈的樹,如圖所示。

  1. # systemd-analyze critical-chain
為預設目標列印時間關鍵鏈
  1. The time after the unit is active or started is printed after the "@" character.
  2. The time the unit takes to start is printed after the "+" character.
  3. multi-user.target @48.342s
  4. └─mariadb.service @31.560s +16.159s
  5. └─network.target @31.558s
  6. └─network.service @30.819s +738ms
  7. └─NetworkManager-wait-online.service @26.035s +4.779s
  8. └─NetworkManager.service @23.821s +2.212s
  9. └─network-pre.target @23.821s
  10. └─firewalld.service @19.863s +3.957s
  11. └─polkit.service @15.381s +4.413s
  12. └─basic.target @12.271s
  13. └─sockets.target @12.271s
  14. └─virtlockd.socket @12.270s
  15. └─sysinit.target @12.251s
  16. └─systemd-update-utmp.service @12.196s +54ms
  17. └─auditd.service @11.705s +486ms
  18. └─systemd-tmpfiles-setup.service @11.609s +93ms
  19. └─rhel-import-state.service @11.397s +211ms
  20. └─local-fs.target @11.363s
  21. └─run-user-0.mount @46.910s
  22. └─local-fs-pre.target @10.575s
  23. └─lvm2-monitor.service @5.996s +4.577s
  24. └─lvm2-lvmetad.service @7.376s
  25. └─lvm2-lvmetad.socket @5.987s
  26. └─-.slice
  1. # systemd-analyze critical-chain ntp.service networking.service

最後,讓我們看看一個更重要的子命令,它允許生成圖形(svg 格式)詳細的已啟動的系統服務,以及在什麼時候突出顯示它們的初始化時間,如下所示。

確保圖形顯示模式或 x-windows 已啟用以檢視繪圖。

  1. # systemd-analyze plot > boot_analysis.svg
  2. # xviewer boot_analysis.svg
Linux 啟動分析

 

Linux 啟動分析

以上所有命令都將列印本地機器的啟動效能統計資訊。 要通過ssh從遠端主機檢視資訊,請使用-H標誌並指定[email protected]指令,如圖所示。

  1. # systemd-analyze time -H [email protected]
  2. # systemd-analyze blame -H [email protected]
  3. # systemd-analyze critical-chain -H [email protected]

systemd-analysis也可用於從系統和 systemd(服務管理器)等中查詢其他狀態和跟蹤資訊。 有關更多資訊,請參閱其手冊頁。

  1. # man systemd-analyze

另請參閱 : 如何在 SystemD 中更改執行級別(目標)