經常使用指令linux總結

linux的基礎操做命令:html

    常見命令:java

mannode

查看幫助文檔python

用法:man + 命令mysql

helplinux

查看指定命令的用法web

用法: 命令 --help(有空格)正則表達式

 

tabsql

linux下命令與文件名補全shell

用法:在打出不熟悉的命令或要輸入名字過長的文件名時,能夠輸入開頭幾個命令的開頭,按鍵盤TAB鍵,補全命令

whereis

查看命令的出處,包含指定命使人的文件都存在系統的各個位置

 

which

查看命令的可執行文件位置

 

history

查看本身使用多的歷史命令

 

 

    磁盤文件操做:

 

ls

查看當前目錄下的文件信息

-a 查看目錄下全部文件,包含隱藏文件(文件名以 . 開頭的是隱藏文件)

-A 查看除 . 及 .. 覺得的文件

-l  查看文件的詳細信息

-h  以優雅的方式列出文件

 

列出的信息:第一個'd'表明文件夾,還會有'l'表明連接,以' - ' 開頭的是文件

後面三個字符爲一組.'rwx'分別表明讀(4),寫(2),執行(1).前三個爲當前用戶的權限,以後的是用戶所在的用戶組的權限,最後爲其餘用戶的權限.在後面的是引用的次數

 

其餘選項:

ls python* :查看全部python開頭的文件/文件夾

ls *.py :查看以py結尾的文件

ls ?.py 查看文件名爲一個字符的py文件

ls >test.txt : 將命令的結果存到文件中

more

分頁查看文件信息

經過分頁查看文件信息,按空格翻頁.q鍵退出

cat

查看文件的全部內容

 

tail

查看指定文件的最後內容,默認查看最後十行,並監聽文件的新增內容.經常使用與監聽日誌文件

用法:tail - 選項 文件(可指定顯示的行數)

 

 

clear

清屏命令與windows同樣

pwd

查看當前終端工做的目錄

 

 

cd

切換工做的目錄

文件夾能夠是絕對路徑

也能夠是相對路徑

 

 

touch

建立文件(可是不經常使用,vi操做中能夠建立文件,而後修改)
mkdir

建立文件夾 

用法: mkdir 文件夾名

能夠級聯建立文件夾  (-v :每次建立回顯信息. -p : 指定父級文件夾,不存在就建立)

 

 

rmdir

刪除文件夾.若是文件夾在使用或者爲空,則不能刪除

rm

文件刪除(慎重操做)

-i : 已交互方式執行(每次刪除須要再次請確認)

-f : 強制刪除,忽略不存在的文件,不提示

-r : 遞歸的刪除

 

 

cp

拷貝文件

用法 : cp 源文件 目標文件

 

 

加上-rf 能夠拷貝文件夾

mv

剪切/移動文件(添加 -f 能夠移動文件夾)

用法和cp類似

tar

打包/解包:將多個文件封裝在一個文件中,打包後的文件後綴名爲.tar

-c :壓縮打包

-v : 回顯

-f : 按照文件操做方式進行操做

(通常這三個選項一塊兒用)(打包後文件依然存在)

 

 

-x : 解包打包的文件

 

 

gzip

壓縮/解壓 一般都是先打包文件而後壓縮文件

-r : 壓縮指定文件,包含文件夾

-d : 解壓

 

 

能夠看出打包後文件仍是很大的,可是壓縮後就很小了

bzip2

壓縮/解壓命令,操做同gzip

壓縮選項是 -z (不加也能夠壓縮)

 

 

 

zip/unzip

加壓/解壓命令(zip壓縮/unzip解壓)

zip 指定壓縮後的文件名(加後綴,不加均可以)  要壓縮的文件

 

 

 

unzip中操做壓縮包時(若已有文件),則會有yes(解壓),no(不解壓),all(全部替換),none(不替換),rename(重命名)

 

find

從指定目錄中查詢文件

 

 

根據大小查找

 

 

 

ln

系統文件的連接,至關於wondows中的快捷方式

連接在linux/unix中分爲軟連接,硬連接

軟連接:不佔用磁盤文件,源文件失效則連接失效

硬連接:只能連接普通文件,不能鏈接目錄

 

 

用戶權限管理:

 

whoami

查看當前登陸用戶

who

查看當前登陸用戶信息(能夠查看遠程登陸的用戶信息)

exit

退出當前終端

useradd
添加一個用戶信息

-d : 指定用戶所屬的主目錄

-m : 指定自動建立主目錄

-g : 指定組名稱

su

切換用戶  

su 切換到root用戶

su root 切換到root用戶

su ~ :切換到root用戶,並更換到/root目錄下

su -root 同上

su user 切換到用戶

su -user 切換到用戶,並更換到用戶目錄下

查看用戶組

cat /etc/group

groupadd

添加用戶組

usermod
修改用戶所在用戶組

chmod

設置權限

文件的操做有三種權限:讀r、寫w、執行x

一樣三種權限能夠經過數字表示:r 四、w 二、x 1

                                                                    100  010   001

通常能夠chmod 777 user

chmod 644 (用戶讀寫,組 讀 其餘用戶,讀)

也能夠 chmod 700

chown

修改文件所屬用戶

 

 

        系統管理

 

ps

查看系統進程 ps -ef:以標準格式展現

 

 

ps -aux : 以BSD格式展現

 

 

top

查看系統進程,相似windows中的任務管理器

 

 

kill

終止進程

在kill加選項 -9 強制殺死

 

 

遠程登陸

使用openssh

1.安裝openssh-server

apt-get install openssh-server

修改/etc/ssh/sshd.config配置

修改PermitRootLogin yes(謹慎操做,在實際中不容許root用戶登陸)

重啓服務

service sshd restart

(查看服務詳情  service sshd status)

在 xshell/secureCRT中鏈接

 

遠程文件操做

vsftp

安裝vsftp

apt-get install vsftp

修改/etc/vsftp.conf配置

 

系統信息 
arch 顯示機器的處理器架構(1) 
uname -m 顯示機器的處理器架構(2) 
uname -r 顯示正在使用的內核版本 
dmidecode -q 顯示硬件系統部件 - (SMBIOS / DMI) 
hdparm -i /dev/hda 羅列一個磁盤的架構特性 
hdparm -tT /dev/sda 在磁盤上執行測試性讀取操做 
cat /proc/cpuinfo 顯示CPU info的信息 
cat /proc/interrupts 顯示中斷 
cat /proc/meminfo 校驗內存使用 
cat /proc/swaps 顯示哪些swap被使用 
cat /proc/version 顯示內核的版本 
cat /proc/net/dev 顯示網絡適配器及統計 
cat /proc/mounts 顯示已加載的文件系統 
lspci -tv 羅列 PCI 設備 
lsusb -tv 顯示 USB 設備 
date 顯示系統日期 
cal 2007 顯示2007年的日曆表 
date 041217002007.00 設置日期和時間 - 月日時分年.秒 
clock -w 將時間修改保存到 BIOS 



關機 (系統的關機、重啓以及登出 ) 
shutdown -h now 關閉系統(1) 
init 0 關閉系統(2) 
telinit 0 關閉系統(3) 
shutdown -h hours:minutes & 按預約時間關閉系統 
shutdown -c 取消按預約時間關閉系統 
shutdown -r now 重啓(1) 
reboot 重啓(2) 
logout 註銷 

 


