linux命令大全

Linux經常使用命令大全(很是全!!!)html

 

系統信息java

arch 顯示機器的處理器架構(1)node

uname -m 顯示機器的處理器架構(2)linux

uname -r 顯示正在使用的內核版本android

dmidecode -q 顯示硬件系統部件 - (SMBIOS / DMI)git

hdparm -i /dev/hda 羅列一個磁盤的架構特性ubuntu

hdparm -tT /dev/sda 在磁盤上執行測試性讀取操做windows

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 顯示一個二進制文件或可執行文件的完整路徑

這裏對FIND搜索命令進行一個詳細的解析

find命令用來在指定目錄下查找文件。任何位於參數以前的字符串都將被視爲欲查找的目錄名。

下面介紹一些關於使用find命令查找文件的命令格式和示例:

1.格式:

find +目錄 +條件 +條件值

若是使用該命令時,不設置任何參數,則find命令將在當前目錄下查找子目錄與文件,

而且將查找到的子目錄和文件所有進行顯示,如圖,在/root下的子目錄和文件所有顯示出來(截取部分):

 

2.find命令查找文件相關細分條件,條件越多,查找越準確

2.1.根據文件格式進行查找:

/home下查找全部以 .txt 結尾的文件: find /home -name *.txt"  

 

在當前目錄及子目錄下查找全部以 .txt .pdf 結尾的文件,-o 的意思爲或者,本機沒有.pdf 格式的文件:

當前目錄及子目錄下查找全部以.txt.pdf結尾的文件

來自: http://man.linuxde.net/find

當前目錄及子目錄下查找全部以.txt.pdf結尾的文件

來自: http://man.linuxde.net/find

 

/home下查找不是以 .txt 結尾的文件:find /home ! -name .txt」  !表示否認 (文件太多,截取部分)

2.2.根據文件類型進行查找:

-type 爲類型參數

f     表示文件

d    表示目錄

c    表示字符設備

b    表示塊設備

s    表示套接字

l     表示連接

查找/mnt下的子目錄:find /mnt -type d

 

查找/mnt下的文件:find /mnt -type f

 

2.3.根據文件目錄層數查找:

find --maxdepth+層數  按最大層數查找

mindepth+層數  按最小層數查找

find /home -maxdepth 2 -type f   查找/hoem下目錄最大層數爲2層的文件:

 

2.4.按文件大小進行查找:

-size爲文件大小單元

-size -n:指小於nk

-size +n:指大於nk

-size n :指等於nk

find /mnt -type f -size -100  /mnt目錄下查找小於100K的文件:

 

2.5.根據文件權限進行查找:

-perm 文件權限指數

find /mnt -type f -perm 660 /mnt下查找權限爲660的文件:

 

這裏對Linuxgrep文本搜索命令進行一個詳細的解析:

搜索isPlay,引號加不加單引號雙引號均可以:grep -rn isPlay

搜索isPlay,忽略大小寫:grep -rn -i isPlay

搜索isPlay,增長通配符(點號和*號配合使用):grep -rn is.*lay

搜索isPlay,在指定的目錄下搜索: grep -rn isPlay frameworks/base/media/

搜索isPlay,開啓logcat並在指定目錄下過濾isPlay

adb logcat | grep -rn isPlay /work/android_8.1/packages/testapps/MediaTest/

清除緩衝區log adb logcat -c

Grep選項:

 

: 表示當前目錄全部文件,也能夠是某個文件名

-r 是遞歸查找

-n 是顯示行號

-R 查找全部文件包含子目錄

-i 忽略大小寫

 

命令行參數:

grep -i pattern files :不區分大小寫地搜索。默認狀況區分大小寫

grep -l pattern files :只列出匹配的文件名,不列出路徑

grep -L pattern files :列出不匹配的文件名

grep -w pattern files :只匹配整個單詞,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’)

grep -C number pattern files :匹配的上下文分別顯示[number]

grep pattern1 | pattern2 files :顯示匹配 pattern1 pattern2 的行

