xargs 是給命令返臘傳遞參數(shù)的一個過濾器,也是組合多個命令的一個工具,它能夠捕獲一個命令的輸出,然后傳遞給另外一個命令。之所以會用到這個命令,關(guān)鍵是由于 很多命令不支持笑世纖管道來傳遞參數(shù) ,而日常工作中就有這個需要,所以就有了 xargs 命令。
創(chuàng)新互聯(lián)是一家專業(yè)提供柴桑企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站建設(shè)、成都做網(wǎng)站、H5技術(shù)、小程序制作等業(yè)務(wù)。10年已為柴桑眾多企業(yè)、政府機構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)絡(luò)公司優(yōu)惠進行中。
我們經(jīng)常會用grep命令在文件中查找需要的內(nèi)容,比如現(xiàn)在一個文件夾里面有9個文件,有三種格式txt, csv和gz壓縮文件。
123里面存的內(nèi)容都一樣為
456里面存的內(nèi)容也一樣為
789里面存的都是
如果我現(xiàn)在要從所有的文件里面找“apple”
我會得到下面的結(jié)果,你會發(fā)現(xiàn) grep不能從gz文件中查找內(nèi)容
zgrep 這個命令可以解決這個問題,這樣就不需要先解壓然后再去查找了
會得到如下結(jié)果,顯示了所有文件格式中找到的“apple”,并且顯示了匹配的行號
如果只想在符合某種特征的文件中找你感興趣的內(nèi)容呢?比如在文件名中包含123的文件中查找“apple”。這時候就需要管道了,你需要先找到這樣的文件然后再從中找“apple”
第一步找到名字中包含123的文件
會得到文件名中包含123的所有文件
第二步查找“apple”
然后我們再來從中找“apple”,你會發(fā)現(xiàn)下面這條命令不work,你啥都得不到
這就是我們開篇提到的, 很多命令不支持管道來傳遞參數(shù)。 這個時候 xargs 就派上用場了
同時用上 zgrep ,這碰仿樣gz文件也一起找了
那么,如果我們想從某一種特定格式的文件中(比如csv文件)找特定的內(nèi)容該怎么做呢?大家應(yīng)該能觸類旁通,舉一反三了吧!
Linux xargs grep zgrep命令
ps 命令的作用是顯示進程信息的;
| 符號,是個管道符號,表示ps 和 grep 命令同時執(zhí)行;
grep 命令是查找(Global Regular Expression Print),能使用正則表達式搜索文本,然后把匹配的行顯示出來;
ps命令有一些參數(shù):
-e : 顯示所有進程
-f : 全格式
-h : 不顯示標題
-l : 長格式
-w : 寬輸出
a :顯示終端上的所有進程,包括其他用戶的進程。
r :只顯示正在運行的進程。
u :以用戶為主的格式來顯示程序狀況。
x :顯示所有程序,不以終端機來區(qū)分。
結(jié)果信息從前到后依次是:
UID PID PPID C STIME TTY TIME CMD
zzw 14124 13991 0 00:38 pts/0 00:00:00 grep –color=auto dae
Linux中的top命令顯示系統(tǒng)上正在運行的進程。它是系統(tǒng)管理員最重要的工具之一。被廣泛用于監(jiān)視服務(wù)器的負載。top命令是一個交互命令。在運行top的時候還可以運行很多命令。
N – 以 PID 的大小的順序排列表示進程列表
P – 以 CPU 占用率大小的順序排列進程列表
M – 以內(nèi)存占用率大小的順序排列進程列表
q – 退出 top
h – 幫助
1 系統(tǒng)運行時間和平均負載
這些字段顯示:當前時間、系統(tǒng)已運行的時間、當前登錄用戶塵察慶的數(shù)量、相應(yīng)最近5、10和15分鐘內(nèi)的平均負載。
2 任務(wù)
第二行顯示的是任務(wù)或者進程的總結(jié)。進程可以處于不同的狀態(tài)。派握這里顯示了全部進程沒猜的數(shù)量。除此之外,還有正在運行、睡眠、停止、僵尸進程的數(shù)量(僵尸是一種進程的狀態(tài))。這些進程概括信息可以用’t’切換顯示。
3 CPU 狀態(tài)
下一行顯示的是CPU狀態(tài)。 這里顯示了不同模式下的所占CPU時間的百分比。這些不同的CPU時間表示:
us, user: 運行(未調(diào)整優(yōu)先級的) 用戶進程的CPU時間
sy,system: 運行內(nèi)核進程的CPU時間
ni,niced:運行已調(diào)整優(yōu)先級的用戶進程的CPU時間
wa,IO wait: 用于等待IO完成的CPU時間
hi:處理硬件中斷的CPU時間
si: 處理軟件中斷的CPU時間
st:這個虛擬機被hypervisor偷去的CPU時間(譯注:如果當前處于一個hypervisor下的vm,實際上hypervisor也是要消耗一部分CPU處理時間的)。
4 內(nèi)存使用
接下來兩行顯示內(nèi)存使用率,有點像’free’命令。第一行是物理內(nèi)存使用,第二行是虛擬內(nèi)存使用(交換空間)。
物理內(nèi)存顯示如下:全部可用內(nèi)存、已使用內(nèi)存、空閑內(nèi)存、緩沖內(nèi)存。相似地:交換部分顯示的是:全部、已使用、空閑和緩沖交換空間。
5 各列的意思
PID 進程ID,進程的唯一標識符
USER 進程所有者的實際用戶名。
PR 進程的調(diào)度優(yōu)先級。這個字段的一些值是’rt’。這意味這這些進程運行在實時態(tài)。
NI 進程的nice值(優(yōu)先級)。越小的值意味著越高的優(yōu)先級。
VIRT 進程使用的虛擬內(nèi)存。
RES 駐留內(nèi)存大小。駐留內(nèi)存是任務(wù)使用的非交換物理內(nèi)存大小。
SHR SHR是進程使用的共享內(nèi)存。
S 這個是進程的狀態(tài)。它有以下不同的值:
D – 不可中斷的睡眠態(tài)。
R – 運行態(tài)
S – 睡眠態(tài)
T – 被跟蹤或已停止
Z – 僵尸態(tài)
%CPU 自從上一次更新時到現(xiàn)在任務(wù)所使用的CPU時間百分比。
%MEM 進程使用的可用物理內(nèi)存百分比。
TIME+ 任務(wù)啟動后到現(xiàn)在所使用的全部CPU時間,精確到百分之一秒。
COMMAND 運行進程所使用的命令。
注意 :不同發(fā)行版的top命令在各種細節(jié)有不同,如果發(fā)現(xiàn)不同時,請讀你的幫助手冊和命令內(nèi)的幫助。)
kill、kill-15、kill-9區(qū)別:
執(zhí)行kill(默認kill -15)命令,系統(tǒng)會發(fā)送一個SIGTERM信號給對應(yīng)的程序,大部分程序接收到SIGTERM信號后,會先釋放自己的資源,然后再停止。用法kill pid。
kill -15 pid。
kill -9命令,系統(tǒng)給對應(yīng)程序發(fā)送的信號是SIGKILL,即exit。exit信號不會被系統(tǒng)阻塞,所以kill -9能順利殺掉進程。用法kill -9 pid。
tail -n 1000:顯示最后1000行
tail -n +1000:從1000行開始顯示,顯示1000行以后的
head -n 1000:顯示前面1000行
cat a.txt 顯示文件
vim xx.conf 編輯文件
打開文件后,按insert鍵進入編輯模式;編輯完后,按esc建退出編輯模式;按shift+冒號后,輸入wq保存退出,wq!保存強制退出,q不保存退出
在根目錄模糊查找名字含java的文件
服務(wù)器端常有很多壓縮過的日志文件,當需要查找日志中某些特定信息的時候,為了避免解壓文件,可以使用zgrep,zcat等命令查找、查看壓縮文件中的信息
zgrep ' 輸入你要查找的東東' /目錄 /文件 .gz 或者.log (當日)
grep ' 輸入你要查找的東東' /目錄 /文件 .gz 或者.log (非當日的壓縮文件)
例如: zgrep 'callMktCamLoad' app.log.2019-12-03-*.gz
rpm包安裝的,可以用 rpm -qa 看到,如果要查找某軟件包是否安裝,用 rpm -qa | grep "軟件或者包的名字"
以deb包安裝的,可以用 dpkg -l 看到。如果是查找指定軟件包,用 dpkg -l | grep "軟件或者包的名字"
yum方法安裝的,可以用 yum list installed 查找,如果是查找指定包,用 yum list installed | grep "軟件名或者包名"
語法:unzip 〔選項〕 壓縮文件名.zip\x0d\x0a\x0d\x0a 各選項的含義分別為:\x0d\x0a\x0d\x0a -x 文件列表 解壓縮文件,但不包括指定的file文件。\x0d\x0a\x0d\x0a -v 查看壓縮文件目錄,但不解壓。\x0d\x0a\x0d\x0a -t 測試文件有無損壞,但不解壓。\x0d\x0a\x0d\x0a -d 目錄 把壓縮文件解到指定目錄下。\x0d\x0a\x0d\x0a -z 只顯示壓縮文件的注解。\x0d\x0a\x0d\x0a -n 不覆蓋已經(jīng)存在的文件。\x0d\x0a\x0d\x0a -o 覆蓋已存在的文件且不要求用戶確認。\x0d\x0a\x0d\x0a -j 不重建文檔的目錄結(jié)構(gòu),把所有文件解壓到同一目錄下。\x0d\x0a\x0d\x0a 例1:將壓縮文件text.zip在當前目錄下解畝陸辯壓縮。\x0d\x0a\x0d\x0a $ unzip text.zip\x0d\x0a\x0d\x0a 例2:將壓縮文件text.zip在指定目錄/tmp下解壓縮,如果已有相同的文件存在,要求unzip命令不覆蓋原先的文件。\x0d\x0a\x0d\x0a $ unzip -n text.zip -d /tmp\x0d\x0a\x0d\x0a 例3:查看壓縮文件目錄,但不解壓。\x0d\x0a\x0d\x0a $ unzip -v text.zip\x0d\x0a\x0d\x0a zgrep命令\x0d\x0a\x0d\x0a 這個命令的功能是在悉敏壓縮文件中尋找匹配的正則表達式,用法和grep命令一樣,只不過操作的對象是壓縮文件。如果用戶想看看在某個壓縮文件中有沒有某一句話,便可用zgrep命令。迅缺