文件和目錄 
cd /home 進入 '/ home' 目錄' 
cd .. 返回上一級目錄 
cd ../.. 返回上兩級目錄 
cd 進入我的的主目錄 
cd ~user1 進入我的的主目錄 
cd - 返回上次所在的目錄 
pwd 顯示工做路徑 
ls 查看目錄中的文件 
ls -F 查看目錄中的文件 
ls -l 顯示文件和目錄的詳細資料 
ls -a 顯示隱藏文件 
ls *[0-9]* 顯示包含數字的文件名和目錄名 
tree 顯示文件和目錄由根目錄開始的樹形結構(1) 
lstree 顯示文件和目錄由根目錄開始的樹形結構(2) 
mkdir dir1 建立一個叫作 'dir1' 的目錄' 
mkdir dir1 dir2 同時建立兩個目錄 
mkdir -p /tmp/dir1/dir2 建立一個目錄樹 
rm -f file1 刪除一個叫作 'file1' 的文件' 
rmdir dir1 刪除一個叫作 'dir1' 的目錄' 
rm -rf dir1 刪除一個叫作 'dir1' 的目錄並同時刪除其內容 
rm -rf dir1 dir2 同時刪除兩個目錄及它們的內容 
mv dir1 new_dir 重命名/移動 一個目錄 
cp file1 file2 複製一個文件 
cp dir/* . 複製一個目錄下的全部文件到當前工做目錄 
cp -a /tmp/dir1 . 複製一個目錄到當前工做目錄 
cp -a dir1 dir2 複製一個目錄 
ln -s file1 lnk1 建立一個指向文件或目錄的軟連接 
ln file1 lnk1 建立一個指向文件或目錄的物理連接 
touch -t 0712250000 file1 修改一個文件或目錄的時間戳 - (YYMMDDhhmm) 
file file1 outputs the mime type of the file as text 
iconv -l 列出已知的編碼 
iconv -f fromEncoding -t toEncoding inputFile > outputFile creates a new from the given input file by assuming it is encoded in fromEncoding and converting it to toEncoding. 
find . -maxdepth 1 -name *.jpg -print -exec convert "{}" -resize 80x60 "thumbs/{}" \; batch resize files in the current directory and send them to a thumbnails directory (requires convert from Imagemagick) 

文件搜索 
find / -name file1 從 '/' 開始進入根文件系統搜索文件和目錄 
find / -user user1 搜索屬於用戶 'user1' 的文件和目錄 
find /home/user1 -name \*.bin 在目錄 '/ home/user1' 中搜索帶有'.bin' 結尾的文件 
find /usr/bin -type f -atime +100 搜索在過去100天內未被使用過的執行文件 
find /usr/bin -type f -mtime -10 搜索在10天內被建立或者修改過的文件 
find / -name \*.rpm -exec chmod 755 '{}' \; 搜索以 '.rpm' 結尾的文件並定義其權限 
find / -xdev -name \*.rpm 搜索以 '.rpm' 結尾的文件,忽略光驅、捷盤等可移動設備 
locate \*.ps 尋找以 '.ps' 結尾的文件 - 先運行 'updatedb' 命令 
whereis halt 顯示一個二進制文件、源碼或man的位置 
which halt 顯示一個二進制文件或可執行文件的完整路徑 



掛載一個文件系統 
mount /dev/hda2 /mnt/hda2 掛載一個叫作hda2的盤 - 肯定目錄 '/ mnt/hda2' 已經存在 
umount /dev/hda2 卸載一個叫作hda2的盤 - 先從掛載點 '/ mnt/hda2' 退出 
fuser -km /mnt/hda2 當設備繁忙時強制卸載 
umount -n /mnt/hda2 運行卸載操做而不寫入 /etc/mtab 文件- 當文件爲只讀或當磁盤寫滿時很是有用 
mount /dev/fd0 /mnt/floppy 掛載一個軟盤 
mount /dev/cdrom /mnt/cdrom 掛載一個cdrom或dvdrom 
mount /dev/hdc /mnt/cdrecorder 掛載一個cdrw或dvdrom 
mount /dev/hdb /mnt/cdrecorder 掛載一個cdrw或dvdrom 
mount -o loop file.iso /mnt/cdrom 掛載一個文件或ISO鏡像文件 
mount -t vfat /dev/hda5 /mnt/hda5 掛載一個Windows FAT32文件系統 
mount /dev/sda1 /mnt/usbdisk 掛載一個usb 捷盤或閃存設備 
mount -t smbfs -o username=user,password=pass //WinClient/share /mnt/share 掛載一個windows網絡共享 

磁盤空間 
df -h 顯示已經掛載的分區列表 
ls -lSr |more 以尺寸大小排列文件和目錄 
du -sh dir1 估算目錄 'dir1' 已經使用的磁盤空間' 
du -sk * | sort -rn 以容量大小爲依據依次顯示文件和目錄的大小 
rpm -q -a --qf '%10{SIZE}t%{NAME}n' | sort -k1,1n 以大小爲依據依次顯示已安裝的rpm包所使用的空間 (fedora, redhat類系統) 
dpkg-query -W -f='${Installed-Size;10}t${Package}n' | sort -k1,1n 以大小爲依據顯示已安裝的deb包所使用的空間 (ubuntu, debian類系統) 



用戶和羣組 
groupadd group_name 建立一個新用戶組 
groupdel group_name 刪除一個用戶組 
groupmod -n new_group_name old_group_name 重命名一個用戶組 
useradd -c "Name Surname " -g admin -d /home/user1 -s /bin/bash user1 建立一個屬於 "admin" 用戶組的用戶 
useradd user1 建立一個新用戶 
userdel -r user1 刪除一個用戶 ( '-r' 排除主目錄) 
usermod -c "User FTP" -g system -d /ftp/user1 -s /bin/nologin user1 修改用戶屬性 
passwd 修改口令 
passwd user1 修改一個用戶的口令 (只容許root執行) 
chage -E 2005-12-31 user1 設置用戶口令的失效期限 
pwck 檢查 '/etc/passwd' 的文件格式和語法修正以及存在的用戶 
grpck 檢查 '/etc/passwd' 的文件格式和語法修正以及存在的羣組 
newgrp group_name 登錄進一個新的羣組以改變新建立文件的預設羣組 

文件的權限 - 使用 "+" 設置權限,使用 "-" 用於取消 
ls -lh 顯示權限 
ls /tmp | pr -T5 -W$COLUMNS 將終端劃分紅5欄顯示 
chmod ugo+rwx directory1 設置目錄的全部人(u)、羣組(g)以及其餘人(o)以讀(r )、寫(w)和執行(x)的權限 
chmod go-rwx directory1 刪除羣組(g)與其餘人(o)對目錄的讀寫執行權限 
chown user1 file1 改變一個文件的全部人屬性 
chown -R user1 directory1 改變一個目錄的全部人屬性並同時改變改目錄下全部文件的屬性 
chgrp group1 file1 改變文件的羣組 
chown user1:group1 file1 改變一個文件的全部人和羣組屬性 
find / -perm -u+s 羅列一個系統中全部使用了SUID控制的文件 
chmod u+s /bin/file1 設置一個二進制文件的 SUID 位 - 運行該文件的用戶也被賦予和全部者一樣的權限 
chmod u-s /bin/file1 禁用一個二進制文件的 SUID位 
chmod g+s /home/public 設置一個目錄的SGID 位 - 相似SUID ,不過這是針對目錄的 
chmod g-s /home/public 禁用一個目錄的 SGID 位 
chmod o+t /home/public 設置一個文件的 STIKY 位 - 只容許合法全部人刪除文件 
chmod o-t /home/public 禁用一個目錄的 STIKY 位 



文件的特殊屬性 - 使用 "+" 設置權限,使用 "-" 用於取消 
chattr +a file1 只容許以追加方式讀寫文件 
chattr +c file1 容許這個文件能被內核自動壓縮/解壓 
chattr +d file1 在進行文件系統備份時,dump程序將忽略這個文件 
chattr +i file1 設置成不可變的文件,不能被刪除、修改、重命名或者連接 
chattr +s file1 容許一個文件被安全地刪除 
chattr +S file1 一旦應用程序對這個文件執行了寫操做,使系統馬上把修改的結果寫到磁盤 
chattr +u file1 若文件被刪除,系統會容許你在之後恢復這個被刪除的文件 
lsattr 顯示特殊的屬性 

 

打包和壓縮文件 
bunzip2 file1.bz2 解壓一個叫作 'file1.bz2'的文件 
bzip2 file1 壓縮一個叫作 'file1' 的文件 
gunzip file1.gz 解壓一個叫作 'file1.gz'的文件 
gzip file1 壓縮一個叫作 'file1'的文件 
gzip -9 file1 最大程度壓縮 
rar a file1.rar test_file 建立一個叫作 'file1.rar' 的包 
rar a file1.rar file1 file2 dir1 同時壓縮 'file1', 'file2' 以及目錄 'dir1' 
rar x file1.rar 解壓rar包 
unrar x file1.rar 解壓rar包 
tar -cvf archive.tar file1 建立一個非壓縮的 tarball 
tar -cvf archive.tar file1 file2 dir1 建立一個包含了 'file1', 'file2' 以及 'dir1'的檔案文件 
tar -tf archive.tar 顯示一個包中的內容 
tar -xvf archive.tar 釋放一個包 
tar -xvf archive.tar -C /tmp 將壓縮包釋放到 /tmp目錄下 
tar -cvfj archive.tar.bz2 dir1 建立一個bzip2格式的壓縮包 
tar -jxvf archive.tar.bz2 解壓一個bzip2格式的壓縮包 
tar -cvfz archive.tar.gz dir1 建立一個gzip格式的壓縮包 
tar -zxvf archive.tar.gz 解壓一個gzip格式的壓縮包 
zip file1.zip file1 建立一個zip格式的壓縮包 
zip -r file1.zip file1 file2 dir1 將幾個文件和目錄同時壓縮成一個zip格式的壓縮包 
unzip file1.zip 解壓一個zip格式壓縮包 

 

RPM 包 - (Fedora, Redhat及相似系統) 
rpm -ivh package.rpm 安裝一個rpm包 
rpm -ivh --nodeeps package.rpm 安裝一個rpm包而忽略依賴關係警告 
rpm -U package.rpm 更新一個rpm包但不改變其配置文件 
rpm -F package.rpm 更新一個肯定已經安裝的rpm包 
rpm -e package_name.rpm 刪除一個rpm包 
rpm -qa 顯示系統中全部已經安裝的rpm包 
rpm -qa | grep httpd 顯示全部名稱中包含 "httpd" 字樣的rpm包 
rpm -qi package_name 獲取一個已安裝包的特殊信息 
rpm -qg "System Environment/Daemons" 顯示一個組件的rpm包 
rpm -ql package_name 顯示一個已經安裝的rpm包提供的文件列表 
rpm -qc package_name 顯示一個已經安裝的rpm包提供的配置文件列表 
rpm -q package_name --whatrequires 顯示與一個rpm包存在依賴關係的列表 
rpm -q package_name --whatprovides 顯示一個rpm包所佔的體積 
rpm -q package_name --scripts 顯示在安裝/刪除期間所執行的腳本l 
rpm -q package_name --changelog 顯示一個rpm包的修改歷史 
rpm -qf /etc/httpd/conf/httpd.conf 確認所給的文件由哪一個rpm包所提供 
rpm -qp package.rpm -l 顯示由一個還沒有安裝的rpm包提供的文件列表 
rpm --import /media/cdrom/RPM-GPG-KEY 導入公鑰數字證書 
rpm --checksig package.rpm 確認一個rpm包的完整性 
rpm -qa gpg-pubkey 確認已安裝的全部rpm包的完整性 
rpm -V package_name 檢查文件尺寸、 許可、類型、全部者、羣組、MD5檢查以及最後修改時間 
rpm -Va 檢查系統中全部已安裝的rpm包- 當心使用 
rpm -Vp package.rpm 確認一個rpm包還未安裝 
rpm2cpio package.rpm | cpio --extract --make-directories *bin* 從一個rpm包運行可執行文件 
rpm -ivh /usr/src/redhat/RPMS/`arch`/package.rpm 從一個rpm源碼安裝一個構建好的包 
rpmbuild --rebuild package_name.src.rpm 從一個rpm源碼構建一個 rpm 包 



YUM 軟件包升級器 - (Fedora, RedHat及相似系統) 
yum install package_name 下載並安裝一個rpm包 
yum localinstall package_name.rpm 將安裝一個rpm包,使用你本身的軟件倉庫爲你解決全部依賴關係 
yum update package_name.rpm 更新當前系統中全部安裝的rpm包 
yum update package_name 更新一個rpm包 
yum remove package_name 刪除一個rpm包 
yum list 列出當前系統中安裝的全部包 
yum search package_name 在rpm倉庫中搜尋軟件包 
yum clean packages 清理rpm緩存刪除下載的包 
yum clean headers 刪除全部頭文件 
yum clean all 刪除全部緩存的包和頭文件 



DEB 包 (Debian, Ubuntu 以及相似系統) 
dpkg -i package.deb 安裝/更新一個 deb 包 
dpkg -r package_name 從系統刪除一個 deb 包 
dpkg -l 顯示系統中全部已經安裝的 deb 包 
dpkg -l | grep httpd 顯示全部名稱中包含 "httpd" 字樣的deb包 
dpkg -s package_name 得到已經安裝在系統中一個特殊包的信息 
dpkg -L package_name 顯示系統中已經安裝的一個deb包所提供的文件列表 
dpkg --contents package.deb 顯示還沒有安裝的一個包所提供的文件列表 
dpkg -S /bin/ping 確認所給的文件由哪一個deb包提供 



APT 軟件工具 (Debian, Ubuntu 以及相似系統) 
apt-get install package_name 安裝/更新一個 deb 包 
apt-cdrom install package_name 從光盤安裝/更新一個 deb 包 
apt-get update 升級列表中的軟件包 
apt-get upgrade 升級全部已安裝的軟件 
apt-get remove package_name 從系統刪除一個deb包 
apt-get check 確認依賴的軟件倉庫正確 
apt-get clean 從下載的軟件包中清理緩存 
apt-cache search searched-package 返回包含所要搜索字符串的軟件包名稱 



查看文件內容 
cat file1 從第一個字節開始正向查看文件的內容 
tac file1 從最後一行開始反向查看一個文件的內容 
more file1 查看一個長文件的內容 
less file1 相似於 'more' 命令,可是它容許在文件中和正向操做同樣的反向操做 
head -2 file1 查看一個文件的前兩行 
tail -2 file1 查看一個文件的最後兩行 
tail -f /var/log/messages 實時查看被添加到一個文件中的內容 



文本處理 
cat file1 file2 ... | command <> file1_in.txt_or_file1_out.txt general syntax for text manipulation using PIPE, STDIN and STDOUT 
cat file1 | command( sed, grep, awk, grep, etc...) > result.txt 合併一個文件的詳細說明文本,並將簡介寫入一個新文件中 
cat file1 | command( sed, grep, awk, grep, etc...) >> result.txt 合併一個文件的詳細說明文本,並將簡介寫入一個已有的文件中 
grep Aug /var/log/messages 在文件 '/var/log/messages'中查找關鍵詞"Aug" 
grep ^Aug /var/log/messages 在文件 '/var/log/messages'中查找以"Aug"開始的詞彙 
grep [0-9] /var/log/messages 選擇 '/var/log/messages' 文件中全部包含數字的行 
grep Aug -R /var/log/* 在目錄 '/var/log' 及隨後的目錄中搜索字符串"Aug" 
sed 's/stringa1/stringa2/g' example.txt 將example.txt文件中的 "string1" 替換成 "string2" 
sed '/^$/d' example.txt 從example.txt文件中刪除全部空白行 
sed '/ *#/d; /^$/d' example.txt 從example.txt文件中刪除全部註釋和空白行 
echo 'esempio' | tr '[:lower:]' '[:upper:]' 合併上下單元格內容 
sed -e '1d' result.txt 從文件example.txt 中排除第一行 
sed -n '/stringa1/p' 查看只包含詞彙 "string1"的行 
sed -e 's/ *$//' example.txt 刪除每一行最後的空白字符 
sed -e 's/stringa1//g' example.txt 從文檔中只刪除詞彙 "string1" 並保留剩餘所有 
sed -n '1,5p;5q' example.txt 查看從第一行到第5行內容 
sed -n '5p;5q' example.txt 查看第5行 
sed -e 's/00*/0/g' example.txt 用單個零替換多個零 
cat -n file1 標示文件的行數 
cat example.txt | awk 'NR%2==1' 刪除example.txt文件中的全部偶數行 
echo a b c | awk '{print $1}' 查看一行第一欄 
echo a b c | awk '{print $1,$3}' 查看一行的第一和第三欄 
paste file1 file2 合併兩個文件或兩欄的內容 
paste -d '+' file1 file2 合併兩個文件或兩欄的內容,中間用"+"區分 
sort file1 file2 排序兩個文件的內容 
sort file1 file2 | uniq 取出兩個文件的並集(重複的行只保留一份) 
sort file1 file2 | uniq -u 刪除交集,留下其餘的行 
sort file1 file2 | uniq -d 取出兩個文件的交集(只留下同時存在於兩個文件中的文件) 
comm -1 file1 file2 比較兩個文件的內容只刪除 'file1' 所包含的內容 
comm -2 file1 file2 比較兩個文件的內容只刪除 'file2' 所包含的內容 
comm -3 file1 file2 比較兩個文件的內容只刪除兩個文件共有的部分 