grep pattern1 files | grep pattern2 :顯示既匹配 pattern1 又匹配 pattern2 的行

用於搜索的特殊符號: < > 分別標註單詞的開始與結尾。

例如: grep man * 會匹配 ‘Batman’、‘manic’、‘man’等 grep <man* 匹配‘manic’和‘man’,但不是‘Batman

grep <man>’ 只匹配‘man’,而不是‘Batman’或‘manic’等其餘的字符串。

^’:指匹配的字符串在行首

$’:指匹配的字符串在行尾

 

這裏對Linux下使用git命令作一個詳細的解析:

提交代碼:

1git pull aosp main/svw_cns3.0_dev

2git add xxx

3git commit -m [MediaTest]Repair click events without noise and related problems

4git push aosp HEAD:refs/for/main/svw_cns3.0_dev

刪除文件:git rm xxx

查看git log中某一次具體提交的內容:先git logcommitid,而後git log commitid -p -1

git回退到上一個版本:git reset  --hard HEAD^。  回退到上上個版本:git reset  --hard HEAD^^

git刪除上次提交中的某個文件(Android.mk~)再從新提交:

rm -rf NetworkConnectionsTest/Android.mk~

git status

git rm NetworkConnectionsTest/Android.mk~

git commit --amend

git push aosp HEAD:refs/for/main/svw_cns3.0_dev

掛載一個文件系統

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 掛載一個cdromdvdrom

mount /dev/hdc /mnt/cdrecorder 掛載一個cdrwdvdrom

mount /dev/hdb /mnt/cdrecorder 掛載一個cdrwdvdrom

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命令,這個命令比較經常使用,你們都很熟悉。問題是這種方法,有時候掛載點和掛載的卷不在同一行,使用腳本分析須要一點技巧的。

第二種方法:使用mount命令,mount -l,這種方法的缺陷在於沒有卷的大小,可是掛載點和掛載的卷在同一行。

第三種方法:查看文件/etc/mtab。原理是,每新掛載一個卷基本上都會更新這個文件的,那麼天然能夠經過這個文件來查看掛載點和掛職的卷。這種方法比mount -l稍微清晰了一點,可是,有時候是不可靠的。

/etc/fstab/etc/mtab的區別

/etc/fstab文件的做用:

記錄了計算機上硬盤分區的相關信息,啓動 Linux 的時候,檢查分區的 fsck 命令,和掛載分區的 mount 命令,都須要 fstab 中的信息,來正確的檢查和掛載硬盤。

/etc/mtab文件的做用:

先看它的英文是:

This changes continuously as the file /proc/mount changes. In other words, when filesystems are mounted and unmounted, the change is immediately reflected in this file.

記載的是如今系統已經裝載的文件系統,包括操做系統創建的虛擬文件等;而/etc/fstab是系統準備裝載的。 每當 mount 掛載分區、umount 卸載分區,都會動態更新 mtabmtab 老是保持着當前系統中已掛載的分區信息,fdiskdf 這類程序,必需要讀取 mtab 文件,才能得到當前系統中的分區掛載狀況。固然咱們本身還能夠經過讀取/proc/mount也能夠來獲取當前掛載信息

