1,從當前目錄下的文件中找到一個字符串linux
grep -rn "hello,world!" * * : 表示當前目錄全部文件,也能夠是某個文件名 -r 是遞歸查找 -n 是顯示行號 -R 查找全部文件包含子目錄 -i 忽略大小寫 下面是一些有意思的命令行參數: grep -i pattern files :不區分大小寫地搜索。默認狀況區分大小寫, grep -l pattern files :只列出匹配的文件名, grep -L pattern files :列出不匹配的文件名, grep -w pattern files :只匹配整個單詞,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’), grep -C number pattern files :匹配的上下文分別顯示[number]行, grep pattern1 | pattern2 files :顯示匹配 pattern1 或 pattern2 的行, grep pattern1 files | grep pattern2 :顯示既匹配 pattern1 又匹配 pattern2 的行。 這裏還有些用於搜索的特殊符號: \< 和 \> 分別標註單詞的開始與結尾。 例如: grep man * 會匹配 ‘Batman’、‘manic’、‘man’等, grep '\<man' * 匹配‘manic’和‘man’,但不是‘Batman’, grep '\<man\>' 只匹配‘man’,而不是‘Batman’或‘manic’等其餘的字符串。 '^':指匹配的字符串在行首, '$':指匹配的字符串在行尾,
2,vi操做shell
1.跳到文本的最後一行:按「G」,即「shift+g」 2.跳到最後一行的最後一個字符 : 先重複1的操做即按「G」,以後按「$」鍵,即「shift+4」。 3.跳到第一行的第一個字符:先按兩次「g」, 4.跳轉到當前行的第一個字符:在當前行按「0」。
3,curl post json請求json
curl -l -H "Content-type: application/json" -X POST -d '{"phone":"13521389587","password":"test"}' http://domain/apis/users.json
4,find 命令ubuntu
1.命令格式: find pathname -options [-print -exec -ok] 2.命令功能: 用於在文件樹中查找文件,並做出相應的處理。 3.命令參數: pathname: find 命令所查找的目錄路徑。譬如用 . 來表示當前目錄,用 / 來表示系統根目錄。 -print: find 命令將匹配的文件輸出到標準輸出。 -exec: find 命令對匹配的文件執行該參數所給出的 shell 命令,相應命令的形式爲 ’command‘ {} \; ,注意 {} 和 「 \;」 之間的空格。 -ok: 和 -exec 的做用相同,只不過以一種更爲安全的模式來執行該參數所給出的 shell 命令,在執行每個命令以前,都會給出提示,讓用戶來肯定是否執行功能。 4.命令選項: -name 按照文件名查找文件 -perm 按照文件權限來查找文件 -prune 使用這一選項可使find 命令不在當前指定的目錄中查找,若是同時使用 -depth 選項,那麼 -prune 將被 find 命令忽略 -user 按照文件屬主來查找文件 -group 按照文件所屬的組來查找文件 -mtime -n +n 按照文件的更改時間來查找文件, - n 表示更改時間距如今 n 天之內, + n 表示文件更改時間距如今 n 天之前。 find 命令還有 -atime和-ctime 選項,但他們都和 -m time 選項相似。 -nogroup 查找無有效所屬組的文件,即該文件所屬的組在 /etc/groups 中不存在。 -nouser 查找無有效屬主的文件,即該文件的屬主在 /etc/passwd 中不存在。 -newer file1 ! file2 查找更改時間比文件 file1 新但比文件 file2 舊的文件。 -type 查找某一類型的文件,諸如: b 塊設備文件 d 目錄 c 字符設備文件 p 管道文件 l 符號連接文件 f 普通文件 -size n:[c] 查找文件長度爲 n 塊的文件,帶有 c 時表示文件長度以字節計。 -depth:在查找文件時,首先查找當前目錄中的文件,而後再在其子目錄中查找。 -fstype 查找位於某一類型文件系統中的文件,這些文件系統類型一般能夠在配置文件 /etc/fstab 中找到,該配置文件中包含了本系統中有關文件系統的信息。 -mount 在查找文件是不跨越文件系統mount點 -follow 若是find 命令遇到符號連接文件,就跟蹤至連接所指向的文件。 -cpio 對匹配的文件使用cpio命令,將這些文件備份到磁帶設備中。 另外,下面三個的區別: -amin n 查找系統中最後N分鐘訪問的文件 -atime n 查找系統中最後 n*24 小時訪問的文件 -cmin n 查找系統中最後 N 分鐘被改變文件狀態的文件 -ctime n 查找系統中最後 n*24小時被改變文件狀態的文件 -mmin n 查找系統中最後 N 分鐘被改變文件數據的文件 -mtime n 查找系統中最後 n*24 小時被改變文件數據的文件 5.使用實例: 實例1:查找指定時間內修改過的文件 命令: find -atime -2 查找48小時內修改過的文件 實例2:根據關鍵字查找 命令: find . -name "*.log" 在當前目錄查找以 .log 結尾的文件。 「.」 表明當前目錄 實例3:按照目錄或文件的權限來查找文件 命令: find /opt/soft/test -perm 777 查找/opt/soft/test 目錄下, 權限爲 777 的文件 實例4:按照類型查找 命令: find . -type f -name "*.log" 查找當前目錄中以 .log 結尾的 普通文件 實例5:查找當前全部目錄並排序 命令: find . -type d | sort 組合命令,其實只要知道 find [PATH] [option] [argument] 就能夠了, 「| 管道」 「sort」 命令隨時能夠跟任何命令組合使用。 實例6:按大小查找文件 命令: find . -size +1000c -print
5,統計目錄下的文件數centos
ls | wc -l
6,查看當前進程打開了多少句柄數api
lsof -n|awk '{print $2}'|sort|uniq -c|sort -nr|more
比較準一點的是安全
lsof -p 進程id > openfiles.log
或者是查看目錄 /proc/pid/fdapp
7,防止火牆 centos 7 dom
firewall-cmd --list-ports firewall-cmd --reload #重啓firewall systemctl stop firewalld.service #中止firewall systemctl disable firewalld.service #禁止firewall開機啓動 firewall-cmd --state #查看默認防火牆狀態(關閉後顯示notrunning,開啓後顯示running)
8,查看linux上下文切換curl
首先安裝sysstat:yum install sysstat //使用的是fedora,ubuntu/debian使用apg-get
pidstat -w -G testp 1 10 //根據進程名監控上下文切換
pidstat -w -p 48863 1 10 //根據PID監控上下文切換
平均時間: UID PID cswch/s nvcswch/s Command
平均時間: 0 48770 2.53 2.78 testp
cswch/s: 每秒任務主動(自願的)切換上下文的次數,當某一任務處於阻塞等待時,將主動讓出本身的CPU資源。
nvcswch/s: 每秒任務被動(不自願的)切換上下文的次數,CPU分配給某一任務的時間片已經用完,所以將強迫該進程讓出CPU的執行權。