字符設置和文件格式轉換 
dos2unix filedos.txt fileunix.txt 將一個文本文件的格式從MSDOS轉換成UNIX 
unix2dos fileunix.txt filedos.txt 將一個文本文件的格式從UNIX轉換成MSDOS 
recode ..HTML < page.txt > page.html 將一個文本文件轉換成html 
recode -l | more 顯示全部容許的轉換格式 



文件系統分析 
badblocks -v /dev/hda1 檢查磁盤hda1上的壞磁塊 
fsck /dev/hda1 修復/檢查hda1磁盤上linux文件系統的完整性 
fsck.ext2 /dev/hda1 修復/檢查hda1磁盤上ext2文件系統的完整性 
e2fsck /dev/hda1 修復/檢查hda1磁盤上ext2文件系統的完整性 
e2fsck -j /dev/hda1 修復/檢查hda1磁盤上ext3文件系統的完整性 
fsck.ext3 /dev/hda1 修復/檢查hda1磁盤上ext3文件系統的完整性 
fsck.vfat /dev/hda1 修復/檢查hda1磁盤上fat文件系統的完整性 
fsck.msdos /dev/hda1 修復/檢查hda1磁盤上dos文件系統的完整性 
dosfsck /dev/hda1 修復/檢查hda1磁盤上dos文件系統的完整性 