磁盤空間

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=InstalledSize;10tInstalledSize;10t      {Installed-Size;10}tInstalledSize;10t{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 -zcvf /home/xahot.tar.gz /xahot

tar -zcvf 打包後生成的文件名全路徑 要打包的目錄

例子:把/xahot文件夾打包後生成一個/home/xahot.tar.gz的文件。

zip 壓縮方法:

壓縮當前的文件夾 zip -r ./xahot.zip ./* -r表示遞歸

zip [參數] [打包後的文件名] [打包的目錄路徑]

解壓 unzip xahot.zip 不解釋

linux zip命令的基本用法是:

linux zip命令參數列表:

-a 將文件轉成ASCII模式

-F 嘗試修復損壞的壓縮文件

-h 顯示幫助界面

-m 將文件壓縮以後,刪除源文件

-n 特定字符串 不壓縮具備特定字尾字符串的文件

-o 將壓縮文件內的全部文件的最新變更時間設爲壓縮時候的時間

-q 安靜模式,在壓縮的時候不顯示指令的執行過程

-r 將指定的目錄下的全部子目錄以及文件一塊兒處理

-S 包含系統文件和隱含文件(S是大寫)

-t 日期 把壓縮文件的最後修改日期設爲指定的日期,日期格式爲mmddyyyy

舉例:

/home/wwwroot/xahot/ 這個目錄下全部文件和文件夾打包爲當前目錄下的xahot.zip

zip q r xahot.zip /home/wwwroot/xahot

上面的命令操做是將絕對地址的文件及文件夾進行壓縮.如下給出壓縮相對路徑目錄

好比目前在Bliux這個目錄下,執行如下操做能夠達到以上一樣的效果.

zip q r xahot.zip xahot

好比如今個人xahot目錄下,我操做的zip壓縮命令是

zip q r xahot.zip *

以上是在安靜模式下進行的,並且包含系統文件和隱含文件

//////////////////////////////////////////////////////////

unzip語 法:

unzip [-cflptuvz][-agCjLMnoqsVX][-P <密碼>][.zip文件][文件][-d <目 錄>][-x <文件>] unzip [-Z]

補充說明:unzip.zip壓縮文件的解壓縮程序。

unzip參 數:

-c 將解壓縮的結果顯示到屏幕上,並對字符作適當的轉換。

-f 更新現有的文件。

-l 顯示壓縮文件內所包含的文件。

-p -c參數相似,會將解壓縮的結果顯示到屏幕上,但不會執行任何的轉換。

-t 檢查壓縮文件是否正確。

-u -f參數相似,可是除了更新現有的文件外,也會將壓縮文件中的其餘文件解壓縮到目錄中。

-v 執行是時顯示詳細的信息。

-z 僅顯示壓縮文件的備註文字。

-a 對文本文件進行必要的字符轉換。

-b 不要對文本文件進行字符轉換。

-C 壓縮文件中的文件名稱區分大小寫。

-j 不處理壓縮文件中原有的目錄路徑。

-L 將壓縮文件中的所有文件名改成小寫。

-M 將輸出結果送到more程序處理。

-n 解壓縮時不要覆蓋原有的文件。

-o 沒必要先詢問用戶,unzip執行後覆蓋原有文件。

-P<密碼> 使用zip的密碼選項。

-q 執行時不顯示任何信息。

-s 將文件名中的空白字符轉換爲底線字符。

-V 保留VMS的文件版本信息。

-X 解壓縮時同時回存文件原來的UID/GID

[.zip文件] 指定.zip壓縮文件。

[文件] 指定要處理.zip壓縮文件中的哪些文件。

-d<目錄> 指定文件解壓縮後所要存儲的目錄。

-x<文件> 指定不要處理.zip壓縮文件中的哪些文件。

-Z unzip -Z等於執行zipinfo指令

舉例:

/home/wwwroot/xahot.zip解壓到當前目錄

unzip xahot.zip

若是出現這個提示:

-bash: zip: command not found    不能執行ZIP壓縮,是由於沒有安裝ZIP

運行下這條安裝命令便可  yum install zip

==============================================================

tar -cvf /usr/local/auto_bak/test.tar /usr/local/test 僅打包,不壓縮

tar -zcvf /usr/local/auto_bak/test.tar.gz /usr/local/test 打包後,以gzip壓縮 在參數f後面的壓縮文件名是本身取的,習慣上用tar來作,若是加z參數,則以tar.gz tgz來表明gzip壓縮過的tar file文件

解壓操做:

#tar -zxvf /usr/local/test.tar.gz

tar 解壓縮命令詳解

-c: 創建壓縮檔案

-x:解壓

-t:查看內容

-r:向壓縮歸檔文件末尾追加文件

-u:更新原壓縮包中的文件

這五個是獨立的命令,壓縮解壓都要用到其中一個,能夠和別的命令連用但只能用其中一個。下面的參數是根據須要在壓縮或解壓檔案時可選的。

-z:有gzip屬性的

-j:有bz2屬性的

-Z:有compress屬性的

-v:顯示全部過程

-O:將文件解開到標準輸出

下面的參數-f是必須的

-f: 使用檔案名字,切記,這個參數是最後一個參數,後面只能接檔案名。

*tar -cf all.tar .jpg

這條命令是將全部.jpg的文件打成一個名爲all.tar的包。-c是表示產生新的包,-f指定包的文件名。

*#tar -rf all.tar .gif

這條命令是將全部.gif的文件增長到all.tar的包裏面去。-r是表示增長文件的意思。

# tar -uf all.tar logo.gif

這條命令是更新原來tarall.tarlogo.gif文件,-u是表示更新文件的意思。

# tar -tf all.tar

這條命令是列出all.tar包中全部文件,-t是列出文件的意思

tar -xf all.tar

這條命令是解出all.tar包中全部文件,-x是解開的意思

壓縮

tar cvf jpg.tar *.jpg //將目錄裏全部jpg文件打包成tar.jpg

tar czf jpg.tar.gz *.jpg   //將目錄裏全部jpg文件打包成jpg.tar後,而且將其用gzip壓縮,生成一  個gzip壓縮過的包,命名爲jpg.tar.gz

tar cjf jpg.tar.bz2 *.jpg //將目錄裏全部jpg文件打包成jpg.tar後,而且將其用bzip2壓縮,生成一個bzip2壓縮過的包,命名爲jpg.tar.bz2

tar cZf jpg.tar.Z *.jpg   //將目錄裏全部jpg文件打包成jpg.tar後,而且將其用compress壓縮,生成一個umcompress壓縮過的包,命名爲jpg.tar.Z

rar a jpg.rar *.jpg //rar格式的壓縮,須要先下載rar for linux

zip jpg.zip *.jpg //zip格式的壓縮,須要先下載zip for linux

解壓

tar xvf file.tar //解壓 tar

tar -xzvf file.tar.gz //解壓tar.gz

tar -xjvf file.tar.bz2   //解壓 tar.bz2

tar xZvf file.tar.Z   //解壓tar.Z

unrar e file.rar //解壓rar

unzip file.zip //解壓zip

總結

(1).tar tar xvf 解壓

(2).gz gzip -d或者gunzip 解壓

(3).tar.gz.tgz tar xzf 解壓

(4).bz2 bzip2 -d或者用bunzip2 解壓

(5).tar.bz2tar xjf 解壓

(6).Z uncompress 解壓

(7).tar.Z tar xZf 解壓

(8).rar unrar e解壓

(9).zip unzip 解壓

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/gexample.txt example.txt文件中的 「string1」 替換成 「string2

sed /^KaTeX parse error: Expected 'EOF', got '#' at position 49: …全部空白行

sed '/ *#̲/d; /^/dexample.txt example.txt文件中刪除全部註釋和空白行

echo esempio| tr [:lower:]’ ‘[:upper:]’ 合併上下單元格內容

sed -e 1dresult.txt 從文件example.txt 中排除第一行

sed -n /stringa1/p’ 查看只包含詞彙 「string1"的行

sed -e s/ $//example.txt 刪除每一行最後的空白字符

sed -e s/stringa1//gexample.txt 從文檔中只刪除詞彙 「string1」 並保留剩餘所有

sed -n 1,5p;5qexample.txt 查看從第一行到第5行內容

sed -n 5p;5qexample.txt 查看第5

sed -e 's/00/0/gexample.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命令,這個命令主要是用來顯示當前系統的進程狀況,有哪些進程,及其 idjps 也是同樣,它的做用是顯示當前系統的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/linuxps命令。

相關文章
相關標籤/搜索