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 命令輸出:
- d (代表了是目錄).
- rwxr-xr-x 是文件或者目錄對所屬用戶,同一組用戶和其它用戶的權限。
- 上面例子中第一個ravisaive 代表了文件文件屬於用戶ravisaive
- 上面例子中的第二個ravisaive代表了文件文件屬於用戶組ravisaive
- 4096 代表了文件大小為4096字節.
- May 8 01:06 代表了文件最后一次修改的日期和時間.
- 最后面的就是文件/文件夾的名字
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
- “Linux“: 機器的內核名
- “tecmint“: 機器的節點名
- “3.8.0-19-generic“: 內核發布版本
- “#30-Ubuntu SMP“: 內核版本
- “i686“: 處理器架構
- “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
|
注意:您還可以使用以下選項:
- -w 搜索單詞 (egrep -w ‘word1|word2‘ /path/to/file).
- -c 用於統計滿足要求的行 (i.e., total number of times the pattern matched) (grep -c ‘word‘ /path/to/file).
- –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本身是基礎的,簡單的。深入理解是不斷學習的過程。