Linux常用命令大全(非常全!!!)


Linux常用命令大全(非常全!!!)

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

 

系統信息 

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 注銷 

 

linux 下crontab -e 命令插入及保存

定時服務時要用到的

root身份登錄到命令行

輸入crontab -e

按下a鍵進入到編輯模式

輸入

0 */1 * * * /home/work/start-service.sh

0 */1 * * * /home/shell/elasticsearch.sh

同時按下ctrl+c退出編輯模式

按下shift+: 輸入wq 退出 crontab

 

我們常用的命令如下:

-r不能用是刪除的

crontab [-u username]    //省略用戶表表示操作當前用戶的crontab     -e      (編輯工作表)     -l      (列出工作表里的命令)     -r      (刪除工作作)

 

linux下使用crontab命令被用來提交和管理用戶的需要周期性執行的任務,示例如下:

crontab -e 編輯周期任務

30 21 * * * /etc/init.d/smb restart 每晚的21:30重啟smb

crontab命令說明:

 crontab命令被用來提交和管理用戶的需要周期性執行的任務,與windows下的計划任務類似,當安裝完成操作系統后,默認會安裝此服務工具,並且會自動啟動crond進程,crond進程每分鍾會定期檢查是否有要執行的任務,如果有要執行的任務,則自動執行該任務。

 

如果任務不是root的權限下運行,要在對應的用戶下建一個crontab - e文件

操作就是 用戶的名稱

$ 用戶名

 

語法

 crontab(選項)(參數)

選項

 -e:編輯該用戶的計時器設置;

 -l:列出該用戶的計時器設置;

 -r:刪除該用戶的計時器設置;

 -u<用戶名稱>:指定要設定計時器的用戶名稱。

參數

 crontab文件:指定包含待執行任務的crontab文件。

 

知識擴展

 Linux下的任務調度分為兩類:系統任務調度和用戶任務調度。

 系統任務調度:系統周期性所要執行的工作,比如寫緩存數據到硬盤、日志清理等。在/etc目錄下有一個crontab文件,這個就是系統任務調度的配置文件。

 

crontab文件的含義:

 用戶所建立的crontab文件中,每一行都代表一項任務,每行的每個字段代表一項設置,它的格式共分為六個字段,前五段是時間設定段,第六段是要執行的命令段,格式如下:

16 */1 * * *

 

8 */2 * * *

minute   hour   day   month   week   command     順序:分 時 日 月 周

其中:

minute: 表示分鍾,可以是從0到59之間的任何整數。

hour:表示小時,可以是從0到23之間的任何整數。

day:表示日期,可以是從1到31之間的任何整數。

month:表示月份,可以是從1到12之間的任何整數。

week:表示星期幾,可以是從0到7之間的任何整數,這里的0或7代表星期日。

command:要執行的命令,可以是系統命令,也可以是自己編寫的腳本文件。

在以上各個字段中,還可以使用以下特殊字符:

 

星號(*):代表所有可能的值,例如month字段如果是星號,則表示在滿足其它字段的制約條件后每月都執行該命令操作。

逗號(,):可以用逗號隔開的值指定一個列表范圍,例如,“1,2,5,7,8,9”

中杠(-):可以用整數之間的中杠表示一個整數范圍,例如“2-6”表示“2,3,4,5,6”

正斜線(/):可以用正斜線指定時間的間隔頻率,例如“0-23/2”表示每兩小時執行一次。同時正斜線可以和星號一起使用,例如*/10,如果用在minute字段,表示每十分鍾執行一次。

 

 

 

 

 

給目錄加權限

chmod -R 777 文件名

注意:必須是R,r不行

 

查看進程

ps aux | less

其中,

-A:顯示所有進程

a:顯示終端中包括其它用戶的所有進程

x:顯示無控制終端的進程

任務:查看系統中的每個進程。

 

// 查看自動服務的進程

ps -ef|grep 'queue:signremindpush'

 

// 查看端口是否占用

netstat -tunlp | grep 8000

 

文件和目錄 

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格式壓縮包 

 

案件:

解壓到指定的文件夾     tar -zxvf java.tar.gz  -C /usr/java

 

 

 

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命令。

 

添加環境變量:export PATH=$PATH:/opt/rabbitmq/sbin

環境變量生效:source  /etc/profile

 

1、linux報錯:export `=' not a valid identifier的一般原因

不能有空格在里面,就算是同行的注釋也不行

 

查看某一端口的占用情況: lsof -i:端口號

前提:首先你必須知道,端口不是獨立存在的,它是依附於進程的。某個進程開啟,那么它對應的端口就開啟了,進程關閉,則該端口也就關閉了。下次若某個進程再次開啟,則相應的端口也再次開啟。而不要純粹的理解為關閉掉某個端口,不過可以禁用某個端口。

1. 可以通過"netstat -anp" 來查看哪些端口被打開。

(注:加參數'-n'會將應用程序轉為端口顯示,即數字格式的地址,如:nfs->2049, ftp->21,因此可以開啟兩個終端,一一對應一下程序所對應的端口號)

2. 然后可以通過"lsof -i:$PORT"查看應用該端口的程序($PORT指對應的端口號)。或者你也可以查看文件/etc/services,從里面可以找出端口所對應的服務。

(注:有些端口通過netstat查不出來,更可靠的方法是"sudo nmap -sT -O localhost")

3. 若要關閉某個端口,則可以:

編輯/etc/sysconfig/iptables文件

1)通過iptables工具將該端口禁掉,如:

"sudo iptables -A INPUT -p tcp --dport $PORT -j DROP"

"sudo iptables -A OUTPUT -p tcp --dport $PORT -j DROP"    

2)或者關掉對應的應用程序,則端口就自然關閉了,如:

"kill -9 PID" (PID:進程號)

如:    通過"netstat -anp | grep ssh"

有顯示:    tcp 0 127.0.0.1:2121 0.0.0.0:* LISTEN 7546/ssh

則:    "kill -9 7546"

 

bash shell 讓程序在Linux終端后台執行的命令

一、為什么要使程序在后台執行

我們計算的程序都是周期很長的,通常要幾個小時甚至一個星期。我們用的環境是用putty遠程連接到日本Linux服務器。所以使程序在后台跑有以下三個好處:

1:我們這邊是否關機不影響日本那邊的程序運行。(不會像以前那樣,我們這網絡一斷開,或一關機,程序就斷掉或找不到數據,跑了幾天的程序只能重頭再來,很是煩惱)

2:不影響計算效率

3:讓程序在后台跑后,不會占據終端,我們可以用終端做別的事情。

二、怎么樣使程序在后台執行

方法有很多,這里主要列舉兩種。假如我們有程序pso.cpp,通過編譯后產生可執行文件pso,我們要使pso在linux服務器后台執行。當客戶端關機后重新登入服務器后繼續查看本來在終端輸出的運行結果。(假設操作都在當前目錄下)

方法1在終端輸入命令:

 $ ./pso > log.file 2>&1 & 

l  1

解釋:將pso直接放在后台運行,並把終端輸出存放在當前目錄下的log.file文件中。

當客戶端關機后重新登陸服務器后,直接查看pso.file文件就可看執行結果(命令:$ cat pso.file )。

方法2在終端輸入命令:

$ nohup  ./pso > pso.file 2>&1 &

l  1

解釋:nohup就是不掛起的意思,將pso直接放在后台運行,並把終端輸出存放在當前

目錄下的pso.file文件中。當客戶端關機后重新登陸服務器后,直接查看pso.file

文件就可看執行結果(命令:#cat pso.file )。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM