Linux常用的60個命令用法


Linux提供了大量的命令,利用它可以有效地完成大量的工作,如磁盤操作、文件存取、目錄操作、進程管理、文件權限設定等。所以,在Linux系統上工作離不開使用系統提供的命令。要想真正理解Linux系統,就必須從Linux命令學起,通過基礎的命令學習可以進一步理解Linux系統。這里把比較重要和使用頻率最多的命令詳細解析。

1. ls命令

ls命令是列出目錄內容(List Directory Contents)的意思。運行它就是列出文件夾里的內容,可能是文件也可能是文件夾。

1
2
3
root @raspberrypi :/# ls
bin   boot.bak  etc   lib         media  opt   root  sbin     srv  tmp  var
boot  dev       home  lost+found  mnt    proc  run   selinux  sys  usr

“ls -l”命令以詳情模式(long listing fashion)列出文件夾的內容。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
root @raspberrypi :/# ls -l
total  92
drwxr-xr-x    2  root root   4096  Jul  26  12 : 19  bin
drwxr-xr-x    2  root root  16384  Jan   1   1970  boot
drwxr-xr-x    2  root root   4096  Jan   1   1970  boot.bak
drwxr-xr-x   12  root root   3060  Aug  26   2013  dev
drwxr-xr-x  100  root root   4096  Aug  26   2013  etc
drwxr-xr-x    3  root root   4096  Jul  26  11 : 47  home
drwxr-xr-x   13  root root   4096  Aug  19  16 : 36  lib
drwx------    2  root root  16384  Jul  26  11 : 22  lost+found
drwxr-xr-x    2  root root   4096  Jul  26  11 : 24  media
drwxr-xr-x    2  root root   4096  Jun  15  15 : 44  mnt
drwxr-xr-x    7  root root   4096  Aug  26  02 : 09  opt
dr-xr-xr-x   75  root root      0  Jan   1   1970  proc
drwx------    7  root root   4096  Aug  23  01 : 47  root
drwxr-xr-x   13  root root    600  Aug  26  02 : 44  run
drwxr-xr-x    2  root root   4096  Jul  26  12 : 19  sbin
drwxr-xr-x    2  root root   4096  Jun  20   2012  selinux
drwxr-xr-x    3  root root   4096  Aug  22  10 : 17  srv
dr-xr-xr-x   12  root root      0  Jan   1   1970  sys
drwxrwxrwt    4  root root   4096  Aug  26  02 : 51  tmp
drwxr-xr-x   10  root root   4096  Jul  26  11 : 24  usr
drwxr-xr-x   11  root root   4096  Jul  26  13 : 43  var

"ls -a"命令會列出文件夾里的所有內容,包括以"."開頭的隱藏文件。

1
2
3
root @raspberrypi :/# ls -a
. bin boot.bak etc lib media opt root sbin srv tmp var
.. boot dev home lost+found mnt proc run selinux sys usr

注意:在Linux中,文件以“.”開頭的就是隱藏文件,並且每個文件,文件夾,設備或者命令都是以文件對待。ls -l 命令輸出:

  1. d (代表了是目錄).
  2. rwxr-xr-x 是文件或者目錄對所屬用戶,同一組用戶和其它用戶的權限。
  3. 上面例子中第一個ravisaive 代表了文件文件屬於用戶ravisaive
  4. 上面例子中的第二個ravisaive代表了文件文件屬於用戶組ravisaive
  5. 4096 代表了文件大小為4096字節.
  6. May 8 01:06 代表了文件最后一次修改的日期和時間.
  7. 最后面的就是文件/文件夾的名字

2. lsblk命令

"lsblk"就是列出塊設備。除了RAM外,以標准的樹狀輸出格式,整齊地顯示塊設備。

“lsblk -l”命令以列表格式顯示塊設備(而不是樹狀格式)。

注意:lsblk是最有用和最簡單的方式來了解新插入的USB設備的名字,特別是當你在終端上處理磁盤/塊設備時。

3. md5sum命令

“md5sum”就是計算和檢驗MD5信息簽名。md5 checksum(通常叫做哈希)使用匹配或者驗證文件的文件的完整性,因為文件可能因為傳輸錯誤,磁盤錯誤或者無惡意的干擾等原因而發生改變。

4. dd命令

“dd”命令代表了轉換和復制文件。可以用來轉換和復制文件,大多數時間是用來復制iso文件(或任何其它文件)到一個usb設備(或任何其它地方)中去,所以可以用來制作USB啟動器。

1
root @raspberry :~# dd  if =/home/user/Downloads/debian.iso of=/dev/sdb1 bs=512M; sync

注意:在上面的例子中,usb設備就是sdb1(你應該使用lsblk命令驗證它,否則你會重寫你的磁盤或者系統),請慎重使用磁盤的名,切忌。

dd 命令在執行中會根據文件的大小和類型 以及 usb設備的讀寫速度,消耗幾秒到幾分鍾不等。

5. uname命令

"uname"命令就是Unix Name的簡寫。顯示機器名,操作系統和內核的詳細信息。

1
2
root @raspberrypi :/# uname -a
Linux raspberrypi  3.6 . 11 + # 528  PREEMPT Tue Aug  20  00 : 25 : 53  BST  2013  armv6l GNU/Linux

注意: uname顯示內核類別, uname -a顯示詳細信息。上面的輸出詳細說明了uname -a

  1. “Linux“: 機器的內核名
  2. “tecmint“: 機器的節點名
  3. “3.8.0-19-generic“: 內核發布版本
  4. “#30-Ubuntu SMP“: 內核版本
  5. “i686“: 處理器架構
  6. “GNU/Linux“: 操作系統名

6. history命令

“history”命令就是歷史記錄。它顯示了在終端中所執行過的所有命令的歷史。

注意:按住“CTRL + R”就可以搜索已經執行過的命令,它可以在你寫命令時自動補全。

7. sudo命令

“sudo”(super user do)命令允許授權用戶執行超級用戶或者其它用戶的命令。通過在sudoers列表的安全策略來指定。

注意:sudo 允許用戶借用超級用戶的權限,然而"su"命令實際上是允許用戶以超級用戶登錄。所以sudo比su更安全。
並不建議使用sudo或者su來處理日常用途,因為它可能導致嚴重的錯誤如果你意外的做錯了事,這就是為什么在linux社區流行一句話:

1
“To err is human, but to really foul up everything, you need root password.”<br>“人非聖賢孰能無過,但是擁有root密碼就真的萬劫不復了。” # 譯

8. mkdir命令