初始化一個文件系統 
mkfs /dev/hda1 在hda1分區建立一個文件系統 
mke2fs /dev/hda1 在hda1分區建立一個linux ext2的文件系統 
mke2fs -j /dev/hda1 在hda1分區建立一個linux ext3(日誌型)的文件系統 
mkfs -t vfat 32 -F /dev/hda1 建立一個 FAT32 文件系統 
fdformat -n /dev/fd0 格式化一個軟盤 
mkswap /dev/hda3 建立一個swap文件系統 



SWAP文件系統 
mkswap /dev/hda3 建立一個swap文件系統 
swapon /dev/hda3 啓用一個新的swap文件系統 
swapon /dev/hda2 /dev/hdb3 啓用兩個swap分區 



備份 
dump -0aj -f /tmp/home0.bak /home 製做一個 '/home' 目錄的完整備份 
dump -1aj -f /tmp/home0.bak /home 製做一個 '/home' 目錄的交互式備份 
restore -if /tmp/home0.bak 還原一個交互式備份 
rsync -rogpav --delete /home /tmp 同步兩邊的目錄 
rsync -rogpav -e ssh --delete /home ip_address:/tmp 經過SSH通道rsync 
rsync -az -e ssh --delete ip_addr:/home/public /home/local 經過ssh和壓縮將一個遠程目錄同步到本地目錄 
rsync -az -e ssh --delete /home/local ip_addr:/home/public 經過ssh和壓縮將本地目錄同步到遠程目錄 
dd bs=1M if=/dev/hda | gzip | ssh user@ip_addr 'dd of=hda.gz' 經過ssh在遠程主機上執行一次備份本地磁盤的操做 
dd if=/dev/sda of=/tmp/file1 備份磁盤內容到一個文件 
tar -Puf backup.tar /home/user 執行一次對 '/home/user' 目錄的交互式備份操做 
( cd /tmp/local/ && tar c . ) | ssh -C user@ip_addr 'cd /home/share/ && tar x -p' 經過ssh在遠程目錄中複製一個目錄內容 
( tar c /home ) | ssh -C user@ip_addr 'cd /home/backup-home && tar x -p' 經過ssh在遠程目錄中複製一個本地目錄 
tar cf - . | (cd /tmp/backup ; tar xf - ) 本地將一個目錄複製到另外一個地方,保留原有權限及連接 
find /home/user1 -name '*.txt' | xargs cp -av --target-directory=/home/backup/ --parents 從一個目錄查找並複製全部以 '.txt' 結尾的文件到另外一個目錄 
find /var/log -name '*.log' | tar cv --files-from=- | bzip2 > log.tar.bz2 查找全部以 '.log' 結尾的文件並作成一個bzip包 
dd if=/dev/hda of=/dev/fd0 bs=512 count=1 作一個將 MBR (Master Boot Record)內容複製到軟盤的動做 
dd if=/dev/fd0 of=/dev/hda bs=512 count=1 從已經保存到軟盤的備份中恢復MBR內容 



光盤 
cdrecord -v gracetime=2 dev=/dev/cdrom -eject blank=fast -force 清空一個可複寫的光盤內容 
mkisofs /dev/cdrom > cd.iso 在磁盤上建立一個光盤的iso鏡像文件 
mkisofs /dev/cdrom | gzip > cd_iso.gz 在磁盤上建立一個壓縮了的光盤iso鏡像文件 
mkisofs -J -allow-leading-dots -R -V "Label CD" -iso-level 4 -o ./cd.iso data_cd 建立一個目錄的iso鏡像文件 
cdrecord -v dev=/dev/cdrom cd.iso 刻錄一個ISO鏡像文件 
gzip -dc cd_iso.gz | cdrecord dev=/dev/cdrom - 刻錄一個壓縮了的ISO鏡像文件 
mount -o loop cd.iso /mnt/iso 掛載一個ISO鏡像文件 
cd-paranoia -B 從一個CD光盤轉錄音軌到 wav 文件中 
cd-paranoia -- "-3" 從一個CD光盤轉錄音軌到 wav 文件中(參數-3) 
cdrecord --scanbus 掃描總線以識別scsi通道 
dd if=/dev/hdc | md5sum 校驗一個設備的md5sum編碼,例如一張 CD 



