一、/var目錄
成都創(chuàng)新互聯(lián)公司是一家專注于成都網(wǎng)站設計、網(wǎng)站建設與策劃設計,肥西網(wǎng)站建設哪家好?成都創(chuàng)新互聯(lián)公司做網(wǎng)站,專注于網(wǎng)站建設十多年,網(wǎng)設計領域的專業(yè)建站公司;建站業(yè)務涵蓋:肥西等地區(qū)。肥西做網(wǎng)站價格咨詢:13518219792
/var 所有服務的登錄的文件或錯誤信息文件(LOG FILES)都在/var/log下,此外,一些數(shù)據(jù)庫如MySQL則在/var/lib下,還有,用戶未讀的郵件的默認存放地點為/var/spool/mail
二、:/var/log/
系統(tǒng)的引導日志:/var/log/boot.log
例如:Feb 26 10:40:48 sendmial : sendmail startup succeeded
就是郵件服務啟動成功!
系統(tǒng)日志一般都存在/var/log下
常用的系統(tǒng)日志如下:
核心啟動日志:/var/log/dmesg
系統(tǒng)報錯日志:/var/log/messages
郵件系統(tǒng)日志:/var/log/maillog
FTP系統(tǒng)日志:/var/log/xferlog
安全信息和系統(tǒng)登錄與網(wǎng)絡連接的信息:/var/log/secure
登錄記錄:/var/log/wtmp 記錄登錄者訊錄,二進制文件,須用last來讀取內(nèi)容 who -u /var/log/wtmp 查看信息
News日志:/var/log/spooler
RPM軟件包:/var/log/rpmpkgs
XFree86日志:/var/log/XFree86.0.log
引導日志:/var/log/boot.log 記錄開機啟動訊息,dmesg | more
cron(定制任務日志)日志:/var/log/cron
安全信息和系統(tǒng)登錄與網(wǎng)絡連接的信息:/var/log/secure
文件 /var/run/utmp 記錄著現(xiàn)在登入的用戶。
文件 /var/log/wtmp 記錄所有的登入和登出。
文件 /var/log/lastlog 記錄每個用戶最後的登入信息。
文件 /var/log/btmp 記錄錯誤的登入嘗試。
less /var/log/auth.log 需要身份確認的操作
三、部分命令詳解
/var/log/messages
messages 日志是核心系統(tǒng)日志文件。它包含了系統(tǒng)啟動時的引導消息,以及系統(tǒng)運行時的其他狀態(tài)消息。IO 錯誤、網(wǎng)絡錯誤和其他系統(tǒng)錯誤都會記錄到這個文件中。其他信息,比如某個人的身份切換為 root,也在這里列出。如果服務正在運行,比如 DHCP 服務器,您可以在 messages 文件中觀察它的活動。通常,/var/log/messages 是您在做故障診斷時首先要查看的文件。
/var/log/XFree86.0.log
這個日志記錄的是 Xfree86 Xwindows 服務器最后一次執(zhí)行的結果。如果您在啟動到圖形模式時遇到了問題,一般情況從這個文件中會找到失敗的原因。
成 功地管理任何系統(tǒng)的關鍵之一,是要知道系統(tǒng)中正在發(fā)生什么事。Linux 中提供了異常日志,并且日志的細節(jié)是可配置的。Linux 日志都以明文形式存儲,所以用戶不需要特殊的工具就可以搜索和閱讀它們。還可以編寫腳本,來掃描這些日志,并基于它們的內(nèi)容去自動執(zhí)行某些功能。 Linux 日志存儲在 /var/log 目錄中。這里有幾個由系統(tǒng)維護的日志文件,但其他服務和程序也可能會把它們的日志放在這里。大多數(shù)日志只有root賬戶才可以讀,不過修改文件的訪問權限 就可以讓其他人可讀。
日志文件分類
/var/log/boot.log
該文件記錄了系統(tǒng)在引導過程中發(fā)生的事件,就是Linux系統(tǒng)開機自檢過程顯示的信息。
/var/log/cron
該 日志文件記錄crontab守護進程crond所派生的子進程的動作,前面加上用 戶、登錄時間和PID,以及派生出的進程的動作。CMD的一個動作是cron派生出一個調(diào)度進程的常見情況。REPLACE(替換)動作記錄用戶對它的 cron文件的更新,該文件列出了要周期性執(zhí)行的任務調(diào)度。 RELOAD動作在REPLACE動作后不久發(fā)生,這意味著cron注意到一個用戶的cron文件被更新而cron需要把它重新裝入內(nèi)存。該文件可能會查 到一些反常的情況。
/var/log/maillog
該日志文件記錄了每一個發(fā)送到系統(tǒng)或從系統(tǒng)發(fā)出的電子郵件的活動。它可以用來查看用戶使用哪個系統(tǒng)發(fā)送工具或把數(shù)據(jù)發(fā)送到哪個系統(tǒng)。下面是該日志文件的片段:
Sep 4 17:23:52 UNIX sendmail[1950]: g849Npp01950: from=root, size=25,
class=0, nrcpts=1,
msgid=200209040923.g849Npp01950@redhat.pfcc.com.cn,
relay=root@localhost
Sep 4 17:23:55 UNIX sendmail[1950]: g849Npp01950: to=lzy@fcceec.net,
ctladdr=root (0/0), delay=00:00:04, xdelay=00:00:03, mailer=esmtp, pri=30025,
relay=fcceec.net. [10.152.8.2], dsn=2.0.0, stat=Sent (Message queued)
/var/log/messages
該日志文件是許多進程日志文件的匯總,從該文件可以看出任何入侵企圖或成功的入侵。如以下幾行:
Sep 3 08:30:17 UNIX login[1275]: FAILED LOGIN 2 FROM (null) FOR suying,
Authentication failure
Sep 4 17:40:28 UNIX -- suying[2017]: LOGIN ON pts/1 BY suying FROM
fcceec.
Sep 4 17:40:39 UNIX su(pam_unix)[2048]: session opened for user root by suying(uid=999)
該 文件的格式是每一行包含日期、主機名、程序名,后面是包含PID或內(nèi)核標識的方括 號、一個冒號和一個空格,最后是消息。該文件有一個不足,就是被記錄的入侵企圖和成功的入侵事件,被淹沒在大量的正常進程的記錄中。但該文件可以由 /etc/syslog文件進行定制。由 /etc/syslog.conf配置文件決定系統(tǒng)如何寫入/var/messages。有關如何配置/etc/syslog.conf文件決定系統(tǒng)日志 記錄的行為,將在后面詳細敘述。
/var/log/syslog
默 認RedHat Linux不生成該日志文件,但可以配置/etc/syslog.conf讓系統(tǒng)生成該日志文件。它和/etc/log/messages日志文件不同, 它只記錄警告信息,常常是系統(tǒng)出問題的信息,所以更應該關注該文件。要讓系統(tǒng)生成該日志文件,在/etc/syslog.conf文件中加上: *.warning /var/log/syslog 該日志文件能記錄當用戶登錄時login記錄下的錯誤口令、Sendmail的問題、su命令執(zhí)行失敗等信息。下面是一條記錄:
Sep 6 16:47:52 UNIX login(pam_unix)[2384]: check pass; user unknown
/var/log/secure
該日志文件記錄與安全相關的信息。該日志文件的部分內(nèi)容如下:
Sep 4 16:05:09 UNIX xinetd[711]: START: ftp pid=1815 from=127.0.0.1
Sep 4 16:05:09 UNIX xinetd[1815]: USERID: ftp OTHER :root
Sep 4 16:07:24 UNIX xinetd[711]: EXIT: ftp pid=1815 duration=135(sec)
Sep 4 16:10:05 UNIX xinetd[711]: START: ftp pid=1846 from=127.0.0.1
Sep 4 16:10:05 UNIX xinetd[1846]: USERID: ftp OTHER :root
Sep 4 16:16:26 UNIX xinetd[711]: EXIT: ftp pid=1846 duration=381(sec)
Sep 4 17:40:20 UNIX xinetd[711]: START: telnet pid=2016 from=10.152.8.2
/var/log/lastlog
該 日志文件記錄最近成功登錄的事件和最后一次不成功的登錄事件,由login生成。 在每次用戶登錄時被查詢,該文件是二進制文件,需要使用 lastlog命令查看,根據(jù)UID排序顯示登錄名、端口號和上次登錄時間。如果某用戶從來沒有登錄過,就顯示為"**Never logged in**"。該命令只能以root權限執(zhí)行。簡單地輸入lastlog命令后就會看到類似如下的信息:
Username Port From Latest
root tty2 Tue Sep 3 08:32:27 +0800 2002
bin **Never logged in**
daemon **Never logged in**
adm **Never logged in**
lp **Never logged in**
sync **Never logged in**
shutdown **Never logged in**
halt **Never logged in**
mail **Never logged in**
news **Never logged in**
uucp **Never logged in**
operator **Never logged in**
games **Never logged in**
gopher **Never logged in**
ftp ftp UNIX Tue Sep 3 14:49:04 +0800 2002
nobody **Never logged in**
nscd **Never logged in**
mailnull **Never logged in**
ident **Never logged in**
rpc **Never logged in**
rpcuser **Never logged in**
xfs **Never logged in**
gdm **Never logged in**
postgres **Never logged in**
apache **Never logged in**
lzy tty2 Mon Jul 15 08:50:37 +0800 2002
suying tty2 Tue Sep 3 08:31:17 +0800 2002
系統(tǒng)賬戶諸如bin、daemon、adm、uucp、mail等決不應該登錄,如果發(fā)現(xiàn)這些賬戶已經(jīng)登錄,就說明系統(tǒng)可能已經(jīng)被入侵了。若發(fā)現(xiàn)記錄的時間不是用戶上次登錄的時間,則說明該用戶的賬戶已經(jīng)泄密了。
/var/log/wtmp
該 日志文件永久記錄每個用戶登錄、注銷及系統(tǒng)的啟動、停機的事件。因此隨著系統(tǒng)正常 運行時間的增加,該文件的大小也會越來越大,增加的速度取決于系統(tǒng)用戶登錄的次數(shù)。該日志文件可以用來查看用戶的登錄記錄,last命令就通過訪問這個文 件獲得這些信息,并以反序從后向前顯示用戶的登錄記錄,last也能根據(jù)用戶、終端 tty或時間顯示相應的記錄。
命令last有兩個可選參數(shù):
last -u 用戶名 顯示用戶上次登錄的情況。
last -t 天數(shù) 顯示指定天數(shù)之前的用戶登錄情況。
/var/run/utmp
該 日志文件記錄有關當前登錄的每個用戶的信息。因此這個文件會隨著用戶登錄和注銷系 統(tǒng)而不斷變化,它只保留當時聯(lián)機的用戶記錄,不會為用戶保留永久的記錄。系統(tǒng)中需要查詢當前用戶狀態(tài)的程序,如 who、w、users、finger等就需要訪問這個文件。該日志文件并不能包括所有精確的信息,因為某些突發(fā)錯誤會終止用戶登錄會話,而系統(tǒng)沒有及時 更新 utmp記錄,因此該日志文件的記錄不是百分之百值得信賴的。
以 上提及的3個文件(/var/log/wtmp、/var/run/utmp、 /var/log/lastlog)是日志子系統(tǒng)的關鍵文件,都記錄了用戶登錄的情況。這些文件的所有記錄都包含了時間戳。這些文件是按二進制保存的,故 不能用less、cat之類的命令直接查看這些文件,而是需要使用相關命令通過這些文件而查看。其中,utmp和wtmp文件的數(shù)據(jù)結構是一樣的,而 lastlog文件則使用另外的數(shù)據(jù)結構,關于它們的具體的數(shù)據(jù)結構可以使用man命令查詢。
每 次有一個用戶登錄時,login程序在文件lastlog中查看用戶的UID。如果存在,則把用戶上次登錄、注銷時間和主機名寫到標準輸出中,然后 login程序在lastlog中記錄新的登錄時間,打開utmp文件并插入用戶的utmp記錄。該記錄一直用到用戶登錄退出時刪除。utmp文件被各種 命令使用,包括who、w、users和finger。
下一步,login程序打開文件wtmp附加用戶的utmp記錄。當用戶登錄退出時,具有更新時間戳的同一utmp記錄附加到文件中。wtmp文件被程序last使用。
/var/log/xferlog
該日志文件記錄FTP會話,可以顯示出用戶向FTP服務器或從服務器拷貝了什么文件。該文件會顯示用戶拷貝到服務器上的用來入侵服務器的惡意程序,以及該用戶拷貝了哪些文件供他使用。
該 文件的格式為:第一個域是日期和時間,第二個域是下載文件所花費的秒數(shù)、遠程系統(tǒng) 名稱、文件大小、本地路徑名、傳輸類型(a:ASCII,b:二進制)、與壓縮相關的標志或tar,或"_"(如果沒有壓縮的話)、傳輸方向(相對于服務 器而言:i代表進,o代表出)、訪問模式(a:匿名,g:輸入口令,r:真實用戶)、用戶名、服務名(通常是ftp)、認證方法(l:RFC931,或 0),認證用戶的ID或"*"。下面是該文件的一條記錄:
Wed Sep 4 08:14:03 2002 1 UNIX 275531
/var/ftp/lib/libnss_files-2.2.2.so b _ o a -root@UNIX ftp 0 * c
/var/log/kernlog
RedHat Linux默認沒有記錄該日志文件。要啟用該日志文件,必須在/etc/syslog.conf文件中添加一行:kern.* /var/log/kernlog 。這樣就啟用了向/var/log/kernlog文件中記錄所有內(nèi)核消息的功能。該文件記錄了系統(tǒng)啟動時加載設備或使用設備的情況。一般是正常的操作, 但如果記錄了沒有授權的用戶進行的這些操作,就要注意,因為有可能這就是惡意用戶的行為。下面是該文件的部分內(nèi)容:
Sep 5 09:38:42 UNIX kernel: NET4: Linux TCP/IP 1.0 for NET4.0
Sep 5 09:38:42 UNIX kernel: IP Protocols: ICMP, UDP, TCP, IGMP
Sep 5 09:38:42 UNIX kernel: IP: routing cache hash table of 512 buckets, 4Kbytes
Sep 5 09:38:43 UNIX kernel: TCP: Hash tables configured (established 4096 bind 4096)
Sep 5 09:38:43 UNIX kernel: Linux IP multicast router 0.06 plus PIM-SM
Sep 5 09:38:43 UNIX kernel: NET4: Unix domain sockets 1.0/SMP for Linux NET4.0.
Sep 5 09:38:44 UNIX kernel: EXT2-fs warning: checktime reached, running e2fsck is recommended
Sep 5 09:38:44 UNIX kernel: VFS: Mounted root (ext2 filesystem).
Sep 5 09:38:44 UNIX kernel: SCSI subsystem driver Revision: 1.00
/var/log/Xfree86.x.log
該 日志文件記錄了X-Window啟動的情況。另外,除了/var/log/外,惡 意用戶也可能在別的地方留下痕跡,應該注意以下幾個地方:root 和其他賬戶的shell歷史文件;用戶的各種郵箱,如.sent、mbox,以及存放在/var/spool/mail/ 和 /var/spool/mqueue中的郵箱;臨時文件/tmp、/usr/tmp、/var/tmp;隱藏的目錄;其他惡意用戶創(chuàng)建的文件,通常是以 "."開頭的具有隱藏屬性的文件等。
四、具體命令
wtmp和utmp文件都是二進制文件,它們不能被諸如tail之類的命令剪貼或合并(使用cat命令)。用戶需要使用who、w、users、last和ac等命令來使用這兩個文件包含的信息。
who命令
who命令查詢utmp文件并報告當前登錄的每個用戶。who的默認輸出包括用戶名、終端類型、登錄日期及遠程主機。例如,鍵入who命令,然后按回車鍵,將顯示如下內(nèi)容:
chyang pts/0 Aug 18 15:06
ynguo pts/2 Aug 18 15:32
ynguo pts/3 Aug 18 13:55
lewis pts/4 Aug 18 13:35
ynguo pts/7 Aug 18 14:12
ylou pts/8 Aug 18 14:15
如果指明了wtmp文件名,則who命令查詢所有以前的記錄。命令who /var/log/wtmp將報告自從wtmp文件創(chuàng)建或刪改以來的每一次登錄。
w命令
w命令查詢utmp文件并顯示當前系統(tǒng)中每個用戶和它所運行的進程信息。例如,鍵入w命令,然后按回車鍵,將顯示如下內(nèi)容:
3:36pm up 1 day, 22:34, 6 users, load average: 0.23, 0.29, 0.27
USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT
chyang pts/0 202.38.68.242 3:06pm 2:04 0.08s 0.04s -bash
ynguo pts/2 202.38.79.47 3:32pm 0.00s 0.14s 0.05 w
lewis pts/3 202.38.64.233 1:55pm 30:39 0.27s 0.22s -bash
lewis pts/4 202.38.64.233 1:35pm 6.00s 4.03s 0.01s sh /home/users/
ynguo pts/7 simba.nic.ustc.e 2:12pm 0.00s 0.47s 0.24s telnet mail
ylou pts/8 202.38.64.235 2:15pm 1:09m 0.10s 0.04s -bash
users命令
users命令用單獨的一行打印出當前登錄的用戶,每個顯示的用戶名對應一個登錄會話。如果一個用戶有不止一個登錄會話,那他的用戶名將顯示相同的次數(shù)。例如,鍵入users命令,然后按回車鍵,將顯示如下內(nèi)容:
chyang lewis lewis ylou ynguo ynguo
last命令
last命令往回搜索wtmp來顯示自從文件第一次創(chuàng)建以來登錄過的用戶。例如:
chyang pts/9 202.38.68.242 Tue Aug 1 08:34 - 11:23 (02:49)
cfan pts/6 202.38.64.224 Tue Aug 1 08:33 - 08:48 (00:14)
chyang pts/4 202.38.68.242 Tue Aug 1 08:32 - 12:13 (03:40)
lewis pts/3 202.38.64.233 Tue Aug 1 08:06 - 11:09 (03:03)
lewis pts/2 202.38.64.233 Tue Aug 1 07:56 - 11:09 (03:12)
如果指明了用戶,那么last只報告該用戶的近期活動,例如,鍵入last ynguo命令,然后按回車鍵,將顯示如下內(nèi)容:
ynguo pts/4 simba.nic.ustc.e Fri Aug 4 16:50 - 08:20 (15:30)
ynguo pts/4 simba.nic.ustc.e Thu Aug 3 23:55 - 04:40 (04:44)
ynguo pts/11 simba.nic.ustc.e Thu Aug 3 20:45 - 22:02 (01:16)
ynguo pts/0 simba.nic.ustc.e Thu Aug 3 03:17 - 05:42 (02:25)
ynguo pts/0 simba.nic.ustc.e Wed Aug 2 01:04 - 03:16 1+02:12)
ynguo pts/0 simba.nic.ustc.e Wed Aug 2 00:43 - 00:54 (00:11)
ynguo pts/9 simba.nic.ustc.e Thu Aug 1 20:30 - 21:26 (00:55)
ac命令
ac命令根據(jù)當前的/var/log/wtmp文件中的登錄進入和退出來報告用戶連接的時間(小時),如果不使用標志,則報告總的時間。例如,鍵入ac命令,然后按回車鍵,將顯示如下內(nèi)容:
total 5177.47
鍵入ac -d命令,然后按回車鍵,將顯示每天的總的連接時間:
Aug 12 total 261.87
Aug 13 total 351.39
Aug 14 total 396.09
Aug 15 total 462.63
Aug 16 total 270.45
Aug 17 total 104.29
Today total 179.02
鍵入ac -p命令,然后按回車鍵,將顯示每個用戶的總的連接時間:
ynguo 193.23
yucao 3.35
rong 133.40
hdai 10.52
zjzhu 52.87
zqzhou 13.14
liangliu 24.34
total 5178.24
lastlog命令
lastlog 文件在每次有用戶登錄時被查詢。可以使用lastlog命令檢查某特 定用戶上次登錄的時間,并格式化輸出上次登錄日志 /var/log/lastlog的內(nèi)容。它根據(jù)UID排序顯示登錄名、端口號(tty)和上次登錄時間。如果一個用戶從未登錄過,lastlog顯示 **Never logged**。注意需要以root身份運行該命令,例如:
rong 5 202.38.64.187 Fri Aug 18 15:57:01 +0800 2000
dbb **Never logged in**
xinchen **Never logged in**
pb9511 **Never logged in**
xchen 0 202.38.64.190 Sun Aug 13 10:01:22 +0800 2000
另外,可加一些參數(shù),例如,"last -u 102"命令將報告UID為102的用戶;"last -t 7"命令表示限制為上一周的報告。
五、進程統(tǒng)計
UNIX 可以跟蹤每個用戶運行的每條命令,如果想知道昨晚弄亂了哪些重要的文件,進 程統(tǒng)計子系統(tǒng)可以告訴你。它還對跟蹤一個侵入者有幫助。與連接時間日志不同,進程統(tǒng)計子系統(tǒng)默認不激活,它必須啟動。在Linux系統(tǒng)中啟動進程統(tǒng)計使用 accton命令,必須用root身份來運行。
accton命令的形式為:accton file,file必須事先存在。
先使用touch命令創(chuàng)建pacct文件:touch /var/log/pacct,然后運行accton:accton /var/log/pacct。一旦accton被激活,就可以使用lastcomm命令監(jiān)測系統(tǒng)中任何時候執(zhí)行的命令。若要關閉統(tǒng)計,可以使用不帶任何 參數(shù)的accton命令。
lastcomm命令報告以前執(zhí)行的文件。不帶參數(shù)時,lastcomm命令顯示當前統(tǒng)計文件生命周期內(nèi)記錄的所有命令的有關信息。包括命令名、用戶、tty、命令花費的CPU時間和一個時間戳。如果系統(tǒng)有許多用戶,輸入則可能很長??聪旅娴睦樱?/p>
crond F root ?? 0.00 secs Sun Aug 20 00:16
promisc_check.s S root ?? 0.04 secs Sun Aug 20 00:16
promisc_check root ?? 0.01 secs Sun Aug 20 00:16
grep root ?? 0.02 secs Sun Aug 20 00:16
tail root ?? 0.01 secs Sun Aug 20 00:16
sh root ?? 0.01 secs Sun Aug 20 00:15
ping S root ?? 0.01 secs Sun Aug 20 00:15
ping6.pl F root ?? 0.01 secs Sun Aug 20 00:15
sh root ?? 0.01 secs Sun Aug 20 00:15
ping S root ?? 0.02 secs Sun Aug 20 00:15
ping6.pl F root ?? 0.02 secs Sun Aug 20 00:15
sh root ?? 0.02 secs Sun Aug 20 00:15
ping S root ?? 0.00 secs Sun Aug 20 00:15
ping6.pl F root ?? 0.01 secs Sun Aug 20 00:15
sh root ?? 0.01 secs Sun Aug 20 00:15
ping S root ?? 0.01 secs Sun Aug 20 00:15
sh root ?? 0.02 secs Sun Aug 20 00:15
ping S root ?? 1.34 secs Sun Aug 20 00:15
locate root ttyp0 1.34 secs Sun Aug 20 00:15
accton S root ttyp0 0.00 secs Sun Aug 20 00:15
進程統(tǒng)計的一個問題是pacct文件可能增長得十分迅速。這時需要交互式地或經(jīng)過 cron機制運行sa命令來保證日志數(shù)據(jù)在系統(tǒng)控制內(nèi)。sa命令報告、清理并維護進程統(tǒng)計文件。它能把/var/log/pacct中的信息壓縮到摘要文 件/var/log/savacct和 /var/log/usracct中。這些摘要包含按命令名和用戶名分類的系統(tǒng)統(tǒng)計數(shù)據(jù)。在默認情況下sa先讀它們,然后讀pacct文件,使報告能包含 所有的可用信息。sa的輸出有下面一些標記項。
/var/log目錄下的20個Linux日志文件功能詳解 :
如果愿意在Linux環(huán)境方面花費些時間,首先就應該知道日志文件的所在位置以及它們包含的內(nèi)容。在系統(tǒng)運行正常的情況下學習了解這些不同的日志文件有助于你在遇到緊急情況時從容找出問題并加以解決。
以下介紹的是20個位于/var/log/ 目錄之下的日志文件。其中一些只有特定版本采用,如dpkg.log只能在基于Debian的系統(tǒng)中看到。
/var/log/messages — 包括整體系統(tǒng)信息,其中也包含系統(tǒng)啟動期間的日志。此外,mail,cron,daemon,kern和auth等內(nèi)容也記錄在var/log/messages日志中。
/var/log/dmesg — 包含內(nèi)核緩沖信息(kernel ring buffer)。在系統(tǒng)啟動時,會在屏幕上顯示許多與硬件有關的信息??梢杂胐mesg查看它們。
/var/log/auth.log — 包含系統(tǒng)授權信息,包括用戶登錄和使用的權限機制等。
/var/log/boot.log — 包含系統(tǒng)啟動時的日志。
/var/log/daemon.log — 包含各種系統(tǒng)后臺守護進程日志信息。
/var/log/dpkg.log – 包括安裝或dpkg命令清除軟件包的日志。
/var/log/kern.log – 包含內(nèi)核產(chǎn)生的日志,有助于在定制內(nèi)核時解決問題。
/var/log/lastlog — 記錄所有用戶的最近信息。這不是一個ASCII文件,因此需要用lastlog命令查看內(nèi)容。
/var/log/maillog /var/log/mail.log — 包含來著系統(tǒng)運行電子郵件服務器的日志信息。例如,sendmail日志信息就全部送到這個文件中。
/var/log/user.log — 記錄所有等級用戶信息的日志。
/var/log/Xorg.x.log — 來自X的日志信息。
/var/log/alternatives.log – 更新替代信息都記錄在這個文件中。
/var/log/btmp – 記錄所有失敗登錄信息。使用last命令可以查看btmp文件。例如,”last -f /var/log/btmp | more“。
/var/log/cups — 涉及所有打印信息的日志。
/var/log/anaconda.log — 在安裝Linux時,所有安裝信息都儲存在這個文件中。
/var/log/yum.log — 包含使用yum安裝的軟件包信息。
/var/log/cron — 每當cron進程開始一個工作時,就會將相關信息記錄在這個文件中。
/var/log/secure — 包含驗證和授權方面信息。例如,sshd會將所有信息記錄(其中包括失敗登錄)在這里。
/var/log/wtmp或/var/log/utmp — 包含登錄信息。使用wtmp可以找出誰正在登陸進入系統(tǒng),誰使用命令顯示這個文件或信息等。
/var/log/faillog – 包含用戶登錄失敗信息。此外,錯誤登錄命令也會記錄在本文件中。
除了上述Log文件以外, /var/log還基于系統(tǒng)的具體應用包含以下一些子目錄:
/var/log/httpd/或/var/log/apache2 — 包含服務器access_log和error_log信息。
/var/log/lighttpd/ — 包含light HTTPD的access_log和error_log。
/var/log/mail/ – 這個子目錄包含郵件服務器的額外日志。
/var/log/prelink/ — 包含.so文件被prelink修改的信息。
/var/log/audit/ — 包含被 Linux audit daemon儲存的信息。
/var/log/samba/ – 包含由samba存儲的信息。
/var/log/sa/ — 包含每日由sysstat軟件包收集的sar文件。
/var/log/sssd/ – 用于守護進程安全服務。
除了手動存檔和清除這些日志文件以外,還可以使用logrotate在文件達到一定大小后自動刪除??梢試L試用vi,tail,grep和less等命令查看這些日志文件。
ls是Linux下最常用的指令之一,也是一條非常古老的命令,它最早可追述到Unix系統(tǒng),甚至更古老的Multics下相同的命令。
計算機一直是一個很復雜的機器,其中的硬件是由許許多多繁瑣的操作系統(tǒng)來控制,其中就包括了Linux操作系統(tǒng),接下來就和我一起來認識一下Linux操作系統(tǒng)中的“l(fā)s”吧。
詳細內(nèi)容
01
一般情況下,ls命令將每個由Directory參數(shù)指定的目錄或者每個由File參數(shù)指定的名稱寫到標準輸出,以及所要求的和標志一起的其它信息,如果不指定File或Directory參數(shù),ls命令顯示當前目錄的內(nèi)容。
02
Linux是一款免費的操作系統(tǒng),是一個性能穩(wěn)定的多用戶網(wǎng)絡操作系統(tǒng),用戶可以通過網(wǎng)絡或其他途徑免費獲得,并可以任意修改其源代碼,是一種開源電腦操作系統(tǒng)內(nèi)核,是一個用C語言寫成,符合POSIX標準的類Unix操作系統(tǒng)。
03
但人們也已經(jīng)習慣了用Linux來形容整個基于Linux內(nèi)核,并且使用GNU工程各種工具和數(shù)據(jù)庫的操作系統(tǒng)。
04
Linux操作系統(tǒng)誕生于1991年10月5日(這是第一次正式向外公布時間),Linux存在著許多不同的Linux版本,但它們都使用了Linux內(nèi)核。
05
Linux可安裝在各種計算機硬件設備中,比如手機、平板電腦、路由器、視頻游戲控制臺、臺式計算機、大型機和超級計算機。
前言
有的時候,我們要通過對系統(tǒng)的cpu負載等性能數(shù)值的查看,來判排查系統(tǒng)產(chǎn)生某種故障(經(jīng)常死機或者運行速度突然變慢)的原因。但是,簡單的top,uptime,w等命令只可以查看當前的負載,而無法查看過去的某一時間段的cpu的負載情況。
下面就介紹一個用于性能分析的命令,其可以用于查看過去的某一時間段的cpu的負載情況(系統(tǒng)性能)。
查看某一時間段的cpu使用情況,請直接跳到第七節(jié)。
一、sar概念
sysstat是Linux 系統(tǒng)中的常用工具包,而sar 是 Linux中sysstat工具包中的用于監(jiān)控Linux系統(tǒng)性能的工具之一。
sysstat 工具包中包含兩種類型的工具:即時查看工具(iostat、mpstat、sar);累計統(tǒng)計工具(sar)
因此sar命令,又叫做系統(tǒng)活動情況報告。不僅可以實時查看服務器的性能,還可以做累計統(tǒng)計。
二、sar可監(jiān)控的范圍
文件的讀寫情況
系統(tǒng)調(diào)用的使用情況
磁盤I/O使用情況
CPU的使用統(tǒng)計
內(nèi)存使用狀況
進程活動
IPC有關的活動
三、sar命令使用環(huán)境
sar命令使用格式:
sar+ 命令行選項(可選) + 間隔時間(可選) + 次數(shù)(可選)
常用來判斷一個系統(tǒng)瓶頸問題
查詢CPU可用 sar -u 和 sar -q 等來查看查詢內(nèi)存可用 sar -B、sar -r 和 sar -W 等來查看查詢io可用 sar -b、sar -u 和 sar -d 等來查看
四、sar命令累計統(tǒng)計的實現(xiàn)過程
系統(tǒng)會通過調(diào)用 /usr/lib64/sa/ 中的三個工具(sa1 sa2 sadc)來實現(xiàn),周期地記錄當時的系統(tǒng)性能的信息的功能。
sa1 :收集并將每天的系統(tǒng)性能的信息寫入一個二進制的文件中,它是sadc的前端程序
sa2 :收集每天的系統(tǒng)活躍的信息并寫入總結性的文件中,其作為 sar的前端程序
sadc :收集系統(tǒng)的動態(tài)數(shù)據(jù)的數(shù)據(jù)并寫入一個二進制的文件中,其作為 sar 工具的后端
五、sar的日志
sar是由有類似日志切割的功能的,它會依據(jù)/etc/cron.d/sysstat中的計劃任務,將日志放入/var/log/sa/中
注:日志為二進制文件,不可使用more、less、vim工具查看,必須使用sar或sadf
可以根據(jù)需求修改該計劃任務
如要查看某一時間段的服務器的性能的其中一個方法就是:使用sar命令,查看當天的日志文件
sar -f /var/log/sa/sa15
[root@? ? lib64]#sar-f/var/log/sa/sa15Linux3.10.0-327.el7.x86_64(ops-node7)07/15/2018_x86_64_(24CPU)12:00:01AMCPU%user%nice%system%iowait%steal%idle12:10:01AMall1.350.000.850.120.0097.6712:20:01AMall1.320.000.860.110.0097.7112:30:02AMall1.370.000.870.110.0097.6512:40:01AMall1.320.000.910.110.0097.6612:50:01AMall1.350.000.890.110.0097.6501:00:01AMall1.360.000.870.110.0097.6601:10:01AMall1.360.000.850.110.0097.6801:20:01AMall1.350.000.890.100.0097.6601:30:01AMall1.320.000.890.110.0097.6801:40:01AMall1.290.000.950.110.0097.6501:50:01AMall1.350.000.880.120.0097.6402:00:01AMall1.340.000.880.110.0097.6802:10:01AMall1.330.000.900.110.0097.6502:20:01AMall1.360.000.870.120.0097.6502:30:01AMall1.350.000.850.120.0097.6802:40:01AMall1.410.000.920.120.0097.5602:50:01AMall1.570.000.950.130.0097.3503:00:01AMall4.210.000.810.160.0094.8103:10:01AMall2.500.000.870.130.0096.5003:20:01AMall1.370.000.870.120.0097.6503:30:01AMall1.360.000.950.130.0097.5603:40:01AMall1.480.000.970.240.0097.3003:50:01AMall1.350.010.910.130.0097.6004:00:01AMall1.390.000.950.190.0097.4704:10:01AMall1.360.000.990.130.0097.52
注意:
sar查看性能或其日志時,使用的12/24小時制;日志的切割是昨天晚上12點到今天12點為一天;默認只保留一個月的日志
六、sar命令參數(shù)及輸出項詳解
【1】格式
用法:sar + 選項 + 時間間隔(可選) + 次數(shù) (可選)
interval: 取樣周期,單位是秒count:取樣次數(shù),默認值為1options:命令行選項
【2】常用選項
-A? ? ? ? ? 所有報告的總和-B? ? ? ? ? 輸出內(nèi)存頁面的統(tǒng)計信息-b? ? ? ? ? 輸出I/O和傳送速率的統(tǒng)計信息-C? ? ? ? ? 輸出進程統(tǒng)計信息及每秒創(chuàng)建的進程數(shù)-d? ? ? ? ? 輸出每一個塊設備的活動信息-H? ? ? ? ? 輸出交換空間利用率信息-h? ? ? ? ? 輸出幫助信息-p? ? ? ? ? 輸出友好設備名字,以方便查看,常與-d和-n參數(shù)結合使用-q? ? ? ? ? 輸出進程隊列長度和系統(tǒng)平均負載狀態(tài)統(tǒng)計信息-R? ? ? ? ? 輸出內(nèi)存頁面的統(tǒng)計信息-r? ? ? ? ? 輸出內(nèi)存和交換空間的統(tǒng)計信息-S? ? ? ? ? 輸出交換空間利用率信息-t? ? ? ? ? 讀取 /var/log/sa/下的某日志的數(shù)據(jù)時顯示其中記錄的原始時間-u? ? ? ? ? 輸出整體CPU使用情況的統(tǒng)計信息-V? ? ? ? ? 輸出版本信息-v? ? ? ? ? 輸出內(nèi)核表狀況統(tǒng)計信息(inode、文件和其他內(nèi)核表的統(tǒng)計信息)-W? ? ? ? ? 輸出系統(tǒng)交換的統(tǒng)計信息-w? ? ? ? ? 輸出任務創(chuàng)建與系統(tǒng)轉(zhuǎn)換統(tǒng)計信息-y? ? ? ? ? 輸出終端設備的活動信息-----------I? ? ? ? ? 輸出指定中斷的統(tǒng)計信息,后方可加參數(shù){...|SUM|ALL|XALL}? ...? ? ? ? ? 指定中斷號SUM? ? ? ? ? 指定輸出每秒接收到的中斷總數(shù)ALL? ? ? ? ? 指定輸出前16個中斷XALL? ? ? ? 指定輸出全部的中斷信息-----------P? ? ? ? ? 輸出指定的部分的CPU的統(tǒng)計信息,后方可加參數(shù){cpu|ALL}cpu? ? ? ? ? 指定cpuALL? ? ? ? ? 輸出單個和整體cpu的統(tǒng)計數(shù)據(jù)-----------n? ? ? ? ? 輸出網(wǎng)絡設備(網(wǎng)卡)狀態(tài)統(tǒng)計信息,后方可加參數(shù){DEV|EDEV|NFS|NFSD|SOCK|ALL}? ? DEV? ? ? ? ? 輸出網(wǎng)絡設備的統(tǒng)計信息EDEV? ? ? ? 輸出網(wǎng)絡設備的錯誤統(tǒng)計信息NFS? ? ? ? ? 輸出NFS客戶端的活動統(tǒng)計信息NFSD? ? ? ? 輸出NFS服務器的活動統(tǒng)計信息SOCK? ? ? ? 輸出網(wǎng)絡套接字的使用統(tǒng)計信息ALL? ? ? ? ? 輸出所有類型的網(wǎng)絡活動統(tǒng)計信息-----------f? ? ? ? ? 從文件中讀取數(shù)據(jù)信息。一般讀取sar日志,也可讀取-o選項生成的文件,后方要加文件名-o? ? ? ? ? 將sar的輸出信息保存到文件中,后方要加文件名-i? ? ? ? ? 指定間隔時長,單位為秒-s? ? ? ? ? 指定輸出統(tǒng)計數(shù)據(jù)的起始時間(格式為hh:mm:ss;例如01:00:00)? -e? ? ? ? ? 指定輸出統(tǒng)計數(shù)據(jù)的截至時間,通常與-S選項連用。無數(shù)值時默認為18:00:00(格式為hh:mm:ss;例如09:00:00)
【3】輸出項
1cpu的輸出
sar -u
%usr? ? ? ? ? ? ? CPU在用戶模式下,執(zhí)行進程的時間百分比 %nice? ? ? ? ? ? ? CPU在用戶模式下,用于nice操作,所占用CPU總時間的百分比 %system? ? ? ? ? ? CPU處在系統(tǒng)模式(內(nèi)核態(tài))下,執(zhí)行進程的時間百分比 %iowait? ? ? ? ? ? CPU用于等待I/O操作完成(等待輸入輸出完成),占用CPU總時間的百分比 %steal? ? ? ? ? ? 管理程序為另一個虛擬進程提供服務而等待虛擬CPU的百分比%idle? ? ? ? ? ? ? CPU空閑時間百分比
注意:
如果%iowait的值過高,表示硬盤存在I/O瓶頸 如果%idle值高,表示CPU較空閑如果%idle 的值高但系統(tǒng)響應慢時,有可能是 CPU 等待分配內(nèi)存,此時應加大內(nèi)存容量 如果%idle 的值持續(xù)低于10,則系統(tǒng)的 CPU 處理能力相對較低,表明系統(tǒng)中最需要解決的資源是 CPU
2I/O和傳送速率輸出
sar -b
tps? ? ? ? ? ? ? ? 每秒向磁盤設備請求數(shù)據(jù)的次數(shù),包括讀、寫請求,其為rtps與wtps的和。每一次IO下發(fā)后會先將多個請求合并為一個I/O磁盤請求,這里tps指請求合并后的請求計數(shù)rtps? ? ? ? ? ? ? 每秒向磁盤設備的讀請求次數(shù) wtps? ? ? ? ? ? ? 每秒向磁盤設備的寫請求次數(shù) bread/s? ? ? ? ? ? 每秒鐘從物理設備讀入的數(shù)據(jù)量,單位為 塊/s bwrtn/s? ? ? ? ? ? 每秒鐘向物理設備寫入的數(shù)據(jù)量,單位為 塊/s
3設備使用情況輸出
sar -d
DEV? ? ? ? ? ? ? ? 磁盤設備,加上用參數(shù)-p可以打印出sda等磁盤設備名稱;如不加參數(shù)-p,設備則顯示為dev253-0等tps? ? ? ? ? ? ? ? 每秒向磁盤設備請求數(shù)據(jù)的次數(shù),包括讀、寫請求,其為rtps與wtps的和。每一次IO下發(fā)后會先將多個請求合并為一個I/O磁盤請求,這里tps指請求合并后的請求計數(shù)rd_sec/s? ? ? ? ? 每秒讀扇區(qū)的次數(shù)wr_sec/s? ? ? ? ? 每秒寫扇區(qū)的次數(shù)avgrq-sz? ? ? ? ? 平均每次設備I/O操作的數(shù)據(jù)大小(扇區(qū))avgqu-sz? ? ? ? ? 磁盤請求隊列的平均長度await? ? ? ? ? ? ? 從請求磁盤到系統(tǒng)處理完,每次請求的平均消耗時間,包括請求隊列等待時間(單位是毫秒)svctm? ? ? ? ? ? ? 系統(tǒng)處理每次請求的平均時間,不包括在請求隊列中消耗的時間%util? ? ? ? ? ? ? I/O請求占CPU的百分比
4網(wǎng)絡設備統(tǒng)計信息輸出
sar -n EDEV
IFACE? ? ? ? ? ? ? 網(wǎng)絡設備名rxpck/s? ? ? ? ? ? 每秒接收的包數(shù)量txpck/s? ? ? ? ? ? 每秒傳輸?shù)陌鼣?shù)量rxbyt/s? ? ? ? ? ? 每秒接收的字節(jié)數(shù)(單位為byte)txbyt/s? ? ? ? ? ? 每秒傳輸?shù)淖止?jié)數(shù)(單位為byte)rxkB/s? ? ? ? ? ? 每秒收的數(shù)據(jù)量(單位為kB)txkB/s? ? ? ? ? ? 每秒發(fā)的數(shù)據(jù)量(單位為kB)rxcmp/s? ? ? ? ? ? 每秒接收壓縮包的數(shù)量txcmp/s? ? ? ? ? ? 每秒傳輸壓縮包的數(shù)量rxmcst/s? ? ? ? ? 每秒接收的多播(multicast)包的總數(shù)排查網(wǎng)絡設備故障
5網(wǎng)絡設備故障信息輸出
EDEV |egrep ‘eth0|IFACE’ (本次指定了網(wǎng)卡etho0,可填入其他網(wǎng)卡)
IFACE網(wǎng)絡設備名rxerr/s每秒接收的壞包數(shù)量txerr/s傳輸包時每秒發(fā)生錯誤的數(shù)量coll/s傳輸包時每秒發(fā)生沖突的數(shù)量rxdrop/s接收包時,每秒丟棄的包的數(shù)量(缺乏緩存導致)txdrop/s傳輸包時,每秒丟棄的包的數(shù)量(缺乏緩存導致)txcarr/s傳輸包時,每秒發(fā)生的傳輸錯誤的數(shù)量rxfram/s接收包時,每秒發(fā)生幀校驗錯誤的數(shù)量rxfifo/s接收包時,每秒鐘緩沖區(qū)溢出錯誤的數(shù)量txfifo/s傳輸包時,每秒鐘緩沖區(qū)溢出錯誤的數(shù)量
6內(nèi)存分頁狀態(tài)輸出
sar -B
pgpgin/s每秒從磁盤空間或交換空間置換到內(nèi)存的字節(jié)數(shù)(單位為KB)pgpgout/s每秒從內(nèi)存置換到磁盤空間或交換空間的字節(jié)數(shù)(單位為KB)fault/s每秒鐘系統(tǒng)產(chǎn)生的缺頁數(shù)(主缺頁加次缺頁)majflt/s每秒鐘產(chǎn)生的主缺頁數(shù)pgfree/s每秒被放入空閑隊列中的頁個數(shù)pgscank/s每秒被kswapd掃描的頁個數(shù)pgscand/s每秒直接被掃描的頁個數(shù)pgsteal/s每秒鐘從cache中被清除來滿足內(nèi)存需要的頁個數(shù)%vmeff每秒清除的頁占總掃描頁的百分比
7進程隊列長度和平均負載狀態(tài)輸出
sar -q
runq-sz? ? ? ? ? 運行隊列的長度,等待運行的進程數(shù)量
plist-sz? ? ? ? 進程列表中進程和線程的數(shù)量
ldavg-1? ? ? ? ? 最后1分鐘的系統(tǒng)平均負載
ldavg-5? ? ? ? ? 過去5分鐘的系統(tǒng)平均負載
ldavg-15? ? ? ? 過去15分鐘的系統(tǒng)平均負載
8內(nèi)存和交換空間狀態(tài)輸出
sar -r
kbmemfree空閑的內(nèi)存數(shù)量(單位為KB)kbmemused已使用的內(nèi)存數(shù)量,不包含內(nèi)核使用的內(nèi)存(單位為KB)%memused已使用內(nèi)存的百分數(shù)kbbuffers內(nèi)核緩沖區(qū)buffer,使用的內(nèi)存數(shù)量(單位為KB)kbcached內(nèi)核高速緩存cache數(shù)據(jù)使用的內(nèi)存數(shù)量(單位為KB)kbcommit保證當前系統(tǒng)所需要的內(nèi)存,即為了確保不溢出而需要的內(nèi)存(RAM+swap)%commitkbcommit與所有內(nèi)存總量的百分比
9系統(tǒng)交換活動信息輸出
sar -W
pswpin/s? ? ? ? ? 每秒系統(tǒng)換入的交換頁面數(shù)量
pswpout/s? ? ? ? ? 每秒系統(tǒng)換出的交換頁面數(shù)量
七、sar使用實例-查看某一時間段的情況
1查看凌晨1點到3點的cpu
sar -s 01:00:00 -e 03:00:00
2查看凌晨1點到3點的系統(tǒng)的平均負載
若要看某時間段其他性能,加上對應選項
sar -s 01:00:00 -e 03:00:00 -q
3查看本月3號的cpu
注意:
該操作需要去查看sar的日志(第五節(jié)已經(jīng)介紹一次)
默認只保存一個月的
sar查看性能或其日志時,注意自己的使用的是12還是24小時制
日志的切割是昨天晚上12點到今天12點為一天
cd/var/log/sa/sar -f sa03