“mkdir”(Make directory)命令在命名路徑下創建新的目錄。然而如果目錄已經存在了,那么它就會返回一個錯誤信息"不能創建文件夾,文件夾已經存在了"("cannot create folder, folder already exists")

root@raspberrypi:/opt/labpark# mkdir raspbox

注意:目錄只能在用戶擁有寫權限的目錄下才能創建。mkdir:不能創建目錄`tecmint`,因為文件已經存在了。(上面的輸出中不要被文件迷惑了,你應該記住我開頭所說的-在linux中,文件,文件夾,驅動,命令,腳本都視為文件)

9. touch 命令

“touch”命令代表了將文件的訪問和修改時間更新為當前時間。touch命令只會在文件不存在的時候才會創建它。如果文件已經存在了,它會更新時間戳,但是並不會改變文件的內容。

1
root @raspberrypi :/opt/labpark# touch rasp.txt

注意:touch 可以用來在用戶擁有寫權限的目錄下創建不存在的文件。

10. chmod 命令

“chmod”命令就是改變文件的模式位。chmod會根據要求的模式來改變每個所給的文件,文件夾,腳本等等的文件模式(權限)。

在文件(文件夾或者其它,為了簡單起見,我們就使用文件)中存在3中類型的權限

1
2
3
Read (r)= 4
Write(w)= 2
Execute(x)= 1

所以如果你想給文件只讀權限,就設置為'4';只寫權限,設置權限為'2';只執行權限,設置為1; 讀寫權限,就是4+2 = 6, 以此類推。

現在需要設置3種用戶和用戶組權限。第一個是擁有者,然后是用戶所在的組,最后是其它用戶。

這里root的權限是 rwx(讀寫和執行權限),
所屬用戶組權限是 r-x (只有讀和執行權限, 沒有寫權限),
對於其它用戶權限是 -x(只有只執行權限)

為了改變它的權限,為擁有者,用戶所在組和其它用戶提供讀,寫,執行權限。

11. chown命令

“chown”命令就是改變文件擁有者和所在用戶組。每個文件都屬於一個用戶組和一個用戶。在你的目錄下,使用"ls -l",你就會看到像這樣的東西。

1
2
3
4
5
6
7
8
root @raspberrypi :/opt# ls -l
total  24
drwxr-xr-x  2  root root  4096  Aug  26  02 : 51  labpark
drwxr-xr-x  3  root root  4096  Aug  22  12 : 20  node
drwxr-xr-x  2  root root  4096  Aug  21  06 : 57  Python
drwxr-xr-x  7  root root  4096  Aug  19  16 : 41  vc
-rw-r--r--  1  root root  13  Aug  22  10 : 04  vsftpd.txt
d-wx-wx-wx  2  root root  4096  Aug  22  11 : 26  wwwroot

在這里,目錄labpark屬於用戶"root",和用戶組"root",

“chown”命令用來改變文件的所有權,所以僅僅用來管理和提供文件的用戶和用戶組授權。

測試試用的是一個Raspberry,所以系統里有一個默認用戶pi,屬於用戶組pi的,試用下面的命令,

1
root @raspberrypi :/opt# chown pi:pi labpark/

可以看到labpark的所屬組已經更改為pi pi

1
2
3
4
5
6
7
8
root @raspberrypi :/opt# ls -l
total  24
drwxr-xr-x  2  pi   pi    4096  Aug  26  02 : 51  labpark
drwxr-xr-x  3  root root  4096  Aug  22  12 : 20  node
drwxr-xr-x  2  root root  4096  Aug  21  06 : 57  python
drwxr-xr-x  7  root root  4096  Aug  19  16 : 41  vc
-rw-r--r--  1  root root    13  Aug  22  10 : 04  vsftpd.txt
d-wx-wx-wx  2  root root  4096  Aug  22  11 : 26  wwwroot

注意:“chown”所給的文件改變用戶和組的所有權到新的擁有者或者已經存在的用戶或者用戶組。

 

12. apt命令

Debian系列以“apt”命令為基礎,“apt”代表了Advanced Package Tool。APT是一個為Debian系列系統(Ubuntu,Kubuntu等等)開發的高級包管理器,在Gnu/Linux系統上,它會為包自動地,智能地搜索,安裝,升級以及解決依賴。

復制代碼
root@raspberrypi:/opt#
 apt-get install
 nginx
Reading
 package lists... Done
Building
 dependency tree
Reading
 state information... Done
nginx
is already
 the newest version.
0
 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
復制代碼
1
2
3
4
5
6
7
8
9
10
11
root @raspberrypi :/opt# apt-get update
Get: 1  http: //mirrordirector.raspbian.org wheezy Release.gpg [490 B]
Hit http: //raspberrypi.collabora.com wheezy Release.gpg
Hit http: //archive.raspberrypi.org wheezy Release.gpg
Get: 2  http: //mirrordirector.raspbian.org wheezy Release [14.4 kB]
Hit http: //raspberrypi.collabora.com wheezy Release
Hit http: //archive.raspberrypi.org wheezy Release
Hit http: //raspberrypi.collabora.com wheezy/rpi armhf Packages
Hit http: //archive.raspberrypi.org wheezy/main armhf Packages
Get: 3  http: //mirrordirector.raspbian.org wheezy/main armhf Packages [7,415 kB]
1 % [ 3  Packages  22.9  kB/ 7 , 415  kB  0 %] [Waiting  for  headers] [Waiting  for  headers]^C

注意:上面的命令會導致系統整體的改變,所以需要root密碼(查看提示符為"#",而不是“$”).和yum命令相比,Apt更高級和智能。

見名知義,apt-cache用來搜索包中是否包含子包mplayer, apt-get用來安裝,升級所有的已安裝的包到最新版。

關於apt-get 和 apt-cache命令更多信息,請查看 25 APT-GET和APT-CACHE命令

13. tar命令

“tar”命令是磁帶歸檔(Tape Archive),對創建一些文件的的歸檔和它們的解壓很有用。

root@raspberry:~# tar -zxvf abc.tar.gz (記住'z'代表了.tar.gz)

root@raspberry:~# tar -jxvf abc.tar.bz2 (記住'j'代表了.tar.bz2)

root@raspberry:~# tar -cvf archieve.tar.gz(.bz2) /path/to/folder/abc

14. cal 命令

“cal”(Calender),它用來顯示當前月份或者未來或者過去任何年份中的月份。

復制代碼
root@raspberrypi:/opt# cal
    August 2013
Su Mo Tu We Th Fr Sa
             1  2  3
 4  5  6  7  8  9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30 31
復制代碼

