【Nslookup】 是一個監測網絡中DNS服務器是否能正確實現域名解析的命令行工具 正則表達式
【last】 shell
【cut】cut命令能夠從一個文本文件或者文本流中提取文本列。 express
cut -b list [-n] [file ...] cut -c list [file ...] cut -f list [-d delim][-s][file ...]
-d:後面接的是用來分隔的字符,預設是TAG 緩存
-s:表示不包括那些不含分隔符的行(這樣有利於去掉註釋和標題)
bash
【sed】
sed 是一種在線編輯器,它一次處理一行內容。處理時,把當前處理的行存儲在臨時緩衝區中,稱爲「模式空間」(pattern space),接着用sed命令處理緩衝區中的內容,處理完成後,把緩衝區的內容送往屏幕。接着處理下一行,這樣不斷重複,直到文件末尾。文件內容並無 改變,除非你使用重定向存儲輸出。Sed主要用來自動編輯一個或多個文件;簡化對文件的反覆操做;編寫轉換程序等。如下介紹的是Gnu版本的Sed 3.02。
定址
能夠經過定址來定位你所但願編輯的行,該地址用數字構成,用逗號分隔的兩個行數表示以這兩行爲起止的行的範圍(包括行數表示的那兩行)。如1,3表示1,2,3行,美圓符號($)表示最後一行。範圍能夠經過數據,正則表達式或者兩者結合的方式肯定 。
Sed命令經常使用實例 服務器
###刪除:d命令 $ sed '2d' example ##刪除example文件的第二行。 $ sed '2,$d' example ##刪除example文件的第二行到末尾全部行。 $ sed '$d' example ##刪除example文件的最後一行。 $ sed '/test/'d example ##刪除example文件全部包含test的行。
###替換:s命令 $ sed 's/test/mytest/g' example ##在整行範圍內把test替換爲mytest。若是沒有g標記,則只有每行第一個匹配的test被替換成mytest。 $ sed -n 's/^test/mytest/p' example ##(-n)選項和p標誌一塊兒使用表示只打印那些發生替換的行。也就是說,若是某一行開頭的test被替換成mytest,就打印它。 $ sed 's/^192.168.0.1/&localhost/' example ##&符號表示替換換字符串中被找到的部份。全部以192.168.0.1開頭的行都會被替換成它自已加localhost,變成192.168.0.1localhost。 $ sed -n 's/\(love\)able/\1rs/p' example ##love被標記爲1,全部loveable會被替換成lovers,並且替換的行會被打印出來。 $ sed 's#10#100#g' example ##不論什麼字符,緊跟着s命令的都被認爲是新的分隔符,因此,「#」在這裏是分隔符,代替了默認的「/」分隔符。表示把全部10替換成100。
###選定行的範圍:逗號 $ sed -n '/test/,/check/p' example ##全部在模板test和check所肯定的範圍內的行都被打印。 $ sed -n '5,/^test/p' example ##打印從第五行開始到第一個包含以test開始的行之間的全部行。 $ sed '/test/,/check/s/$/sed test/' example ##對於模板test和west之間的行,每行的末尾用字符串sed test替換。
###多點編輯:e命令 $ sed -e '1,5d' -e 's/test/check/' example ##(-e)選項容許在同一行裏執行多條命令。如例子所示,第一條命令刪除1至5行,第二條命令用check替換test。命令的執行順序對結果有影響。若是兩個命令都是替換命令,那麼第一個替換命令將影響第二個替換命令的結果。 $ sed --expression='s/test/check/' --expression='/love/d' example ##一個比-e更好的命令是--expression。它能給sed表達式賦值。
###從文件讀入:r命令 $ sed '/test/r file' example ##file裏的內容被讀進來,顯示在與test匹配的行後面,若是匹配多行,則file的內容將顯示在全部匹配行的下面。 ###寫入文件:w命令 $ sed -n '/test/w file' example ##在example中全部包含test的行都被寫入file裏。
###追加命令:a命令 $ sed '/^test/a\\--->this is a example' example ##'this is a example'被追加到以test開頭的行後面,sed要求命令a後面有一個反斜槓。
###插入:i命令 $ sed '/test/i\\ new line -------------------------' example ###若是test被匹配,則把反斜槓後面的文本插入到匹配行的前面。
###下一個:n命令 $ sed '/test/{ n; s/aa/bb/; }' example ##若是test被匹配,則移動到匹配行的下一行,替換這一行的aa,變爲bb,並打印該行,而後繼續。 ###變形:y命令 $ sed '1,10y/abcde/ABCDE/' example ##把1--10行內全部abcde轉變爲大寫,注意,正則表達式元字符不能使用這個命令。 ###退出:q命令 $ sed '10q' example-----打印完第10行後,退出sed。 ###保持和獲取:h命令和G命令 $ sed -e '/test/h' -e '$G example-----在sed處理文件的時候,每一行都被保存在一個叫模式空間的臨時緩衝區中,除非行被刪除或者輸出被取消,不然全部被處理的行都將 打印在屏幕上。接着模式空間被清空,並存入新的一行等待處理。在這個例子裏,匹配test的行被找到後,將存入模式空間,h命令將其複製並存入一個稱爲保 持緩存區的特殊緩衝區內。第二條語句的意思是,當到達最後一行後,G命令取出保持緩衝區的行,而後把它放回模式空間中,且追加到如今已經存在於模式空間中 的行的末尾。在這個例子中就是追加到最後一行。簡單來講,任何包含test的行都被複制並追加到該文件的末尾。 ###保持和互換:h命令和x命令 $ sed -e '/test/h' -e '/check/x' example -----互換模式空間和保持緩衝區的內容。也就是把包含test與check的行互換。
【生成隨機密碼】 網絡
cat /dev/urandom |tr -dc _A-Z-a-z-0-9 | head -c${1:-6};echo;
head:將每一個文件的前十行打印到標準輸出 dom
head [Option] ... [File]... 編輯器
-c N: 打印前N個bytes 工具
-n N:打印前N行
• sort 語法:[root @test /root ]# sort [-t 分隔符] [(+起始)(-結束)] [-nru] 參數說明: -t 分隔符:使用分隔符來隔開不一樣區間,預設是 tab +start -end:由第 start 區間排序到 end 區間 -n :使用『純數字』排序(不然就會以文字型態來排序) -r :反向排序 -u :相同出現的一行,只列出一次! 範例:[root @test /root]# cat /etc/passwd | sort將列出來的我的帳號排序! [root @test /root]# cat /etc/passwd | sort -t: +2n將我的帳號中,以使用者 ID 來排序(以 : 來分隔,第三個爲 ID ,但第一個代號爲 0 之故) [root @test /root]# cat /etc/passwd | sort -t: +2nr反相排序囉! • wc 語法:[root @test /root ]# wc [-lmw] 參數說明: -l :多少行 -m :多少字符 -w :多少字 範例:[root @test /root]# cat /etc/passwd | wc -l這個文件裏頭有多少行? [root @test /root]# cat /etc/passwd | wc -w這個文件裏頭有多少字!? • uniq這個指令用來將『重複的行刪除掉只顯示一個』 語法:[root @test /root ]# uniq 範例:[root @test /root]# last | cut -d" " -f1 | sort | uniq • tee命令重定向到文件的同時將數據顯示在屏幕上 語法:[root @test /root ]# last | tee last.list | cut -d " " -f1 範例:[root @test /root]# last | tee last.list | cut -d " " -f1 • tr 語法:[root @test /root ]# tr [-ds] SET1 參數說明: -d :刪除 SET1 這個字符串 -s :取代掉重複的字符! 範例:[root @test /root]# last | tr '[a-z]' '[A-Z]' <==將小寫改爲大寫 [root @test /root]# cat /etc/passwd | tr -d : <== : 這個符號在 /etc/passwd 中不見了! [root @test /root]# cat /home/test/dostxt | tr -d '\r' > dostxt-noM • split 語法:[root @test /root ]# split [-bl] 輸入文件 輸出文件前導字符 參數說明: -b :以文件 size 來分 -l :以行數來分 範例:[root @test /root]# split -l 5 /etc/passwd test <==會產生 testaa, testab, testac... 等等的文件 說明:在 Linux 底下就簡單的多了!你要將文件分割的話,那麼就使用 -b size 來將一個分割的文件限制其大小,若是是行數的話,那麼就使用 -l line 來分割! 管線命令在 bash 的連續的處理程序中是至關重要的!另外,在 log file 的分析當中也是至關重要的一環。 管道輸送到一個命令的標準輸入可使用標準輸入參數」-「 進行更仔細的控制.如cat命令的示例 eg: sort mylist | more sort mylist | cat –n | lpr pwd | cat – mylist | lpr