亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何理解LINUX日志

發布時間:2021-10-22 11:03:43 來源:億速云 閱讀:157 作者:柒染 欄目:云計算

本篇文章給大家分享的是有關如何理解LINUX日志,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

每個使用UNIX/LINUX的人都知道日志的用處,那你是否清楚LINUX這些日志信息處理的來龍去脈呢~

本人通過近一個月來對源代碼的死纏爛打,終于有所體會!

我們可以看到LINUX系統信息日志的途徑基本有以下2種:

1>dmesg查看----這個命令比較常見

2>/var/log/下的文件

那下面我們就從這個2個途徑著手,一步步的走下去.

<一>

首先,我們來看dmesg這個常見的命令背后隱藏的是什么!!

1> 先讓我們來MAN一下這個家伙

----------------------------------------------man dmesg--------------------------------------------------

----------------------------------------------man dmesg--------------------------------------------------

NAME  
       dmesg - print or control the kernel ring buffer

SYNOPSIS  
       dmesg [ -c ] [ -n level ] [ -s bufsize ]

DESCRIPTION  
       dmesg  is  used  to  examine  or  control  the kernel ring  
       buffer.

       The program helps users to print  out  their  bootup  mes-  
       sages.   Instead of copying the messages by hand, the user  
       need only:  
              dmesg > boot.messages  
       and mail the boot.messages file to whoever can debug their  
       problem.

OPTIONS  
       -c     Clear the ring buffer contents after printing.

       -sbufsize  
              Use  a  buffer  of size bufsize to query the kernel  
              ring buffer.   This  is  16392  by  default.   (The  
              default  kernel  syslog  buffer  size  was  4096 at  
              first, 8192 since 1.3.54, 16384 since 2.1.113.)  If  
              you  have  set  the kernel buffer to be larger than  
              the default then this option can be  used  to  view  
              the entire buffer.

       -nlevel  
              Set  the level at which logging of messages is done  
              to the console.  For example,  -n  1  prevents  all  
              messages,  expect panic messages, from appearing on  
              the console.  All  levels  of  messages  are  still  
              written  to  /proc/kmsg, so syslogd(8) can still be  
              used  to  control  exactly  where  kernel  messages  
              appear.  When the -n option is used, dmesg will not  
              print or clear the kernel ring buffer.

              When both options are used, only the last option on  
              the command line will have an effect.  
 

從LINUX提供的手冊,我們可以得知一條最重要的信息   dmesg是從kernel 的ring buffer(環緩沖區)中讀取信息的.  

---------------------------------------------over man --------------------------------------------------

---------------------------------------------over man --------------------------------------------------

 2>  那什么是ring buffer呢?

       在LINUX中,所有的系統信息(包內核信息)都會傳送到ring buffer中.而內核產生的信息由printk()打印出來。系統啟動時所看到的信息都是由該函數打印到屏幕中。 printk()打出的信息往往以<0><2>...這的數字表明消息的重要級別。高于一定的優先級別會打印到屏幕上, 否則只會保留在系統的緩沖區中(ring buffer)。

       至于dmesg具體是如何從ring buffer中讀取的,大家可以看dmesg.c源代碼.很短,比較容易讀懂.

<二>

dmesg怎么搞的大家應該很明白了吧.至于/var/log/下的文件更是大家熟悉得不能再熟悉了!

1>  /var/log/..下為什么有這么多文件呢?

      一句話解釋: 是syslogd這個守護進程根據   /etc/syslog.conf,將不同的服務產生的Log記錄到不同的文件中.  

    這里的/etc/syslog.conf我就不細說了,很多這方面的信息(去查吧).  

2> 既然知道了,/var/log/..是由syslogd這個守護進程產生的.那就再順著這條線走下去.  

    LINUX系統啟動后,由/etc/init.d/sysklogd先后啟動klogd,syslogd兩個守護進程。  

    其中klogd會通過syslog()系統調用或者讀取proc文件系統來從系統緩沖區(ring buffer)中得到由內核printk()  

    發出的信息.而syslogd是通過klogd來讀取系統內核信息.  

我想至此,大家心理應該對log產生,讀取等一系列的動作有所感覺.(如果沒有,請檢查你的智商).  

為了還不明白的人:  

總結一下:   

1>  所有系統信息是輸出到ring buffer中去的.dmesg所顯示的內容也是從ring buffer中讀取的.  

2>  LINUX系統中/etc/init.d/sysklogd會啟動2個守護進程:Klogd&&Syslogd  

3>  klogd是負責讀取內核信息的,有2種方式:  

            syslog()系統調用(這個函數用法比較全,大家去MAN一下看看)  

            直接的對/proc/kmsg進行讀取(再這提一下,/proc/kmsg是專門輸出內核信息的地方)  

4>   Klogd的輸出結果會傳送給syslogd進行處理,syslogd會根據/etc/syslog.conf的配置把log  

      信息輸出到/var/log/下的不同文件中.  

redhat linux知識庫

以上就是如何理解LINUX日志,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

阳山县| 定南县| 班玛县| 慈利县| 聂拉木县| 泸定县| 梨树县| 双鸭山市| 西乌珠穆沁旗| 青冈县| 仲巴县| 肃宁县| 钟山县| 梓潼县| 出国| 沂水县| 资中县| 定州市| 晋江市| 漯河市| 华蓥市| 日土县| 丹凤县| 房产| 永和县| 余干县| 新化县| 渝中区| 微博| 莎车县| 邵阳市| 治县。| 五河县| 辉县市| 土默特右旗| 东港市| 南宫市| 云阳县| 普兰店市| 绥江县| 溧阳市|