網絡 - (以太網和WIFI無線) 
ifconfig eth0 顯示一個以太網卡的配置 
ifup eth0 啓用一個 'eth0' 網絡設備 
ifdown eth0 禁用一個 'eth0' 網絡設備 
ifconfig eth0 192.168.1.1 netmask 255.255.255.0 控制IP地址 
ifconfig eth0 promisc 設置 'eth0' 成混雜模式以嗅探數據包 (sniffing) 
dhclient eth0 以dhcp模式啓用 'eth0' 
route -n show routing table 
route add -net 0/0 gw IP_Gateway configura default gateway 
route add -net 192.168.0.0 netmask 255.255.0.0 gw 192.168.1.1 configure static route to reach network '192.168.0.0/16' 
route del 0/0 gw IP_gateway remove static route 
echo "1" > /proc/sys/net/ipv4/ip_forward activate ip routing 
hostname show hostname of system 
host www.example.com lookup hostname to resolve name to ip address and viceversa(1) 
nslookup www.example.com lookup hostname to resolve name to ip address and viceversa(2) 
ip link show show link status of all interfaces 
mii-tool eth0 show link status of 'eth0' 
ethtool eth0 show statistics of network card 'eth0' 
netstat -tup show all active network connections and their PID 
netstat -tupl show all network services listening on the system and their PID 
tcpdump tcp port 80 show all HTTP traffic 
iwlist scan show wireless networks 
iwconfig eth1 show configuration of a wireless network card 
hostname show hostname 
host www.example.com lookup hostname to resolve name to ip address and viceversa 
nslookup www.example.com lookup hostname to resolve name to ip address and viceversa 
whois www.example.com lookup on Whois database 

 

JPS工具

jps(Java Virtual Machine Process Status Tool)是JDK 1.5提供的一個顯示當前全部java進程pid的命令,簡單實用,很是適合在linux/unix平臺上簡單察看當前java進程的一些簡單狀況。

    我想不少人都是用過unix系統裏的ps命令,這個命令主要是用來顯示當前系統的進程狀況,有哪些進程,及其 id。 jps 也是同樣,它的做用是顯示當前系統的java進程狀況,及其id號。咱們能夠經過它來查看咱們到底啓動了幾個java進程(由於每個java程序都會獨佔一個java虛擬機實例),和他們的進程號(爲下面幾個程序作準備),並可經過opt來查看這些進程的詳細啓動參數。

     使用方法:在當前命令行下打 jps(須要JAVA_HOME,沒有的話,到改程序的目錄下打) 。

jps存放在JAVA_HOME/bin/jps,使用時爲了方便請將JAVA_HOME/bin/加入到Path.

$> jps
23991 Jps
23789 BossMain
23651 Resin

 


比較經常使用的參數:

-q 只顯示pid,不顯示class名稱,jar文件名和傳遞給main 方法的參數
$>  jps -q
28680
23789
23651

-m 輸出傳遞給main 方法的參數,在嵌入式jvm上多是null

$> jps -m
28715 Jps -m
23789 BossMain
23651 Resin -socketwait 32768 -stdout /data/aoxj/resin/log/stdout.log -stderr /data/aoxj/resin/log/stderr.log

-l 輸出應用程序main class的完整package名 或者 應用程序的jar文件完整路徑名

$> jps -l
28729 sun.tools.jps.Jps
23789 com.asiainfo.aimc.bossbi.BossMain
23651 com.caucho.server.resin.Resin

-v 輸出傳遞給JVM的參數

$> jps -v
23789 BossMain
28802 Jps -Denv.class.path=/data/aoxj/bossbi/twsecurity/java/trustwork140.jar:/data/aoxj/bossbi/twsecurity/java/:/data/aoxj/bossbi/twsecurity/java/twcmcc.jar:/data/aoxj/jdk15/lib/rt.jar:/data/aoxj/jd

k15/lib/tools.jar -Dapplication.home=/data/aoxj/jdk15 -Xms8m
23651 Resin -Xss1m -Dresin.home=/data/aoxj/resin -Dserver.root=/data/aoxj/resin -Djava.util.logging.manager=com.caucho.log.LogManagerImpl -

Djavax.management.builder.initial=com.caucho.jmx.MBeanServerBuilderImpl

sudo jps看到的進程數量最全

jps 192.168.0.77

列出遠程服務器192.168.0.77機器全部的jvm實例,採用rmi協議,默認鏈接端口爲1099

(前提是遠程服務器提供jstatd服務)

注:jps命令有個地方很很差,彷佛只能顯示當前用戶的java進程,要顯示其餘用戶的仍是隻能用unix/linux的ps命令。

 

 

AWK

AWK是一個優良的文本處理工具,Linux和Unix環境中現有的功能最強大的數據處理引擎之一。

語法

awk [選項參數] 'script' var=value file(s)
或
awk [選項參數] -f scriptfile var=value file(s)
View Code

調用方式

awk 命令行
你能夠象使用普通UNIX 命令同樣使用awk,在命令行中你也可使用awk 程序設計語言,,這種方法通常只用於解決簡單的問題。固然,你也能夠在shell script 程序中引用awk 命令行甚至awk 程序腳本。

使用-f 選項調用awk 程序
awk 容許將一段awk 程序寫入一個文本文件,而後在awk 命令行中用-f 選項調用並執行這段程序。


利用命令解釋器調用awk 程序
利用UNIX 支持的命令解釋器功能,咱們能夠將一段awk 程序寫入文本文件,而後在它的第一行加上#!/bin/awk –f。
View Code

參數相關

FILENAME:awk瀏覽的文件名
FNR:awk瀏覽的文件的記錄數
FS:設置輸入域的分隔符
NF:瀏覽域的個數
NR:已讀的記錄數
OFS:輸出域分隔符
ORS:輸出記錄分隔符
RS:控制記錄分隔符
$0:指整條記錄
$1:第一個做用域及第一列
~:匹配,與==相比不是精確比較
!~:不匹配,不精確比較
==:等於,必須所有相等,精確比較
!=:不等於,精確比較
&&:邏輯與
||:邏輯或
+:匹配時表示1個或1個以上
/[0-9][0-9]+/:兩個或兩個以上數字
/[0-9][0-9]*/:一個或一個以上數字
View Code

案例

過濾/etc/passwd文件,以冒號爲分隔符,過濾出第一列
awk -F ':' '{print $1}' /etc/passwd

統計/etc/passwd文件中,一共有多少個用戶
awk '{count++;print $0;} END {print "user count is:",count} ' /etc/passwd

統計/etc/passwd文件,打印出文件名,已讀的記錄數,以冒號爲分隔符,每行瀏覽域的個數,每行記錄的內容
awk -F ':' '{print "filename:" FILENAME ",linenumber:" NR ",columns:" NF, ",linecontent:" $0}' /etc/passwd

統計/etc/passwd文件,從0開始,依次往下瀏覽,一直到最後並打印出循環了多少次
awk 'BEGIN {count=0;print "start use count is:",count} {count++;print $0;} END {print "user count is:",count} '  /etc/passwd

統計當前目錄下,全部文件總大小,並輸出到all file siz is
ll |awk 'BEGIN {size=0} {size=size+$5} END {print "all file size is:",size}'

統計當前目錄下,除去4096大小的文件外,全部文件大小的總和,輸出到all file siz is
ll |awk 'BEGIN {size=0} {if ($5 !=4096) size=size+$5} END {print "all file size is:",size}'

統計/etc/passwd文件,在每行行首從0開始記錄瀏覽行數
awk -F ':' 'BEGIN {null=0} {name[null]=$1;null++} END {for(i=0;i<NR;i++) print i,name[i]}' /etc/passwd

統計netstat -anp 狀態爲LISTEN和CONNECT的鏈接數量分別是多少
netstat -anp|awk '$6~/LISTEN|CONNECTED/{sum[$6]++} END{for (i in sum) printf "%-10s %-6s %-3s \n", i," ",sum[i]}'

計算/home目錄下,普通文件的大小,使用KB做爲單位
ls -l|awk 'BEGIN{sum=0} !/^d/{sum+=$5} END{print "total size is:",sum/1024,"KB"}'
ls -l|awk 'BEGIN{sum=0} !/^d/{sum+=$5} END{print "total size is:",int(sum/1024),"KB"}'         //int是取整的意思

統計/home目錄下不一樣用戶的普通文件的總數是多少?
ls -l|awk 'NR!=1 && !/^d/{sum[$3]++} END{for (i in sum) printf "%-6s %-5s %-3s \n",i," ",sum[i]}'   
mysql        199 
root           374 

統計/home目錄下不一樣用戶的普通文件的大小總size是多少?
ls -l|awk 'NR!=1 && !/^d/{sum[$3]+=$5} END{for (i in sum) printf "%-6s %-5s %-3s %-2s \n",i," ",sum[i]/1024/1024,"MB"}'
View Code

 

SED

SED即Stream Editor文本流編輯,是一個「非交互式」面向字符流的編輯器。能同時處理多個文件多行的內容,能夠不對原文件改動,把整個文件輸入到屏幕,能夠把只匹配到模式的內容輸入到屏幕上。還能夠對原文件改動,可是不會再屏幕上返回結果。

語法

sed [options] 'command' file(s)
或者
sed [options] -f scriptfile file(s)
View Code

選項

 -e :直接在命令行模式上進行sed動做編輯,此爲默認選項;
 -f :將sed的動做寫在一個文件內,用–f filename 執行filename內的sed動做;
 -i :直接修改文件內容;
 -n :只打印模式匹配的行;
 -r :支持擴展表達式;
 -h或--help:顯示幫助;
 -V或--version:顯示版本信息;
 -a :新增, a 的後面能夠接字串,而這些字串會在新的一行出現(目前的下一行);
 -c :取代, c 的後面能夠接字串,這些字串能夠取代 n1,n2 之間的行;
 -d ∶刪除,由於是刪除啊,因此 d 後面一般不接任何咚咚;
 -i ∶插入, i 的後面能夠接字串,而這些字串會在新的一行出現(目前的上一行);
 -p ∶列印,亦即將某個選擇的資料印出;一般 p 會與參數 sed -n 一塊兒運做;
 -s ∶取代,能夠直接進行取代的工做哩;一般這個 s 的動做能夠搭配正規表示法;
View Code

經常使用命令

a\\ 在當前行下面插入文本。
i\\ 在當前行上面插入文本。
c\\ 把選定的行改成新的文本。
d 刪除,刪除選擇的行。
D 刪除模板塊的第一行。
s 替換指定字符
h 拷貝模板塊的內容到內存中的緩衝區。
H 追加模板塊的內容到內存中的緩衝區。
g 得到內存緩衝區的內容,並替代當前模板塊中的文本。
G 得到內存緩衝區的內容,並追加到當前模板塊文本的後面。
l 列表不能打印字符的清單。
n 讀取下一個輸入行,用下一個命令處理新的行而不是用第一個命令。
N 追加下一個輸入行到模板塊後面並在兩者間嵌入一個新行,改變當前行號碼。
p 打印模板塊的行。
P(大寫) 打印模板塊的第一行。
q 退出Sed。
b lable 分支到腳本中帶有標記的地方,若是分支不存在則分支到腳本的末尾。
r file 從file中讀行。
t label if分支,從最後一行開始,條件一旦知足或者T,t命令,將致使分支到帶有標號的命令處,或者到腳本的末尾。
T label 錯誤分支,從最後一行開始,一旦發生錯誤或者T,t命令,將致使分支到帶有標號的命令處,或者到腳本的末尾。
w file 寫並追加模板塊到file末尾。 
W file 寫並追加模板塊的第一行到file末尾。 
! 表示後面的命令對全部沒有被選定的行發生做用。 
= 打印當前行號碼。 
'#' 把註釋擴展到下一個換行符之前。 
View Code

替換標記

g 表示行內全面替換。 
p 表示打印行。 
w 表示把行寫入一個文件。 
x 表示互換模板塊中的文本和緩衝區中的文本。 
y 表示把一個字符翻譯爲另外的字符(可是不用於正則表達式)
\\1 子串匹配標記
& 已匹配字符串標記
View Code

sed元字符集

^ 匹配行開始,如:/^sed/匹配全部以sed開頭的行。
$ 匹配行結束,如:/sed$/匹配全部以sed結尾的行。
. 匹配一個非換行符的任意字符,如:/s.d/匹配s後接一個任意字符,最後是d。
* 匹配0個或多個字符,如:'/*sed/'匹配全部模板是一個或多個空格後緊跟sed的行。
[] 匹配一個指定範圍內的字符,如/[ss]ed/匹配sed和Sed。 
[^] 匹配一個不在指定範圍內的字符,如:/[^A-RT-Z]ed/匹配不包含A-R和T-Z的一個字母開頭,緊跟ed的行。
\\(..\\) 匹配子串,保存匹配的字符,如s/\\(love\\)able/\\1rs,loveable被替換成lovers。
& 保存搜索字符用來替換其餘字符,如s/love/**&**/,love這成**love**。
\\< 匹配單詞的開始,如:/\\\\> 匹配單詞的結束,如/love\\>/匹配包含以love結尾的單詞的行。
x\\{m\\} 重複字符x,m次,如:/0\\{5\\}/匹配包含5個0的行。
x\\{m,\\} 重複字符x,至少m次,如:/0\\{5,\\}/匹配至少有5個0的行。
x\\{m,n\\} 重複字符x,至少m次,很少於n次,如:/0\\{5,10\\}/匹配5~10個0的行。
View Code

sed匹配模式正則

sed '5 q' /etc/passwd  #打印前5行  
sed -n '/r*t/p' /etc/passwd  #打印匹配r有0個或者多個,後接一個t字符的行  
sed -n '/.r.*/p' /etc/passwd  #打印匹配有r的行而且r後面跟任意字符  
sed -n '/o*/p' /etc/passwd  #打印o字符重複任意次  
sed -n '/o\{1,\}/p' /etc/passwd  #打印o字重複出現一次以上  
sed -n '/o\{1,3\}/p' /etc/passwd  #打印o字重複出現一次到三次之間以上  
View Code

sed對文件內容增長(-i修改源文件)

cat file.txt
Python
Django
Flask
Hello World

1. 匹配字符行的行首添加
sed '/Python/s/^/Lain /' file.txt
Lain Python
Django
Flask
Hello World

2. 匹配字符行的行尾添加
sed 's/Python/& Lain/' file.txt
Python Lain
Django
Flask
Hello World

3. 匹配字符前添加
sed 's/World/Lain &/' file.txt
Python
Django
Flask
Hello Lain World

4. 匹配字符後添加
sed 's/World/& Lain/' file.txt
Python
Django
Flask
Hello World Lain

5. 匹配行的上一行添加
sed '/Flask/i\HTML' file.txt
或者
sed '/Flask/i HTML' file.txt
Python
Django
HTML
Flask
Hello World

6. 匹配行的下一行添加
sed '/Flask/a HTML' file.txt
或者
sed '/Flask/a\HTML' file.txt
Python
Django
Flask
HTML
Hello World

7. 全部行行首添加
sed 's/^/Lain /g' file.txt
或者
sed 's/^/Lain /' file.txt
Lain Python
Lain Django
Lain Flask
Lain Hello World

8. 全部行行尾添加
sed 's/$/ Lain/' file.txt
或者
sed 's/$/ Lain/g' file.txt
Python Lain
Django Lain
Flask Lain
Hello World Lain

9.指定行添加內容
sed '1,2s/$/ Lain/g' file.txt  #1,2行行尾添加
sed '1,2s/^/# /' file.txt  #1,2行行首添加
View Code

sed對文件內容刪除(-i修改源文件)

cat file.txt
#Python web
#Django web
Flask web
Hello World web
JavaScript
PHP Nginx

1. 刪除行首是'#'的行
sed '/^#/d' file.txt
Flask web
Hello World web
JavaScript
PHP Nginx

2. 刪除行首不是'#'的行
sed '/^#/!d' file.txt
#Python web
#Django web

3. 刪除行
sed '1d' file.txt  #刪除第一行
sed '$d' file.txt  #刪除最後一行
sed '1,2d' file.txt  #刪除指定行

4. 刪除匹配字符所在的行
sed '/Hello/d' file.txt
#Python web
#Django web
Flask web
JavaScript
PHP Nginx
View Code

sed對文件內容修改(-i修改源文件)

cat file.txt
#Python web
#Django web
Flask web
Hello World web
JavaScript
PHP Nginx

1. 更換匹配字符所在行
sed '/Flask/c\LAIN' file.txt
#Python web
#Django web
LAIN
Hello World web
JavaScript
PHP Nginx

2. 更換文件中全部匹配字符
sed 's/web/core/' file.txt
#Python core
#Django core
Flask core
Hello World core
JavaScript
PHP Nginx

3. 更換匹配字符所在行的關鍵字
sed '/Flask/s@web@core@' file.txt
或者
sed '/Flask/s#web#core#' file.txt
#Python web
#Django web
Flask core
Hello World web
JavaScript
PHP Nginx

4. 替換匹配關鍵字所在行的'#'
sed '/web/s/#//' file.txt
Python web
Django web
Flask web
Hello World web
JavaScript
PHP Nginx
View Code

 

sed參考http://www.noobyard.com/article/p-clbfljkz-co.html

GREP

GREP(global search regular expression(RE) and print out the line,全面搜索正則表達式並把行打印出來)是一種強大的文本搜索工具,它能使用正則表達式搜索文本,並把匹配的行打印出來。
grep的工做方式,它在一個或多個文件中搜索字符串模板。若是模板包括空格,則必須被引用,模板後的全部字符串被看做文件名。搜索的結果被送到屏幕,不影響原文件內容。
grep可用於shell腳本,由於grep經過返回一個狀態值來講明搜索的狀態,若是模板搜索成功,則返回0,若是搜索不成功,則返回1,若是搜索的文件不存在,則返回2。咱們利用這些返回值就可進行一些自動化的文本處理工做。

語法
grep [OPTION]... PATTERN [FILE]...
匹配模式
 -E, --extended-regexp     擴展正則表達式egrep
 -F, --fixed-strings       一個換行符分隔的字符串的集合fgrep
 -G, --basic-regexp        基本正則
 -P, --perl-regexp         調用的perl正則
 -e, --regexp=PATTERN      後面根正則模式,默認無
 -f, --file=FILE           從文件中得到匹配模式
 -i, --ignore-case         不區分大小寫
 -w, --word-regexp         匹配整個單詞
 -x, --line-regexp         匹配整行
 -z, --null-data           一個 0 字節的數據行,但不是空行
 -s, --no-messages         不顯示錯誤信息
 -v, --invert-match        顯示不匹配的行
 -V, --version             顯示版本號
 --help                    顯示幫助信息
 --mmap                    use memory-mapped input if possible
View Code

控制項

輸入控制:
 -m, --max-count=NUM       匹配的最大數
 -b, --byte-offset         打印匹配行前面打印該行所在的塊號碼。
 -n, --line-number         顯示的加上匹配所在的行號
 --line-buffered           刷新輸出每一行
 -H, --with-filename       當搜索多個文件時,顯示匹配文件名前綴
 -h, --no-filename         當搜索多個文件時,不顯示匹配文件名前綴
 --label=LABEL             print LABEL as filename for standard input
 -o, --only-matching       只顯示一行中匹配PATTERN 的部分
 -q, --quiet, --silent     不顯示任何東西
 --binary-files=TYPE       假定二進制文件的TYPE 類型;TYPE 能夠是`binary', `text', 或`without-match'
 -a, --text                匹配二進制的東西
 -I                        不匹配二進制的東西
 -d, --directories=ACTION  目錄操做,讀取,遞歸,跳過
 -D, --devices=ACTION      設置對設備,FIFO,管道的操做,讀取,跳過
 -R, -r, --recursive       遞歸調用
 --include=PATTERN         只查找匹配FILE_PATTERN 的文件
 --exclude=PATTERN         跳過匹配FILE_PATTERN 的文件和目錄
 --exclude-from=FILE       跳過全部除FILE 之外的文件
 -L, --files-without-match 匹配多個文件時,顯示不匹配的文件名
 -l, --files-with-matches  匹配多個文件時,顯示匹配的文件名
 -c, --count               顯示匹配了多少次
 -Z, --null                在FILE 文件最後打印空字符

文件控制:
 -B, --before-context=NUM  打印匹配自己以及前面的幾個行由NUM控制
 -A, --after-context=NUM   打印匹配自己以及隨後的幾個行由NUM控制
 -C, --context=NUM         打印匹配自己以及隨後,前面的幾個行由NUM控制
 -NUM                      根-C的用法同樣的
 --color[=WHEN],
 --colour[=WHEN]           使用標誌高亮匹配字串;
 
 -U, --binary              使用標誌高亮匹配字串;
 -u, --unix-byte-offsets   當CR 字符不存在,報告字節偏移(MSDOS 模式)
View Code

案例

- 測試文件
cat test.txt
systemd-network:x:998:996:systemd Network Management:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
polkitd:x:997:995:User for polkitd:/:/sbin/nologin
colord:x:996:994:User for colord:/var/lib/colord:/sbin/nologin
abrt:x:173:173::/etc/abrt:/sbin/nologin
tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
unbound:x:995:993:Unbound DNS resolver:/etc/unbound:/sbin/nologin
usbmuxd:x:113:113:usbmuxd user:/:/sbin/nologin
saslauth:x:994:76:Saslauthd user:/run/saslauthd:/sbin/nologin
libstoragemgmt:x:993:990:daemon account for libstoragemgmt:/var/run/lsm:/sbin/nologin
geoclue:x:992:989:User for geoclue:/var/lib/geoclue:/sbin/nologin
rpc:x:32:32:Rpcbind Daemon:/var/lib/rpcbind:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
setroubleshoot:x:991:988::/var/lib/setroubleshoot:/sbin/nologin
rtkit:x:172:172:RealtimeKit:/proc:/sbin/nologin
pulse:x:171:171:PulseAudio System Daemon:/var/run/pulse:/sbin/nologin
gdm:x:42:42::/var/lib/gdm:/sbin/nologin
rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin
nfsnobody:x:65534:65534:Anonymous NFS User:/var/lib/nfs:/sbin/nologin
radvd:x:75:75:radvd user:/:/sbin/nologin
qemu:x:107:107:qemu user:/:/sbin/nologin
chrony:x:990:985::/var/lib/chrony:/sbin/nologin
mysql:x:27:27:MariaDB Server:/var/lib/mysql:/sbin/nologin
pcp:x:989:984:Performance Co-Pilot:/var/lib/pcp:/sbin/nologin
gnome-initial-setup:x:988:983::/run/gnome-initial-setup/:/sbin/nologin