顯示指定的年份的月份,可以是過去的也可以是未來的。

1
2
3
4
5
6
7
8
root @raspberrypi :/opt# cal  10  1986
     October  1986
Su Mo Tu We Th Fr Sa
           1   2   3   4
  5   6   7   8   9  10  11
12  13  14  15  16  17  18
19  20  21  22  23  24  25
26  27  28  29  30  31

注意: 你不需要往回調整日歷50年,既不用復雜的數據計算你出生那天,也不用計算你的生日在哪天到來,[因為它的最小單位是月,而不是日]。

15. date命令

“date”命令使用標准的輸出打印當前的日期和時間,也可以深入設置。

1
2
root @raspberrypi :/opt# date
Mon Aug  26  03 : 21 : 36  UTC  2013

設置系統時間:

root@raspberrypi:/opt# date --set='26 aug 2013 11:42'
Mon Aug 26 11:42:00 UTC 2013

注意:這個命令在腳本中十分有用,以及基於時間和日期的腳本更完美。而且在終端中改變日期和時間,讓你更專業!!!(當然你需要root權限才能操作這個,因為它是系統整體改變)

16. cat命令

“cat”代表了連結(Concatenation),連接兩個或者更多文本文件或者以標准輸出形式打印文件的內容。

在book.txt中只有一個book單詞,在facebook.txt中只有facebook一個單詞,然后連接之后輸出如下:

1
2
3
root @raspberrypi :/opt/labpark# cat book.txt facebook.txt
book
facebook

! 叫做非,帶'!'的反向字符串為真

更多請閱讀Linux cat 命令的實例 

17. cp 命令

“copy”就是復制。它會從一個地方復制一個文件到另外一個地方。

root@raspberrypi:/opt/labpark# cp book.txt book_backup.txt

注意: cp,在shell腳本中是最常用的一個命令,而且它可以使用通配符(在前面一塊中有所描述),來定制所需的文件的復制。

18. mv 命令

“mv”命令將一個地方的文件移動到另外一個地方去。

1
root @raspberrypi :/opt/labpark# mv nihao.txt /opt/python/

注意:mv 命令可以使用通配符。mv需謹慎使用,因為移動系統的或者未授權的文件不但會導致安全性問題,而且可能系統崩潰。

19. pwd 命令

“pwd”(print working directory),在終端中顯示當前工作目錄的全路徑。

1
2
root @raspberrypi :/opt/labpark# pwd
/opt/labpark

注意: 這個命令並不會在腳本中經常使用,但是對於新手,當從連接到nux很久后在終端中迷失了路徑,這絕對是救命稻草。

20. cd 命令

最后,經常使用的“cd”命令代表了改變目錄。它在終端中改變工作目錄來執行,復制,移動,讀,寫等等操作。

注意: 在終端中切換目錄時,cd就大顯身手了。“cd ~”會改變工作目錄為用戶的家目錄,而且當用戶發現自己在終端中迷失了路徑時,非常有用。“cd ..”從當前工作目錄切換到(當前工作目錄的)父目錄。

這些命令肯定會讓你在Linux上很舒服。但是這並不是結束。例如,如果你熟練使用這些命令,歡呼吧,少年,你會發現你已從小白級別提升為了中級用戶了。在下篇文章,我會介紹像“kill”,"ps","grep"等等命令,期待吧,我不會讓你失望的。

對中級 Linux 用戶非常有用的 20 個命令

21. 命令: Find

搜索指定目錄下的文件,從開始於父目錄,然后搜索子目錄。

1
2
3
root @raspberrypi :/opt/labpark# find book*
book_backup.txt
book.txt

 

1
2
root @raspberrypi :/opt/labpark# find -name *.c
./hello.c

  

1
2
root @raspberrypi :/opt/labpark# find -iname FACE*
./facebook.txt

 

注意: `-name‘選項是搜索大小寫敏感。可以使用`-iname‘選項,這樣在搜索中可以忽略大小寫。(*是通配符,可以搜索所有的文件;‘.sh‘你可以使用文件名或者文件名的一部分來制定輸出結果)

注意:以上命令查找根目錄下和所有文件夾以及加載的設備的子目錄下的所有包含‘tar.gz'的文件。

22. 命令: grep

‘grep‘命令搜索指定文件中包含給定字符串或者單詞的行。舉例搜索‘/etc/passwd‘文件中的‘pi'

1
2
root @raspberrypi :/opt/labpark# grep pi /etc/passwd
pi:x: 1000 : 1000 :,,,:/opt/wwwroot:/bin/bash

使用’-i'選項將忽略大小寫。

1
2
root @raspberrypi :/opt/labpark#
  grep -i   'PI'  /etc/passwd<br><br>pi:x: 1000 : 1000 :,,,:/opt/wwwroot:/bin/bash

 

使用’-r'選項遞歸搜索所有自目錄下包含字符串 “localhost“.的行。

1
2
3
4
root @raspberrypi :/opt/labpark# grep -r  "localhost"  /etc/php5/
/etc/php5/cgi/php.ini:SMTP = localhost
/etc/php5/cli/php.ini:SMTP = localhost
/etc/php5/fpm/php.ini:SMTP = localhost

注意:您還可以使用以下選項:

  1. -w 搜索單詞 (egrep -w ‘word1|word2‘ /path/to/file).
  2. -c 用於統計滿足要求的行 (i.e., total number of times the pattern matched) (grep -c ‘word‘ /path/to/file).
  3. –color 彩色輸出 (grep –color server /etc/passwd).

23. 命令: man

‘man‘是系統幫助頁。Man提供命令所有選項及用法的在線文檔。幾乎所有的命令都有它們的幫助頁,例如:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
root @raspberrypi :/opt/labpark# man
What manual page  do  you want?
root @raspberrypi :/opt/labpark# man man
MAN( 1 )                        Manual pager utils                        MAN( 1 )
 
NAME
        man - an  interface  to the on-line reference manuals
 
SYNOPSIS
        man  [-C  file]  [-d]  [-D]  [--warnings[=warnings]]  [-R encoding] [-L
        locale] [-m system[,...]] [-M path] [-S list]  [-e  extension]  [-i|-I]
        [--regex|--wildcard]   [--names-only]  [-a]  [-u]  [--no-subpages]  [-P
        pager] [-r prompt] [- 7 ] [-E encoding] [--no-hyphenation] [--no-justifiâ€
        cation]  [-p  string]  [-t]  [-T[device]]  [-H[browser]] [-X[dpi]] [-Z]
        [[section] page ...] ...
        man -k [apropos options] regexp ...
        man -K [-w|-W] [-S list] [-i|-I] [--regex] [section] term ...
        man -f [whatis options] page ...
        man -l [-C file] [-d] [-D] [--warnings[=warnings]]  [-R  encoding]  [-L
        locale]  [-P  pager]  [-r  prompt]  [- 7 ] [-E encoding] [-p string] [-t]
        [-T[device]] [-H[browser]] [-X[dpi]] [-Z] file ...
        man -w|-W [-C file] [-d] [-D] page ...
        man -c [-C file] [-d] [-D] page ...
        man [-hV]
 
DESCRIPTION

上面是man命令的系統幫助頁,類似的有cat和ls的幫助頁。

注意:系統幫助頁是為了命令的使用和學習而設計的。

24. 命令: ps

ps命令給出正在運行的某個進程的狀態,每個進程有特定的id成為PID。

1
2
3
4
5
6
7
root @raspberrypi :/opt/labpark# ps
   PID TTY          TIME CMD
  2801  pts/ 1     00 : 00 : 01  bash
  2868  pts/ 1     00 : 00 : 00  su
  2885  pts/ 1     00 : 00 : 00  su
  2892  pts/ 1     00 : 00 : 00  bash
  2981  pts/ 1     00 : 00 : 00  ps

使用‘-A‘選項可以列出所有的進程及其PID。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
root @raspberrypi :/opt/labpark# ps -A
   PID TTY          TIME CMD
     1  ?         00 : 00 : 01  init
     2  ?         00 : 00 : 00  kthreadd
     3  ?         00 : 00 : 00  ksoftirqd/ 0
     5  ?         00 : 00 : 00  kworker/ 0 :0H
     6  ?         00 : 00 : 00  kworker/u: 0
     7  ?         00 : 00 : 00  kworker/u:0H
     8  ?         00 : 00 : 00  khelper
     9  ?         00 : 00 : 00  kdevtmpfs
    10  ?         00 : 00 : 00  netns
    12  ?         00 : 00 : 00  bdi- default
    13  ?         00 : 00 : 00  kblockd
    14  ?         00 : 00 : 00  khubd
    15  ?         00 : 00 : 00  rpciod
    16  ?         00 : 00 : 00  khungtaskd
    17  ?         00 : 00 : 00  kswapd0
    18  ?         00 : 00 : 00  fsnotify_mark
    19  ?         00 : 00 : 00  nfsiod
    20  ?         00 : 00 : 00  crypto
    27  ?         00 : 00 : 00  kthrotld
    28  ?         00 : 00 : 00  VCHIQ- 0
    29  ?         00 : 00 : 00  VCHIQr- 0
    30  ?         00 : 00 : 00  VCHIQs- 0
    31  ?         00 : 00 : 00  iscsi_eh
    32  ?         00 : 00 : 00  dwc_otg
    33  ?         00 : 00 : 00  DWC Notificatio
    35  ?         00 : 00 : 00  deferwq
    36  ?         00 : 00 : 00  kworker/u: 2
    37  ?         00 : 00 : 15  mmcqd/ 0
    38  ?         00 : 00 : 00  jbd2/mmcblk0p2-
    39  ?         00 : 00 : 00  ext4-dio-unwrit
   154  ?         00 : 00 : 00  udevd
   636  ?         00 : 00 : 00  udevd
   650  ?         00 : 00 : 00  udevd
  1523  ?         00 : 00 : 01  ifplugd
  1546  ?         00 : 00 : 00  ifplugd
  1686  ?         00 : 00 : 00  kworker/ 0 : 2
  1784  ?         00 : 00 : 00  dhclient
  1839  ?         00 : 00 : 00  rc
  1848  ?         00 : 00 : 02  startpar
  1914  ?         00 : 00 : 00  rsyslogd
  1940  ?         00 : 00 : 00  php5-fpm
  1941  ?         00 : 00 : 00  php5-fpm
  1942  ?         00 : 00 : 00  php5-fpm
  1967  ?         00 : 00 : 00  cron
  2005  ?         00 : 00 : 00  dbus-daemon
  2048  ?         00 : 00 : 00  nginx
  2050  ?         00 : 00 : 00  nginx
  2069  ?         00 : 00 : 00  mysqld_safe
  2443  ?         00 : 00 : 14  mysqld
  2444  ?         00 : 00 : 00  logger
  2501  ?         00 : 00 : 00  sshd
  2529  ?         00 : 00 : 00  thd
  2537  ?         00 : 00 : 00  vsftpd
  2692  ?         00 : 00 : 00  ntpd
  2715  ?         00 : 00 : 00  rc.local
  2718  ?         00 : 00 : 00  rc.local
  2720  ?         00 : 00 : 25  python
  2723  ?         00 : 00 : 02  sshd
  2728  ?         00 : 00 : 00  console-kit-dae
  2795  ?         00 : 00 : 00  polkitd
  2801  pts/ 1     00 : 00 : 01  bash
  2868  pts/ 1     00 : 00 : 00  su
  2875  pts/ 1     00 : 00 : 00  bash
  2885  pts/ 1     00 : 00 : 00  su
  2892  pts/ 1     00 : 00 : 00  bash
  2934  ?         00 : 00 : 00  kworker/ 0 : 1
  2971  ?         00 : 00 : 00  flush- 179 : 0
  2982  pts/ 1     00 : 00 : 00  ps

注意:當你要知道有哪些進程在運行或者需要知道想殺死的進程PID時ps命令很管用。你可以把它與‘grep‘合用來查詢指定的輸出結果,例如:

1
2
3
root @raspberrypi :/opt/labpark# ps -A | grep -i nginx
  2048  ?         00 : 00 : 00  nginx
  2050  ?         00 : 00 : 00  nginx


ps命令與grep命令用管道線分割可以得到我們想要的結果。

25. 命令: kill

也許你從命令的名字已經猜出是做什么的了,kill是用來殺死已經無關緊要或者沒有響應的進程.它是一個非常有用的命令,而不是非常非常有用.你可能很熟悉Windows下要殺死進程可能需要頻繁重啟機器因為一個在運行的進程大部分情況下不能夠殺死,即使殺死了進程也需要重新啟動操作系統才能生效.但在linux環境下,事情不是這樣的.你可以殺死一個進程並且重啟它而不是重啟整個操作系統.

殺死一個進程需要知道進程的PID.

假設你想殺死已經沒有響應的‘nginx'進程,運行如下命令:

1
root @raspberrypi :/opt/labpark# kill  2048

注意:kill需要PID作為參數,pkill可以選擇應用的方式,比如指定進程的所有者等.

