首頁  >  文章  >  運維  >  常用linux指令有哪些

常用linux指令有哪些

爱喝马黛茶的安东尼
爱喝马黛茶的安东尼原創
2019-07-23 16:47:1815137瀏覽

常用linux指令有哪些

Linux常用指令大全

最近都在跟Linux打交道,感覺還不錯。我覺得Linux比起windows比較麻煩的就是很多東西都要用指令來控制,當然,這也是很多人喜歡linux的原因,比較短小但卻功能強大。我將我了解到的命令列舉一下,僅供大家參考:

系統資訊 

arch 顯示機器的處理器架構

uname - m 顯示機器的處理器架構

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 -

#lspci - tv 羅列PCI 裝置 

lsusb -tv 顯示USB 裝置 

date 顯示系統日期 

cal 2007 顯示2007年的行事曆表 

#date 041217002007.00#date 041217002007.00#和時間- 月日時分年.秒 

clock -w 將時間修改保存到BIOS 

關機(系統的關機、重啟以及登出) 

shutdown -h now 關閉系統

init 0 關閉系統

telinit 0 關閉系統

shutdown -h hours:minutes & 依預定時間關閉系統 

shutdown -c 取消按預定時間關閉系統 

shutdown -r now 重新啟動

reboot 重新啟動

logout 登出 

檔案和目錄 

cd /home 進入'/ home' 目錄' 

cd .. 回上一級目錄 

cd ../.. 回上兩層目錄 

cd 進入個人的主目錄 

cd ~user1 進入個人的主目錄 

cd - 返回上次所在的目錄 

#pwd 顯示工作路徑 

ls 檢視目錄中的檔案和目錄的詳細資料 

#ls -a 顯示隱藏檔案 

ls *[0-9]* 顯示包含數字的檔案名稱和目錄名稱 

tree 顯示檔案和目錄由根目錄開始的樹狀結構

#lstree 顯示檔案和目錄由根目錄開始的樹形結構

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 ' {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 顯示特殊的屬性 

相關推薦:《linux運維教學

打包與壓縮檔案 

bunzip2 file1.bz2 解壓縮一個叫做'file1.bz2'的檔案 

bzip2 file1 壓縮一個叫做'file1' 的檔案 

gunzip file1.gz 解壓縮一個叫做 'file1.gz'的檔案 ##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...) & gt;文件的詳細說明文本,並將簡介寫入一個新文件中 

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

ifconfig eth0 192.168.1.1 netmask 255.255.255.位址 

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 1​​68.0.0 netmask 255.255.0.0 gw 1​​92.168.192.168.192. 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

nslookup www.example.com lookup hostname to resolve name

nslookup www.example.com lookup hostname to resolve name

nslookup www.example.com lookup hostname to resolve name to #nslookupdress and vicevereversa

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' 

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 ffshow

##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.logdout.log -stderr /data/aoxj/resin/log/stderr.logdout.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.MBeanServerBuilderImplpl

##sudo jps看到的進程數量最全

jps 192.168.0.77

列出遠端伺服器192.168.0.77機器所有的jvm實例,採用rmi協議,預設連接埠為1099

(前提是遠端伺服器提供jstatd服務)

註:jps指令有個地方很不好,似乎只能顯示目前使用者的java進程,要顯示其他使用者的還是只能用unix/linux的ps指令。

以上是常用linux指令有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn