Linux經常使用命令

1、系統信息 html

arch 顯示機器的處理器架構(1)
uname -m 顯示機器的處理器架構(2)
uname -r 顯示正在使用的內核版本
top 查看CPU實時性能
free 查看內存
lspci -tv 羅列 PCI 設備
date 顯示系統日期
cal 2007 顯示2007年的日曆表
clock -w 將時間修改保存到 BIOS java

2、關機、重啓和註銷
init 0 關閉系統(1)
halt 關閉系統(2)
reboot 重啓
logout 註銷

3、文件和目錄
cd /home 進入 '/ home' 目錄'
cd .. 返回上一級目錄
cd ../.. 返回上兩級目錄
pwd 顯示工做路徑
ls 查看目錄中的文件
ls -F 查看目錄中的文件
ls -l 顯示文件和目錄的詳細資料
ls -a 顯示隱藏文件
mkdir dir1 建立一個叫作 'dir1' 的目錄'
mkdir -p /tmp/dir1/dir2 建立一個目錄樹
rm -f file1 刪除一個叫作 'file1' 的文件'
rmdir dir1 刪除一個叫作 'dir1' 的目錄'
mv dir1 new_dir 重命名/移動 一個目錄
cp file1 file2 複製一個文件
cp -a dir1 dir2 遞歸複製
ln -s file1 lnk1 建立一個指向文件或目錄的軟連接

4、網絡(以太網和WIFI無線)
ifconfig 查看IP地址
route 查看默認網關
cat /etc/resolv.conf 查看DNS
ifup eth0 啓用一個 'eth0' 網絡設備
ifdown eth0 禁用一個 'eth0' 網絡設備
setup 圖形化配置界面(能夠設置主機名、IP地址、DNS等)
route -n 查看路由表
route add -net 0/0 gw IP_Gateway 配置默認路由
route add -net 192.168.0.0 netmask 255.255.0.0 gw 192.168.1.1 對'192.168.0.0/16'網段配置靜態路由
route del 0/0 gw IP_gateway r刪除靜態路由
echo "1" > /proc/sys/net/ipv4/ip_forward 激活IP轉發功能
dig www.baidu.com 解析www.baidu.com域名
ip link show show link status of all interfaces
netstat -a 列出全部端口
netstat -at 列出全部TCP端口
netstat -au 列出全部UDP端口
netstat -atp 列出全部TCP端口和PID
netstat -atpl 列出全部處於監聽狀態的TCP端口和PID
tcpdump tcp port 80 對80端口抓包linux

5、文件搜索
find / -name file1 從 '/' 開始進入根文件系統搜索文件和目錄
find / -name \*.rpm -exec chmod 755 '{}' \; 搜索以 '.rpm' 結尾的文件並定義其權限
find / -xdev -name \*.rpm 搜索以 '.rpm' 結尾的文件,忽略光驅、捷盤等可移動設備
locate \*.ps 尋找以 '.ps' 結尾的文件 - 先運行 'updatedb' 命令
whereis halt 顯示一個二進制文件、源碼或man的位置
which halt 顯示一個二進制文件或可執行文件的完整路徑

6、rpm包管理
rpm -ivh 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 -ql package_name 顯示一個已經安裝的rpm包提供的文件列表
rpm -qf /etc/httpd/conf/httpd.conf 確認所給的文件由哪一個rpm包所提供
rpm -qa gpg-pubkey 確認已安裝的全部rpm包的完整性
rpm -V package_name 檢查文件尺寸、 許可、類型、全部者、羣組、MD5檢查以及最後修改時間
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 install package_name 下載並安裝一個rpm包
yum localinstall 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 刪除全部緩存的包和頭文件 ubuntu

7、掛載一個文件系統
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/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網絡共享 windows

8、磁盤空間
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類系統) 緩存

9、其餘經常使用操做
用戶和羣組
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 登錄進一個新的羣組以改變新建立文件的預設羣組tomcat

解鎖用戶
pam_tally2 -u tom 查看被鎖用戶信息,等效於pam_tally2 --user tom
pam_tally2 -u tom -r 對被鎖用戶手動解鎖,等效於pam_tally2 --user tom --reset安全

文件的權限 - 使用 "+" 設置權限,使用 "-" 用於取消
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 位 bash

文件的特殊屬性 - 使用 "+" 設置權限,使用 "-" 用於取消
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格式壓縮包

查看文件內容
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內容

10、查看進程的命令

Linux:

查詢佔用最多內存的進程
ps aux | sort -k4nr | head -K

sort -k4nr中(k表明從第幾個位置開始,後面的數字4便是其開始位置,結束位置若是沒有,則默認到最後;
n指代numberic sort,根據其數值排序;r指代reverse,這裏是指反向比較結果,輸出時默認從小到大,反向後從大到小)
本例中,能夠看到%MEM在第4個位置,根據%MEM的數值進行由大到小的排序。
head -K(K指代行數,即輸出前幾位的結果)

一、查詢進程
ps -ef|grep "進程名"
查找java進程:ps -ef|grep java
查找tomcat進程:ps -ef|grep tomcat;
查找oracle:ps -ef|grep ora,查找oracle監聽程序:ps -ef|grep tnslsnr;
若是統計進程數,直接在後面加上wc -l,譬如查找java進程數量:
ps -ef|grep tomcat|grep -v grep|wc -l(加上"grep -v grep"意思是排除自身查詢這個命令,不做統計)

二、查詢端口
查詢java程序所監聽端口:netstat -tunlp|grep java
也可查詢端口是否在監聽:netstat -tunlp|grep 1521(這個是查詢oracle監聽程序是否在監聽,默認端口是1521)
查詢java程序活動端口所創建鏈接:netstat -an|grep ESTABLISHED
查詢java程序活動端口所創建鏈接數量:netstat -an|grep ESTABLISHED|grep -v grep|wc -l

Window:

一、查詢進程
cmd命令行模式:
列出全部進程:tasklist
查看airclt進程是否存在:tasklist|findstr airclt(前提是知道該進程名)
統計以airclt開頭的進程個數:tasklist|findstr "^airclt"|find /C /I "airclt"
查看java進程個數:tasklist|find /C /I "java"(/C是統計個數,/I是不區分大小寫)

二、查詢端口
cmd命令行模式:
列出監聽端口:netstat -ano|findstr LISTEN
列出oracle監聽端口數量:netstat -ano|findstr LISTEN|find /C /I "1521"
(前提oracle默認監聽端口爲1521)
固然在肯定某個端口惟一性的前提下,能夠這樣操做:netstat -ano|find /C /I "10050"

相關文章
相關標籤/搜索