26. 命令: whereis

whereis的作用是用來定位命令的二進制文件\資源\或者幫助頁.舉例來說,獲得ls和kill命令的二進制文件/資源以及幫助頁:

1
2
root @raspberrypi :/# whereis ls
ls: /bin/ls /usr/share/man/man1/ls. 1 .gz
1
2
root @raspberrypi :/# whereis kill
kill: /bin/kill /usr/share/man/man2/kill. 2 .gz /usr/share/man/man1/kill. 1 .gz

注意:當需要知道二進制文件保存位置時有用.

27. 命令: service

‘service‘命令控制服務的啟動、停止和重啟,它讓你能夠不重啟整個系統就可以讓配置生效以開啟、停止或者重啟某個服務。

查看當前服務狀態

復制代碼
root@raspberrypi:/# service --status-all
 [ ? ]  alsa-utils
 [ - ]  bootlogs
 [ ? ]  bootmisc.sh
 [ ? ]  checkfs.sh
 [ ? ]  checkroot-bootclean.sh
 [ - ]  checkroot.sh
 [ - ]  console-setup
 [ + ]  cron
 [ + ]  dbus
 [ ? ]  dphys-swapfile
 [ ? ]  fake-hwclock
 [ - ]  hostname.sh
 [ ? ]  hwclock.sh
 [ + ]  ifplugd
 [ - ]  kbd
 [ - ]  keyboard-setup
 [ ? ]  killprocs
 [ ? ]  kmod
 [ - ]  lightdm
 [ - ]  motd
 [ ? ]  mountall-bootclean.sh
 [ ? ]  mountall.sh
 [ ? ]  mountdevsubfs.sh
 [ ? ]  mountkernfs.sh
 [ ? ]  mountnfs-bootclean.sh
 [ ? ]  mountnfs.sh
 [ ? ]  mtab.sh
 [ ? ]  mysql
 [ ? ]  networking
 [ - ]  nfs-common
 [ + ]  nginx
 [ - ]  ntp
 [ + ]  php5-fpm
 [ ? ]  plymouth
 [ ? ]  plymouth-log
 [ - ]  procps
 [ ? ]  rc.local
 [ - ]  rmnologin
 [ - ]  rpcbind
 [ - ]  rsync
 [ + ]  rsyslog
 [ ? ]  sendsigs
 [ + ]  ssh
 [ - ]  sudo
 [ + ]  triggerhappy
 [ + ]  udev
 [ ? ]  udev-mtab
 [ ? ]  umountfs
 [ ? ]  umountnfs.sh
 [ ? ]  umountroot
 [ - ]  urandom
 [ + ]  vsftpd
 [ - ]  x11-common
復制代碼

查看nginx服務的狀態:service nginx status

 

1
2
root @raspberrypi :/# service nginx status
[ ok ] nginx is running.

停止nginx服務:

1
2
3
4
root @raspberrypi :/# service nginx stop
Stopping nginx: nginx.
root @raspberrypi :/# service nginx status
[FAIL] nginx is not running ... failed!

啟動nginx服務:

1
2
3
4
root @raspberrypi :/# service nginx start
Starting nginx: nginx.
root @raspberrypi :/# service nginx status
[ ok ] nginx is running.

注意:要想使用service命令,進程的腳本必須放在‘/etc/init.d‘,並且路徑必須在指定的位置。

如果要運行“service apache2 start”實際上實在執行“service /etc/init.d/apache2 start”.

28. 命令: alias

alias是一個系統自建的shell命令,允許你為名字比較長的或者經常使用的命令指定別名。

我經常用‘ls -l‘命令,它有五個字符(包括空格)。於是我為它創建了一個別名‘l'。

1
2
3
root @raspberrypi :/# alias l= 'ls -l'
root @raspberrypi :/# alias
alias l= 'ls -l'

試試它是否能用:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
root @raspberrypi :/# l
total  92
drwxr-xr-x    2  root root   4096  Jul  26  12 : 19  bin
drwxr-xr-x    2  root root  16384  Jan   1   1970  boot
drwxr-xr-x    2  root root   4096  Jan   1   1970  boot.bak
drwxr-xr-x   12  root root   3060  Aug  26  10 : 43  dev
drwxr-xr-x  100  root root   4096  Aug  26  10 : 43  etc
drwxr-xr-x    3  root root   4096  Jul  26  11 : 47  home
drwxr-xr-x   13  root root   4096  Aug  19  16 : 36  lib
drwx------    2  root root  16384  Jul  26  11 : 22  lost+found
drwxr-xr-x    2  root root   4096  Jul  26  11 : 24  media
drwxr-xr-x    2  root root   4096  Jun  15  15 : 44  mnt
drwxr-xr-x    7  root root   4096  Aug  26  03 : 11  opt
dr-xr-xr-x   79  root root      0  Jan   1   1970  proc
drwx------    7  root root   4096  Aug  23  01 : 47  root
drwxr-xr-x   14  root root    620  Aug  26  11 : 45  run
drwxr-xr-x    2  root root   4096  Jul  26  12 : 19  sbin
drwxr-xr-x    2  root root   4096  Jun  20   2012  selinux
drwxr-xr-x    3  root root   4096  Aug  22  10 : 17  srv
dr-xr-xr-x   12  root root      0  Jan   1   1970  sys
drwxrwxrwt    4  root root   4096  Aug  26  11 : 39  tmp
drwxr-xr-x   10  root root   4096  Jul  26  11 : 24  usr
drwxr-xr-x   11  root root   4096  Jul  26  13 : 43  var
復制代碼

去掉’l'別名,要使用unalias命令:

1
2
3
4
5
root @raspberrypi :/# unalias l
root @raspberrypi :/# alias
root @raspberrypi :/# ^C
root @raspberrypi :/# l
bash: l: command not found
1
去掉‘l’別名之后,再輸入‘l’,就會報 commadn not found!

29.命令: df

報告系統的磁盤使用情況。在跟蹤磁盤使用情況方面對於普通用戶和系統管理員都很有用。 ‘df‘ 通過檢查目錄大小工作,但這一數值僅當文件關閉時才得到更新。

1
2
3
4
5
6
7
8
9
root @raspberrypi :/# df
Filesystem     1K-blocks    Used Available Use% Mounted on
rootfs           15128576  2169496   12325996   15 % /
/dev/root        15128576  2169496   12325996   15 % /
devtmpfs           216120        0     216120    0 % /dev
tmpfs               44876      232      44644    1 % /run
tmpfs                5120        0       5120    0 % /run/lock
tmpfs               89740        0      89740    0 % /run/shm
/dev/mmcblk0p1      57288    18512      38776   33 % /boot

加上 -h 參數,按M為單位輸出

復制代碼
root@raspberrypi:/# df -h
Filesystem      Size  Used Avail Use% Mounted on
rootfs           15G  2.1G   12G  15% /
/dev/root        15G  2.1G   12G  15% /
devtmpfs        212M     0  212M   0% /dev
tmpfs            44M  232K   44M   1% /run
tmpfs           5.0M     0  5.0M   0% /run/lock
tmpfs            88M     0   88M   0% /run/shm
/dev/mmcblk0p1   56M   19M   38M  33% /boot
復制代碼

‘df’命令的更多例子請參閱 12 df Command Examples in Linux.

30. 命令: du

估計文件的空間占用。 逐層統計文件(例如以遞歸方式)並輸出摘要。

注意: ‘df‘ 只顯示文件系統的使用統計,但‘du‘統計目錄內容。‘du‘命令的更詳細信息請參閱10 du (Disk Usage) Commands.

31. 命令: rm

'rm' 標准移除命令。 rm 可以用來刪除文件和目錄。

'rm' 不能直接刪除目錄,需要加上相應的'-rf'參數才可以。

警告: "rm -rf" 命令是一個破壞性的命令,假如你不小心刪除一個錯誤的目錄。一旦你使用'rm -rf' 刪除一個目錄,在目錄中所有的文件包括目錄本身會被永久的刪除,所以使用這個命令要非常小心。

33. 命令: passwd

這是一個很重要的命令,在終端中用來改變自己密碼很有用。顯然的,因為安全的原因,你需要知道當前的密碼。

root@raspberrypi:/opt/wwwroot# passwd
Enter new UNIX password:
Retype new UNIX password:
passwd: password updated successfully

34. 命令: lpr

這個命令用來在命令行上將指定的文件在指定的打印機上打印。

1
root @raspberry :~# lpr -P deskjet- 4620 -series  1 - final .pdf

注意: "lpq"命令讓你查看打印機的狀態(是開啟狀態還是關閉狀態)和等待打印中的工作(文件)的狀態。

35. 命令: cmp

比較兩個任意類型的文件並將結果輸出至標准輸出。如果兩個文件相同, ‘cmp‘默認返回0;如果不同,將顯示不同的字節數和第一處不同的位置。

以下面兩個文件為例:

先看看book.txt有什么吧:

1
2
root @raspberrypi :/opt/labpark# cat book.txt
Hi,  this  is the book.

再看看test.txt

1
2
root @raspberrypi :/opt/labpark# cat test.txt
Hi, this  is test file!

.比較一下這兩個文件,看看命令的輸出。

1
2
root @raspberrypi :/opt/labpark# cmp book.txt test.txt
book.txt test.txt differ:  byte  4 , line  1

36. 命令: wget

Wget是用於非交互式(例如后台)下載文件的免費工具.支持HTTP, HTTPS, FTP協議和 HTTP 代理。

 

1
2
3
4
5
6
7
8
9
root @raspberrypi :/opt# wget http: //www.nodejs.org/dist/v0.11.5/node-v0.11.5.tar.gz
-- 2013 - 08 - 26  11 : 59 : 38 --  http: //www.nodejs.org/dist/v0.11.5/node-v0.11.5.tar.gz
Resolving www.nodejs.org (www.nodejs.org)...  165.225 . 133.150
Connecting to www.nodejs.org (www.nodejs.org)| 165.225 . 133.150 |: 80 ... connected.
HTTP request sent, awaiting response...  200  OK
Length:  15054281  (14M) [application/octet-stream]
Saving to: `node-v0. 11.5 .tar.gz'
 
42 % [===============>                       ]  6 , 436 , 208    1 .17M/s  eta 13s

37 命令: mount

mount 是一個很重要的命令,用來掛載不能自動掛載的文件系統。你需要root權限掛載設備。

在插入你的文件系統后,首先運行"lsblk"命令,識別出你的設備,然后把分配的設備名記下來。

對 Linux 專家非常有用的 20 個命令

41. 命令: ifconfig

ifconfig用來配置常駐內核的網絡接口信息。在系統啟動必要時用來設置網絡適配器的信息。之后,它通常是只需要在調試時或當系統需要調整時使用。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
root @raspberrypi :/opt# ifconfig
eth0      Link encap:Ethernet  HWaddr b8: 27 :eb:1c:aa: 00
           inet addr: 10.2 . 58.80   Bcast: 10.2 . 59.255   Mask: 255.255 . 254.0
           UP BROADCAST RUNNING MULTICAST  MTU: 1500   Metric: 1
           RX packets: 75745  errors: 0  dropped: 0  overruns: 0  frame: 0
           TX packets: 34414  errors: 0  dropped: 0  overruns: 0  carrier: 0
           collisions: 0  txqueuelen: 1000
           RX bytes: 24591939  ( 23.4  MiB)  TX bytes: 3747774  ( 3.5  MiB)
 
lo        Link encap:Local Loopback
           inet addr: 127.0 . 0.1   Mask: 255.0 . 0.0
           UP LOOPBACK RUNNING  MTU: 16436   Metric: 1
           RX packets: 0  errors: 0  dropped: 0  overruns: 0  frame: 0
           TX packets: 0  errors: 0  dropped: 0  overruns: 0  carrier: 0
           collisions: 0  txqueuelen: 0
           RX bytes: 0  ( 0.0  B)  TX bytes: 0  ( 0.0  B)
復制代碼
檢查所有的網絡適配器

“-a”參數用來顯示所有網絡適配器(網卡)的詳細信息,包括那些停用的適配器。

復制代碼
root@raspberrypi:~# ifconfig -a
eth0      Link encap:Ethernet  HWaddr b8:27:eb:1c:aa:00
          inet addr:10.2.58.80  Bcast:10.2.59.255  Mask:255.255.254.0
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:1768 errors:0 dropped:0 overruns:0 frame:0
          TX packets:708 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:250870 (244.9 KiB)  TX bytes:75918 (74.1 KiB)

lo        Link encap:Local Loopback
          inet addr:127.0.0.1  Mask:255.0.0.0
          UP LOOPBACK RUNNING  MTU:16436  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0
          RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)

wlan0     Link encap:Ethernet  HWaddr e8:4e:06:0e:05:a6
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)
復制代碼

 

42. 命令: netstat

netstat命令顯示各種網絡相關的信息,如網絡連接,路由表,接口統計,偽裝連接,組播成員身份等...

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
root @raspberrypi :~# netstat -a
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address           Foreign Address         State
tcp         0       0  *:mysql                 *:*                     LISTEN
tcp         0       0  *:http                  *:*                     LISTEN
tcp         0       0  *:ftp                   *:*                     LISTEN
tcp         0       0  *:ssh                   *:*                     LISTEN
tcp         0      52  10.2 . 58.80 :ssh          nihaopc.sohu-inc.: 58688  ESTABLISHED
udp         0       0  *: 52725                  *:*
udp         0       0  *:bootpc                *:*
udp         0       0  10.2 . 58.80 :ntp          *:*
udp         0       0  localhost:ntp           *:*
udp         0       0  *:ntp                   *:*
Active UNIX domain sockets (servers and established)
Proto RefCnt Flags       Type       State         I-Node   Path
unix   2       [ ACC ]     STREAM     LISTENING      2613      /var/run/php5-fpm.sock
unix   2       [ ACC ]     STREAM     LISTENING      2634      /var/run/dbus/system_bus_socket
unix   2       [ ACC ]     SEQPACKET  LISTENING      482       /run/udev/control
unix   8       [ ]         DGRAM                     2532      /dev/log
unix   2       [ ACC ]     STREAM     LISTENING      3061      /var/run/mysqld/mysqld.sock
unix   2       [ ]         DGRAM                     3066      /var/run/thd.socket
unix   3       [ ]         STREAM     CONNECTED      2612
unix   3       [ ]         STREAM     CONNECTED      3663
unix   2       [ ]         DGRAM                     2536
unix   2       [ ]         DGRAM                     3626

顯示所有tcp相關端口:

復制代碼
root@raspberrypi:~# netstat -at
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address           Foreign Address         State
tcp        0      0 *:mysql                 *:*                     LISTEN
tcp        0      0 *:http                  *:*                     LISTEN
tcp        0      0 *:ftp                   *:*                     LISTEN
tcp        0      0 *:ssh                   *:*                     LISTEN
tcp        0     52 10.2.58.80:ssh          nihaopc.sohu-inc.:58688 ESTABLISHED
復制代碼

顯示所有連接的統計信息:

復制代碼
root@raspberrypi:~# netstat -s
Ip:
    2363 total packets received
    0 forwarded
    0 incoming packets discarded
    2348 incoming packets delivered
    1383 requests sent out
    12 dropped because of missing route
Icmp:
    0 ICMP messages received
    0 input ICMP message failed.
    ICMP input histogram:
    0 ICMP messages sent
    0 ICMP messages failed
    ICMP output histogram:
Tcp:
    141 active connections openings
    1 passive connection openings
    0 failed connection attempts
    70 connection resets received
    1 connections established
    708 segments received
    978 segments send out
    8 segments retransmited
    0 bad segments received.
    70 resets sent
Udp:
    395 packets received
    0 packets to unknown port received.
    0 packet receive errors
    397 packets sent
UdpLite:
TcpExt:
    2 delayed acks sent
    213 packets directly queued to recvmsg prequeue.
    36114 bytes directly received in process context from prequeue
    35 packet headers predicted
    239 acknowledgments not containing data payload received
    2 congestion windows recovered without slow start after partial ack
    8 other TCP timeouts
    70 connections reset due to early user close
    TCPRcvCoalesce: 3
    TCPOFOQueue: 91
IpExt:
    InNoRoutes: 7
    InMcastPkts: 41
    InBcastPkts: 1204
    InOctets: 428992
    OutOctets: 116913
    InMcastOctets: 1744
    InBcastOctets: 253841
復制代碼


好的!由於某些原因如果你不想解析netstat 輸出的主機、端口和用戶名稱的話 

1
root @raspberrypi :~# netstat -an

好,你可能需要獲取的 netstat 持續輸出的動態信息,通過傳遞中斷輸出指令 (ctrl + c)來停止。

1
root @raspberrypi :~# netstat -c

  

43. 命令: nslookup

網絡實用程序,用於獲得互聯網服務器的信息。顧名思義,該實用程序將發現通過查詢 DNS 域的名稱服務器信息。

1
root @raspberrypi :~# nslookup

45.命令: uptime

你連接到你的 Linux 服務器時發現一些不尋常或惡意的東西,你會做什么?猜測......不,絕不!你可以運行uptime來驗證當服務器無人值守式到底發生了什么事情。

1
2
root @raspberrypi :~# uptime
  04 : 09 : 59  up  7  min,   1  user,  load average:  0.01 0.31 0.24

50. 命令:w

是否覺得命令'w'很滑稽?但是事實上不是的。它是一個命令,盡管只有一個字符長!命令"w"是uptime和who命令,以前后的順序組合在一起。

root@raspberrypi:~# w
 04:10:30 up 7 min,  1 user,  load average: 0.01, 0.27, 0.23
USER     TTY      FROM             LOGIN@   IDLE   JCPU   PCPU WHAT
root     pts/0    10.2.58.132      04:04    0.00s  0.65s  0.03s w

52. 命令: top

顯示CPU進程信息。這個命令自動刷新,默認是持續顯示CPU進程信息,除非使用了中斷指令(Ctrl+c)。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
root @raspberrypi :~# top
top -  04 : 11 : 19  up  8  min,   1  user,  load average:  0.00 0.23 0.22
Tasks:   67  total,    1  running,   66  sleeping,    0  stopped,    0  zombie
%Cpu(s):   1.7  us,   0.7  sy,   0.0  ni,  97.7  id,   0.0  wa,   0.0  hi,   0.0  si,   0.0  st
KiB Mem:     448760  total,    133924  used,    314836  free,     10656  buffers
KiB Swap:    102396  total,         0  used,    102396  free,     66232  cached
 
   PID USER      PR  NI  VIRT  RES  SHR S  %CPU %MEM    TIME+  COMMAND
  2816  root       20    0   9920  6008  3032  S    1.0   1.3    0 : 04.21  python
  2922  root       20    0   4664  1356  1028  R    1.0   0.3    0 : 00.09  top
  1857  root       20    0   2012  1856  1496  S    0.3   0.4    0 : 00.64  startpar
  2539  mysql      20    0   279m  31m  5672  S    0.3   7.2    0 : 03.22  mysqld
  2818  root       20    0   9804  3260  2628  S    0.3   0.7    0 : 00.68  sshd
     1  root       20    0   2144   728   620  S    0.0   0.2    0 : 01.63  init
     2  root       20    0      0     0     0  S    0.0   0.0    0 : 00.00  kthreadd
     3  root       20    0      0     0     0  S    0.0   0.0    0 : 00.01  ksoftirqd/ 0
     5  root        0  - 20      0     0     0  S    0.0   0.0    0 : 00.00  kworker/ 0 :0H
     6  root       20    0      0     0     0  S    0.0   0.0    0 : 00.08  kworker/u: 0
     7  root        0  - 20      0     0     0  S    0.0   0.0    0 : 00.00  kworker/u:0H
     8  root        0  - 20      0     0     0  S    0.0   0.0    0 : 00.00  khelper
     9  root       20    0      0     0     0  S    0.0   0.0    0 : 00.00  kdevtmpfs
    10  root        0  - 20      0     0     0  S    0.0   0.0    0 : 00.00  netns
    11  root       20    0      0     0     0  S    0.0   0.0    0 : 00.43  kworker/ 0 : 1
    12  root       20    0      0     0     0  S    0.0   0.0    0 : 00.00  bdi- default
    13  root        0  - 20      0     0     0  S    0.0   0.0    0 : 00.00  kblockd

53. 命令: mkfs.ext4

這個命令在指定的設備上創建一個新的ext4文件系統,如果這個命令后面跟的是個錯誤的設備,那么整個設備就會被擦除和格式化,所以建議不要運行這個命令,除非你清楚自己正在干什么。

1
2
Mkfs.ext4 /dev/sda1 (sda1 block will be formatted)
mkfs.ext4 /dev/sdb1 (sdb1 block will be formatted)

  

54. vi/emac/nano 命令

vi (visual), emac, nano 是 linux 中最常用的一些編輯器。它們經常用於編輯文本,配置,… 等文件. A quick guide to work around vi and nano is, emac is a.

55. 命令: rsync

Rsync復制文件,參數-P開啟進度條。如果你已經安裝了rsync,你可以使用一個簡單的別名。

root@raspberrypi:~# alias cp='rsync -aP'

現在嘗試在終端復制一個大文件,這樣將會看到顯示剩余部分的輸出,與進度條類似。

而且,保持和維護備份是系統管理員不得不做的最重要、最無聊的工作之一。Rsync是一個用於新建和維護備份的非常好用的終端工具(也存在許多其它工具)。

1
2
3
4
5
6
7
[root @raspberry ~]$ rsync -zvr IMG_5267\ copy\= 33 \ copy\=ok.jpg ~/Desktop/
 
sending incremental file list
IMG_5267 copy= 33  copy=ok.jpg
 
sent  2883830  bytes  received  31  bytes   5767722.00  bytes/sec
total size is  2882771   speedup is  1.00

 

注意: -z表示壓縮, -v表示詳細信息,-r表示遞歸。

56. 命令: free

跟蹤內存的使用和資源一樣重要,就像管理員執行的任何其它任務,可以使用 'free' 命令來在這里救援.

1
2
3
4
5
root @raspberrypi :/opt/labpark# free
              total       used       free     shared    buffers     cached
Mem:         448760      134304      314456           0       10664       66648
-/+ buffers/cache:       56992      391768
Swap:        102396           0      102396

以可讀的格式顯示,檢查當前內存使用

1
2
3
4
5
root @raspberrypi :/opt/labpark# free -h
              total       used       free     shared    buffers     cached
Mem:          438M       131M       307M         0B        10M        65M
-/+ buffers/cache:        55M       382M
Swap:          99M         0B        99M

設定 時間間隔 后 ,持續檢查 使用狀態

1
2
3
4
5
6
7
8
9
10
root @raspberrypi :/opt/labpark# free -s  3
              total       used       free     shared    buffers     cached
Mem:         448760      134552      314208           0       10680       66652
-/+ buffers/cache:       57220      391540
Swap:        102396           0      102396
 
              total       used       free     shared    buffers     cached
Mem:         448760      134552      314208           0       10680       66652
-/+ buffers/cache:       57220      391540
Swap:        102396           0      102396

57. mysqldump 命令

好了,現在你從名字上就能明白這個命令所代表的作用。mysqldump 命令會轉儲(備份)數據庫的全部或特定一部分數據到一個給定的文件中。例如:

[root@raspberry~]$ mysqldump -u root -p --all-databases > /home/server/Desktop/backupfile.sql

注意: mysqldump 需要 MySQL 在運行中並且有正確的授權密碼。我們在 用mysqldump命令備份數據庫中討論了一些有用的 “mysqldump” 命令用法。

58. mkpasswd 命令

根據指定的長度,產生一個難猜的隨機密碼。

1
2
3
4
[root @raspberry  ~]$ mkpasswd -l  10
zI4+Ybqfx9
[root @raspberry  ~]$ mkpasswd -l  20
w0Pr7aqKk&hmbmqdrlmk

注意: -l 10 產生一個10個字符的隨機密碼,而-l 20 產生 20個字符的密碼,它可以設置為任意長度來取得所希望的結果。這個命令很有用,經常在腳本語言里使用來產生隨機的密碼。你可能需要 yum 或 apt ‘expect’ 包來使用這個命令。

1
2
3
apt-get install expect
//或者
yum  install expect

 

59. Command: paste

合並兩個或多個文本文件,按行來進行合並。示例。如果 a1.txt 的內容是:

root@raspberrypi:/opt/labpark# cat a1.txt
1
2
3
4
5

如果 a2.txt 的內容是:

1
2
3
4
5
6
7
root @raspberrypi :/opt/labpark# cat a2.txt
         a
         b
                 c
         d
         e
         f

  合並a1.txt, a2.txt 兩個或多個文本文件,按行來進行合並.輸出到 a3.txt 文件之后查看a3.txt

1
2
3
4
5
6
7
8
root @raspberrypi :/opt/labpark# paste a1.txt a2.txt > a3.txt
root @raspberrypi :/opt/labpark# cat a3.txt
1                a
2                b
3                        c
4                d
5                e
                 f

60.Command: lsof

lsof 是"list open files("列表中打開的文件") 的縮寫,顯示您的系統當前已打開的所有文件。這是非常有用的對於想找出哪些進程使用某一特定文件,或顯示為單個進程打開所有文件。一些有用的 10 個lsof 命令示例,你可能會感興趣閱讀。

這里並沒有結束,系統管理員會很多東西,為你提供漂亮的界面,服務於你的工作。系統管理實際上是學習和實現的一門優雅的藝術。我們會盡力給你介紹 linux 專業人員必須了解的知識以及一些其他必要東西,linux本身是基礎的,簡單的。深入理解是不斷學習的過程。


免責聲明!

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



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