1. 匹配含有'mysql'的行
grep mysql test.txt
mysql:x:27:27:MariaDB Server:/var/lib/mysql:/sbin/nologin

2. 匹配以'mysql'或者'tss'開頭的行
grep '^\(tss\|mysql\)' test.txt
tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
mysql:x:27:27:MariaDB Server:/var/lib/mysql:/sbin/nologin

3. 遞歸匹配'soft'目錄下全部含有'Daemon'的行並顯示行號
grep -Frn 'Daemon' /soft

4. 不顯示以'mysql'或者'tss'開頭的行
grep -n '^\(root\|mysql\)' test.txt

5. 不區分大小寫匹配
grep -i '^\(ROOT\|MYSQL\)' test.txt
mysql:x:27:27:MariaDB Server:/var/lib/mysql:/sbin/nologin

6. 匹配關鍵字並打印先後
grep -A3 'gdm' test.txt  #A後三行
gdm:x:42:42::/var/lib/gdm:/sbin/nologin
rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin
nfsnobody:x:65534:65534:Anonymous NFS User:/var/lib/nfs:/sbin/nologin
radvd:x:75:75:radvd user:/:/sbin/nologin
grep -B3 'gdm' test.txt  #B前三行
grep -B3 'gdm' test.txt  #C先後三行
View Code
FIND

FIND命令用來在指定目錄下查找文件。任何位於參數以前的字符串都將被視爲欲查找的目錄名。若是使用該命令時,不設置任何參數,則find命令將在當前目錄下查找子目錄與文件。而且將查找到的子目錄和文件所有進行顯示。

語法

find   path   -option   [   -print ]   [ -exec   -ok   command ]   {} \;

參數

pathname: find命令所查找的目錄路徑。例如用.來表示當前目錄,用/來表示系統根目錄。
-print:  find命令將匹配的文件輸出到標準輸出。
-exec:   find命令對匹配的文件執行該參數所給出的shell命令。相應命令的形式爲'command' { } \;,注意{ }和\;之間的空格。
-ok:     和-exec的做用相同,只不過以一種更爲安全的模式來執行該參數所給出的shell命令,在執行每個命令以前,都會給出提示,讓用戶來肯定是否執行。
-print    將查找到的文件輸出到標準輸出
-exec   command   {} \;      —–將查到的文件執行command操做,{} 和 \;之間有空格;

-mount, -xdev : 只檢查和指定目錄在同一個文件系統下的文件,避免列出其它文件系統中的文件
-amin n : 在過去 n 分鐘內被讀取過
-anewer file : 比文件 file 更晚被讀取過的文件
-atime n : 在過去 n 天過讀取過的文件
-cmin n : 在過去 n 分鐘內被修改過
-mtime n : 按文件更改時間來查找文件,-n指n天之內,+n指n天之前
-cnewer file :比文件 file 更新的文件
-ctime n : 在過去 n 天過修改過的文件
-empty : 空的文件-gid n or -group name : gid 是 n 或是 group 名稱是 name
-ipath p, -path p : 路徑名稱符合 p 的文件,ipath 會忽略大小寫
-name name, -iname name : 文件名稱符合 name 的文件。iname 會忽略大小寫
-depth : 使查找在進入子目錄前先行查找完本目錄
-fstype : 查位於某一類型文件系統中的文件,這些文件系統類型一般可 在/etc/fstab中找到
-mount : 查文件時不跨越文件系統mount點
-follow : 若是遇到符號連接文件,就跟蹤連接所指的文件
-cpio : 查位於某一類型文件系統中的文件,這些文件系統類型一般可 在/etc/fstab中找到
-prune : 忽略某個目錄
View Code

案例

find   -name april*                     在當前目錄下查找以april開始的文件
find   -name   april*   fprint file        在當前目錄下查找以april開始的文件,並把結果輸出到file中
find   -name ap* -o -name may*   查找以ap或may開頭的文件
find   /mnt   -name tom.txt   -ftype vfat   在/mnt下查找名稱爲tom.txt且文件系統類型爲vfat的文件
find   /mnt   -name t.txt ! -ftype vfat   在/mnt下查找名稱爲tom.txt且文件系統類型不爲vfat的文件
find   /tmp   -name wa* -type l            在/tmp下查找名爲wa開頭且類型爲符號連接的文件
find   /home   -mtime   -2                 在/home下查最近兩天內改動過的文件
find   /home    -atime -1                  查1天以內被存取過的文件
find   /home -mmin    +60                  在/home下查60分鐘前改動過的文件
find   /home   -amin   +30                  查最近30分鐘前被存取過的文件
find   /home   -newer   tmp.txt             在/home下查更新時間比tmp.txt近的文件或目錄
find   /home   -anewer   tmp.txt            在/home下查存取時間比tmp.txt近的文件或目錄
find   /home   -used   -2                  列出文件或目錄被改動過以後,在2日內被存取過的文件或目錄
find   /home   -user cnscn                列出/home目錄內屬於用戶cnscn的文件或目錄
find   /home   -uid   +501                  列出/home目錄內用戶的識別碼大於501的文件或目錄
find   /home   -group   cnscn              列出/home內組爲cnscn的文件或目錄
find   /home   -gid 501                   列出/home內組id爲501的文件或目錄
find   /home   -nouser                    列出/home內不屬於本地用戶的文件或目錄
find   /home   -nogroup                   列出/home內不屬於本地組的文件或目錄
find   /home    -name tmp.txt    -maxdepth   4   列出/home內的tmp.txt 查時深度最多爲3層
find   /home   -name tmp.txt   -mindepth   3   從第2層開始查
find   /home   -empty                     查找大小爲0的文件或空目錄
find   /home   -size   +512k                查大於512k的文件
find   /home   -size   -512k               查小於512k的文件
find   /home   -links   +2                查硬鏈接數大於2的文件或目錄
find   /home   -perm   0700                查權限爲700的文件或目錄
find   /tmp   -name tmp.txt   -exec cat {} \;  在/tmp目錄下搜索並查看tmp.txt文件
find   /tmp   -name   tmp.txt   -ok   rm {} \;  在/tmp目錄下搜索並刪除tmp.txt文件
find   /tmp  -type  f  -ctime  +30  -ok   rm {} \;  搜索/tmp下30天之前建立的文件並刪除
find   /tmp  -type  f  -ctime  +7  -exec cp {} /soft \;  搜索/tmp下7天之前建立的文件並拷貝到/soft目錄下
find    /   -amin    -10     查找在系統中最後10分鐘訪問的文件
find    /   -atime   -2        查找在系統中最後48小時訪問的文件
find    /   -empty             查找在系統中爲空的文件或者文件夾
find    /   -group   cat        查找在系統中屬於 groupcat的文件
find    /   -mmin   -5         查找在系統中最後5分鐘裏修改過的文件
find    /   -mtime   -1       查找在系統中最後24小時裏修改過的文件
find    /   -nouser           查找在系統中屬於做廢用戶的文件
find    /   -user    fred     查找在系統中屬於FRED這個用戶的文件
View Code