編譯地址:8 Linux Commands Every Developer Should Know
原文地址:
http://www.vaikan.com/8-linux-commands-every-developer-should-know/
每個(gè)程序員纠拔,在職業(yè)生涯的某個(gè)時(shí)刻,總會(huì)發(fā)現(xiàn)自己需要知道一些Linux方面的知識(shí)聚请。我并不是說你應(yīng)該成為一個(gè)Linux專家,我的意思是龄恋,當(dāng)面對(duì)linux命令行任務(wù)時(shí),你應(yīng)該能很熟練的完成挖息。事實(shí)上鞭呕,學(xué)會(huì)了下面8個(gè)命令珊擂,我基本上能完成任何需要完成的任務(wù)。
注意:下面的每個(gè)命令都有十分豐富的文檔說明用含。這篇文章并不是來詳盡的展示每個(gè)命令的各種功用的。我在這里要講的是這幾個(gè)最常用的命令的最常見用法。如果你對(duì)linux命令并不是很了解义辕,你想找一些這方面的資料學(xué)習(xí)灌砖,那這篇文章將會(huì)給你一個(gè)基本的指導(dǎo)善炫。
讓我們從處理一些數(shù)據(jù)開始宪萄。假設(shè)我們有兩個(gè)文件,分別記錄的訂單清單和訂單處理結(jié)果狰右。
order.out.log
8:22:19 111, 1, Patterns of Enterprise Architecture, Kindle edition, 39.99
8:23:45 112, 1, Joy of Clojure, Hardcover, 29.99
8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99
order.in.log
8:22:20 111, Order Complete
8:23:50 112, Order sent to fulfillment
8:24:20 113, Refund sent to processing
cat
cat – 連接文件班利,并輸出結(jié)果
cat
命令非常的簡(jiǎn)單,你從下面的例子可以看到馒稍。
jfields$ cat order.out.log
8:22:19 111, 1, Patterns of Enterprise Architecture, Kindle edition, 39.99
8:23:45 112, 1, Joy of Clojure, Hardcover, 29.99
8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99
就像它的說明描述的皿哨,你可以用它來連接多個(gè)文件。
jfields$ cat order.*
8:22:20 111, Order Complete
8:23:50 112, Order sent to fulfillment
8:24:20 113, Refund sent to processing
8:22:19 111, 1, Patterns of Enterprise Architecture, Kindle edition, 39.99
8:23:45 112, 1, Joy of Clojure, Hardcover, 29.99
8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99
如果你想看這些log文件的內(nèi)容纽谒,你可以把它們連接起來并輸出到標(biāo)準(zhǔn)輸出上证膨,就是上面的例子展示的。這很有用鼓黔,但輸出的內(nèi)容可以更有邏輯些央勒。
sort
sort – 文件里的文字按行排序
此時(shí)sort
命令顯然是你最佳的選擇。
jfields$ cat order.* | sort
8:22:19 111, 1, Patterns of Enterprise Architecture, Kindle edition, 39.99
8:22:20 111, Order Complete
8:23:45 112, 1, Joy of Clojure, Hardcover, 29.99
8:23:50 112, Order sent to fulfillment
8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99
8:24:20 113, Refund sent to processing
就像上面例子顯示的澳化,文件里的數(shù)據(jù)已經(jīng)經(jīng)過排序崔步。對(duì)于一些小文件,你可以讀取整個(gè)文件來處理它們缎谷,然而井濒,真正的log文件通常有大量的內(nèi)容,你不能不考慮這個(gè)情況列林。此時(shí)你應(yīng)該考慮過濾出某些內(nèi)容瑞你,把cat
、sort
后的內(nèi)容通過管道傳遞給過濾工具希痴。
grep
grep, egrep, fgrep – 打印出匹配條件的文字行
假設(shè)我們只對(duì)Patterns of Enterprise Architecture這本書的訂單感興趣者甲。使用grep
,我們能限制只輸出含有Patterns
字符的訂單砌创。
jfields$ cat order.* | sort | grep Patterns
8:22:19 111, 1, Patterns of Enterprise Architecture, Kindle edition, 39.99
8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99
假設(shè)退款訂單113出了一些問題虏缸,你希望查看所有相關(guān)訂單——你又需要使用grep
了。
jfields$ cat order.* | sort | grep ":\d\d 113, "
8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99
8:24:20 113, Refund sent to processing
你會(huì)發(fā)現(xiàn)在grep
上的匹配模式除了“113”外還有一些其它的東西嫩实。這是因?yàn)?13還可以匹配上書目或價(jià)格刽辙,加上額外的字符后,我們可以精確的搜索到我們想要的東西甲献。
現(xiàn)在我們已經(jīng)知道了退貨的詳細(xì)信息宰缤,我們還想知道日銷售和退款總額。但我們只關(guān)心Patterns of Enterprise Architecture這本書的信息竟纳,而且只關(guān)心數(shù)量和價(jià)格撵溃。我現(xiàn)在要做到是切除我們不關(guān)心的任何信息疚鲤。
cut
cut – 刪除文件中字符行上的某些區(qū)域
又要使用grep
锥累,我們用grep
過濾出我們想要的行。有了我們想要的行信息集歇,我們就可以把它們切成小段桶略,刪除不需要的部分?jǐn)?shù)據(jù)。
jfields$ cat order.* | sort | grep Patterns
8:22:19 111, 1, Patterns of Enterprise Architecture, Kindle edition, 39.99
8:24:19 113, -1, Patterns of Enterprise Architecture, Kindle edition, 39.99
jfields$ cat order.* | sort | grep Patterns | cut -d"," -f2,5
1, 39.99
-1, 39.99
現(xiàn)在,我們把數(shù)據(jù)縮減為我們計(jì)算想要的形式际歼,把這些數(shù)據(jù)粘貼到Excel里立刻就能得到結(jié)果了惶翻。
cut
是用來消減信息、簡(jiǎn)化任務(wù)的鹅心,但對(duì)于輸出內(nèi)容吕粗,我們通常會(huì)有更復(fù)雜的形式。假設(shè)我們還需要知道訂單的ID旭愧,這樣可以用來關(guān)聯(lián)相關(guān)的其他信息颅筋。我們用cut
可以獲得ID信息,但我們希望把ID放到行的最后输枯,用單引號(hào)包上议泵。
sed
sed – 一個(gè)流編輯器。它是用來在輸入流上執(zhí)行基本的文本變換桃熄。
下面的例子展示了如何用sed
命令變換我們的文件行先口,之后我們?cè)谠儆?code>cut移除無用的信息。
jfields$ cat order.* | sort | grep Patterns \
>| sed s/"[0-9\:]* \([0-9]*\)\, \(.*\)"/"\2, '\1'"/
1, Patterns of Enterprise Architecture, Kindle edition, 39.99, '111'
-1, Patterns of Enterprise Architecture, Kindle edition, 39.99, '113'
lmp-jfields01:~ jfields$ cat order.* | sort | grep Patterns \
>| sed s/"[0-9\:]* \([0-9]*\)\, \(.*\)"/"\2, '\1'"/ | cut -d"," -f1,4,5
1, 39.99, '111'
-1, 39.99, '113'
我們對(duì)例子中使用的正則表達(dá)式多說幾句瞳收,不過也沒有什么復(fù)雜的碉京。正則表達(dá)式做了下面幾種事情:
- 刪除時(shí)間戳
- 捕捉訂單號(hào)
- 刪除訂單號(hào)后的逗號(hào)和空格
- 捕捉余下的行信息
里面的引號(hào)和反斜杠有點(diǎn)亂,但使用命令行時(shí)必須要用到這些缎讼。
一旦捕捉到了我們想要的數(shù)據(jù)收夸,我們可以使用\1 & \2
來存儲(chǔ)它們,并把它們輸出成我們想要的格式血崭。我們還在其中加入了要求的單引號(hào)卧惜,為了保持格式統(tǒng)一,我們還加入了逗號(hào)夹纫。最后咽瓷,用cut
命令把不必要的數(shù)據(jù)刪除。
現(xiàn)在我們有麻煩了舰讹。我們上面已經(jīng)演示了如何把log文件消減成更簡(jiǎn)潔的訂單形式茅姜,但我們的財(cái)務(wù)部門需要知道訂單里一共有哪些書。
uniq
uniq – 刪除重復(fù)的行
下面的例子展示了如何過濾出跟書相關(guān)的交易月匣,刪除不需要的信息钻洒,獲得一個(gè)不重復(fù)的信息。
看起來這是一個(gè)很簡(jiǎn)單的任務(wù)锄开。
這都是很好用的命令素标,但前提是你要能找到你想要的文件。有時(shí)候你會(huì)發(fā)現(xiàn)一些文件藏在很深的文件夾里萍悴,你根本不知道它們?cè)谀耐吩狻5绻闶侵滥阋獙ふ业奈募拿值脑捲⒚猓@對(duì)你就不是個(gè)問題了。
find
find – 在文件目錄中搜索文件
在上面的例子中我們處理了order.in.log
和order.out.log
這兩個(gè)文件计维。這兩個(gè)文件放在我的home目錄里的袜香。下面了例子將向大家展示如何在一個(gè)很深的目錄結(jié)構(gòu)里找到這樣的文件。
jfields$ find /Users -name "order*"
Users/jfields/order.in.log
Users/jfields/order.out.log
find
命令有很多其它的參數(shù)鲫惶,但99%的時(shí)間里我只需要這一個(gè)就夠了蜈首。
簡(jiǎn)單的一行,你就能找到你想要的文件欠母,然后你可以用cat
查看它疾就,用cut
修剪它。但文件很小時(shí)艺蝴,你用管道把它們輸出到屏幕上是可以的猬腰,但當(dāng)文件大到超出屏幕時(shí),你也許應(yīng)該用管道把它們輸出給less
命令猜敢。
less
less – 在文件里向前或向后移動(dòng)
讓我們?cè)倩氐胶?jiǎn)單的 cat | sort
例子中來姑荷,下面的命令就是將經(jīng)過合并、排序后的內(nèi)容輸出到less
命令里缩擂。在 less
命令鼠冕,使用“/
”來執(zhí)行向前搜索,使用“胯盯?
”命令執(zhí)行向后搜索懈费。搜索條件是一個(gè)正則表達(dá)式。
jfields$ cat order* | sort | less
如果你在 less
命令里使用 /113.*
博脑,所有113訂單的信息都會(huì)高亮憎乙。你也可以試試?.*112
,所有跟訂單112相關(guān)的時(shí)間戳都會(huì)高亮叉趣。最后你可以用 ‘q
’ 來退出less
命令泞边。
linux里有很豐富的各種命令,有些是很難用的疗杉。然而阵谚,學(xué)會(huì)了前面說的這8個(gè)命令,你已經(jīng)能處理大量的log分析任務(wù)了烟具,完全不需要用腳本語言寫程序來處理它們梢什。