linux常用命令手冊整理

Linux常用命令大全
系統信息 
arch 顯示機器的處理器架構(1) 
uname -m 顯示機器的處理器架構(2) 
uname -r 顯示正在使用的內核版本 
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 顯示已加載的文件系統 
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 

文件搜索 
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 以容量大小爲依據依次顯示文件和目錄的大小  

用戶和羣組 
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 設置用戶口令的失效期限 
 
文件的權限 - 使用 "+" 設置權限,使用 "-" 用於取消 
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 -xvfj archive.tar.bz2 解壓一個bzip2格式的壓縮包 
tar -cvfz archive.tar.gz dir1 創建一個gzip格式的壓縮包 
tar -xvfz 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 文件系統 

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和壓縮將本地目錄同步到遠程目錄
rsync -azvrtopg --progress -e ssh --delete [email protected]:/var/www/* /backup/rsync/www
            --#從服務器上備份到本地的/backup/rsync/www裏面
rsync -avz --progress -e ssh --delete /backup/rsync/www/ [email protected]::www
            --#從本地恢復文件到服務器
    -v, --verbose 詳細模式輸出。
    -q, --quiet 精簡輸出模式。
    -c, --checksum 打開校驗開關,強制對文件傳輸進行校驗。
    -a, --archive 歸檔模式,表示以遞歸方式傳輸文件,並保持所有文件屬性,等於-rlptgoD。
    -r, --recursive 對子目錄以遞歸模式處理。
    -R, --relative 使用相對路徑信息。
    -b, --backup 創建備份,也就是對於目的已經存在有同樣的文件名時,將老的文件重新命名爲~filename。可以使用--suffix選項來指定不同的備份文件前綴。
    --backup-dir 將備份文件(如~filename)存放在在目錄下。
    -suffix=SUFFIX 定義備份文件前綴。
    -u, --update 僅僅進行更新,也就是跳過所有已經存在於DST,並且文件時間晚於要備份的文件,不覆蓋更新的文件。
    -l, --links 保留軟鏈結。
    -L, --copy-links 想對待常規文件一樣處理軟鏈結。
    --copy-unsafe-links 僅僅拷貝指向SRC路徑目錄樹以外的鏈結。
    --safe-links 忽略指向SRC路徑目錄樹以外的鏈結。
    -H, --hard-links 保留硬鏈結。
    -p, --perms 保持文件權限。
    -o, --owner 保持文件屬主信息。
    -g, --group 保持文件屬組信息。
    -D, --devices 保持設備文件信息。
    -t, --times 保持文件時間信息。
    -S, --sparse 對稀疏文件進行特殊處理以節省DST的空間。
    -n, --dry-run現實哪些文件將被傳輸。
    -x, --one-file-system 不要跨越文件系統邊界。
    -B, --block-size=SIZE 檢驗算法使用的塊尺寸,默認是700字節。
    -e, --rsh=指定使用rsh、ssh方式進行數據同步。
    --rsync-path=PATH 指定遠程服務器上的rsync命令所在路徑信息。
    -C, --cvs-exclude 使用和CVS一樣的方法自動忽略文件,用來排除那些不希望傳輸的文件。
    --existing 僅僅更新那些已經存在於DST的文件,而不備份那些新創建的文件。
    --delete 刪除那些DST中SRC沒有的文件。
    --delete-excluded 同樣刪除接收端那些被該選項指定排除的文件。
    --delete-after 傳輸結束以後再刪除。
    --ignore-errors 及時出現IO錯誤也進行刪除。
    --max-delete=NUM 最多刪除NUM個文件。
    --partial 保留那些因故沒有完全傳輸的文件,以是加快隨後的再次傳輸。
    --force 強制刪除目錄,即使不爲空。
    --numeric-ids 不將數字的用戶和組匹配爲用戶名和組名。
    --timeout=超時時間,單位爲秒。
    -I, --ignore-times 不跳過那些有同樣的時間和長度的文件。
    --size-only 當決定是否要備份文件時,僅僅察看文件大小而不考慮文件時間。
    --modify-window=NUM 決定文件是否時間相同時使用的時間戳窗口,默認爲0。
    -T --temp-dir=DIR 在DIR中創建臨時文件。
    --compare-dest=DIR 同樣比較DIR中的文件來決定是否需要備份。
    -P 等同於 --partial。
    --progress 顯示備份過程。
    -z, 對備份的文件在傳輸時進行壓縮處理。
    --exclude=PATTERN 指定排除不需要傳輸的文件模式。
    --include=PATTERN 指定不排除而需要傳輸的文件模式。
    --exclude-from=FILE 排除FILE中指定模式的文件。
    --include-from=FILE 不排除FILE指定模式匹配的文件。
    --version 打印版本信息。
    --address 綁定到特定的地址。
    --config=FILE 指定其他的配置文件,不使用默認的rsyncd.conf文件。
    --port=PORT 指定其他的rsync服務端口。
    --blocking-io 對遠程shell使用阻塞IO。
    -stats 給出某些文件的傳輸狀態。
    --progress 在傳輸時現實傳輸過程。
    --log-format=formAT 指定日誌文件格式。
    --password-file=FILE 從FILE中得到密碼。
    --bwlimit=KBPS 限制I/O帶寬,KBytes per second。
    
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內容 

網絡
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 
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 

scp用法
    -p 保留原文件的修改時間,訪問時間和訪問權限。  
    -q  不顯示傳輸進度條。  
    -r  遞歸複製整個目錄。  
    -v 詳細方式顯示輸出。scp和ssh(1)會顯示出整個過程的調試信息。這些信息用於調試連接,驗證和配置問題。
    從本地服務器複製到遠程服務器: 
        (1) 複製文件:  
        命令格式:  
        scp local_file remote_username@remote_ip:remote_folder  
        或者  
        scp local_file remote_username@remote_ip:remote_file  
        或者  
        scp local_file remote_ip:remote_folder  
        或者  
        scp local_file remote_ip:remote_file
        (2) 複製目錄:  
        命令格式:  
        scp -r local_folder remote_username@remote_ip:remote_folder  
        或者  
        scp -r local_folder remote_ip:remote_folder
    從遠程服務器複製到本地服務器:
        (1) 複製文件:  
        命令格式:  
        scp remote_username@remote_ip:remote_folder local_file
        (2) 複製目錄:  
        命令格式:  
        scp -r remote_username@remote_ip:remote_folder local_folder
        
ssh用法
    -A:開啓認證代理連接轉發功能; 
    -a:關閉認證代理連接轉發功能;
    -b:使用本機指定地址作爲對應連接的源ip地址; 
    -C:請求壓縮所有數據; 
    -F:指定ssh指令的配置文件; 
    -f:後臺執行ssh指令; 
    -g:允許遠程主機連接主機的轉發端口; 
    -i:指定身份文件; 
    -l:指定連接遠程服務器登錄用戶名; 
    -N:不執行遠程指令; 
    -o:指定配置選項; 
    -p:指定遠程服務器上的端口; 
    -q:靜默模式; 
    -X:開啓X11轉發功能; 
    -x:關閉X11轉發功能;
ssh-keygen #爲ssh生成、管理和轉換認證祕鑰,支持RSA和DSA認證
    -b:指定密鑰長度; 
    -e:讀取openssh的私鑰或者公鑰文件; 
    -C:添加註釋; 
    -f:指定用來保存密鑰的文件名;
ssh-copy-id#把本地主機的公鑰複製到遠程主機的authorized_keys文件上,ssh-copy-id命令也會給遠程主機的用戶主目錄(home)和~/.ssh/authorized_keys設置合適的權限    

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章