RedHat Linux Shell經常使用命令(多數也適用於Unix和AIX)

注:本文轉載自瘋狂的矩陣一文,http://www.cnblogs.com/520sojustdoit/p/4642568.htmlhtml

------------------------------------------------------------------------------------------------java

目的:經過對平常使用的一些Linux命令進行總結分享,但願能給你們一些幫助。
說明:本文的命令都是在RedHat Linux下測試的,Unix和IBM AIX下的命令有所不一樣,具體查看 man page。若有錯誤,歡迎指正。mysql

建議:讀者在操做的過程當中但願造成參考 man page的習慣,很是有用。

1.# 表示權限用戶(如:root),$ 表示普通用戶
  開機提示:Login:輸入用戶名
  password:輸入口令   用戶是系統註冊用戶成功登錄後,能夠進入相應的用戶環境.
  退出當前shell,輸入:exitlinux

1   [etl@ll-etl-02 bin]$
2   [root@ll-etl-02 bin]#

2.useradd netseek 添加一個netseek用戶(添加用戶前要考慮該用戶放在那個用戶組,方便往後管理,groupadd)
  passwd netseek  給netseek這個用戶設置密碼.
  (/etc/passwd /etc/group)
  userdel netseek 刪除帳號
  userdel -r netseek 刪除帳號連同自家目錄.
  [更詳細的操做請參閱man page,和帳號管理篇]ios

3.查看目錄和文件命令
  ls -l  顯示文件列表(相似於Windows的詳細列表)(經常使用)
  ls -al        -a 顯示全部檔案及目錄 (ls內定將檔案名或目錄名稱開頭爲"."的視爲隱藏檔,不會列出)
  ls -al |grep '^d'   顯示目錄
  ls -al |grep '^[^d]' 在一個目錄中查詢不包含目錄的全部文件
  ls -sh        (man ls 查看man幫助.)c++

 

linux幾種文件類型:
  d    表示此文件是一個目錄
  -    表示此文件是一個普通文件
  b    表示此文件是一個特殊的塊設備I/O文件
  c    表示此文件是一個特殊的字符設備I/O文件
  l    表示此文件是一個鏈接文件。在其文件名稱後緊跟與它鏈接的文件路徑及名稱sql

 

  實例:shell

1   [etl@ll-etl-02 bin]$ ls -l
2   -rw-r-----. 1 etl etl 152023  7月 13 01:06 hs_err_pid8675.log
3   drwxr-x---. 2 etl etl  4096  7月 13 11:04 bin

  其中-rw-r-----. 表示該文件的權限,其中第一個'-'或者'd'表示文件類型,後面的每三個爲一組,分別是user,user_group,others的權限信息。
  改變文件權限能夠用chmod來實現,後續會講到或者參見 [man chmod]
  
  file 命令經過探測文件內容判斷文件類型數據庫

 

4.創建文件和目錄
  touch 1.txt
  cat > 2.txt (用定向符建立文件,填寫內容後,按ctrl+d保存內容)
  mkdir mywork 創建mywork這個目錄
  rmdir 刪除目錄(相似於rm -r)編程

 

5.拷貝文件或目錄
  cp filename1 filename2  目標文件filename2若是存在則覆蓋(經常使用)
  cp -r dir1 dir2 複製目錄
  cp -rf 參數f是刪除已經存在的目標文件而不提示
  cp -i  參數i和f相反,在覆蓋目標文件以前將給出提示要求用戶確認,回答y時目標文件將被覆蓋,是交互式拷貝.

 

6.刪除文件和目錄(刪除文件或目錄均可以用rm搞定)
  rm 1.c //將1.c這個文件刪除(經常使用)
  rm -rf (強制刪除文件或目錄,刪除時不提示.慎用,考慮賬號的權限和文件的使用者有哪些。)

7.移走目錄或者改文件名
  mv [opitons] 源文件或目錄   目標文件或目錄(經常使用)
  [options]主要參數
  -i:交互方式操做,若是mv操做將致使對已存在的目標文件的覆蓋,此時系統詢問是否重寫,要求用戶回答「y」或「n」,
     這樣能夠避免誤覆蓋文件.
  -f:禁止交互操做。mv操做要覆蓋某個已有的目標文件時不給任何指示,指定此參數後i參數將再也不起做用。
  mv hello ../ 將hello目錄或者文件移動上一級.
 
8.alias 別名
  alias dir='ls -l'   輸入dir,其實就至關於執行了ls -l
  查看alias 能夠用type命令,如

1   [etl@ll-etl-02 ~]$ type ll
2   ll is aliased to 'ls -l --color=auto'

 

9.權限的控制,Linux的權限系統爲安全提供一層強的保障,(rwx 421)
  chmod +x hello.sh 賦於可執行權限.
  (詳細介紹一下權限的控制)
  chmod 命令 權限修改 用法:chmod 一位8進制數 filename (rwx 421)
 eg: chmod u+x filenmame      只想給本身運行,別人只能讀
  chown netseek.netseek mydir  改變用戶屬組

    u:表示文件全部者
    g:表示同組用戶
    o:表示其它用戶
    a:表示全部用戶
    opt則是表明操做,能夠爲:
    +:添加某個權限
    -:取消某個權限
    =:賦予給定的權限,並取消原有的權限
    而mode則表明權限:
    r:可讀 4
    w:可寫 2
    x:可執行 1

10.pwd 顯示當前目錄完整路徑和改變目錄(經常使用)
  cd netseek 進入netseek這個目錄
  cd 退出當前目錄
  cd ../ 進入上一級目錄.
  cd - 返回上一次目錄(很是實用的一個操做,能夠快速的在兩個目錄間切換)(經常使用)
  cd ~ 返回主目錄

11. 查看文本信息cat,more,less,vi,tail 命令
  將某個文件的內容顯示出來,兩個命令不一樣的是:cat 把文件內容一直打印出來,而more則分展顯示。
  less 能夠上下翻滾查看內容,支持vi命令的翻頁。
  cat > 1.txt 能夠填寫或者複製內容,按ctrl+d保存
  cat 1.c
  more 1.c
  head -n filename 顯示第N行的內容
  
  tail -n filename 顯示後N行的內容
  tail -n 20 /var/log/message 顯示最新的20行日誌
  tail -10f filename  顯示後N行的內容,並打印更新(經常使用)

12.設置linux時間和日期
  date 命令("date MMDDhhmmYYYY.ss")
  2006年7月24日12:37 ,30秒
  date 072412372006.30
  date -s 20:30:30 #設置系統時間爲20: 30:30
  date -s 2006-7-24 #設置系統時期爲2006-7-24
  clock -r #對系統Bios中讀取時間參數
  clock -w #將系統時間(如由date設置的時間)寫入Bios
  
  time - time a simple command or give resource usage
  time 命令用於計算程序消耗的系統時間,使用方法是:

1   [etl@ll-etl-02 ~]$ time test.sh
2   test.sh is done.
3   real    0m1.003s
4   user    0m2.000s
5   sys     0m0.003s

 

13.查看找文件(find,grep,awk更多的請參照man page或shell編程專題講解)
  幾種介紹:
  find 路徑  -name 文件名
  find /etc -name named.conf   結合-exec參數能實現很靈活的查找(經常使用)
  locate 經過文件名搜索文件的工具(要先經過updatedb創建索引數據庫)
  localte named.conf
  whereis 是尋找二進制文件,同時也會找到其幫助文件
  which 和where 類似,只是咱們所設置的環境變量中設置好的路徑中尋找;好比;

 

14.查殺進程
  ps 給出一個系統當前的進程拍照
  配合grep能靈活地找出本身關心的進程

  ps -ef |grep dss
  ps aux
  ps -ef |grep  (經常使用)  
  kill -9  
  看看哪一個進程佔用的內存最大  
  ps -aux|sort +5n

找出進程後比較多的操做是kill進程, (經常使用)

1  [etl@ll-etl-02 ~]$ ps -ef |grep etl                                             
2  etl       1758 29117  0 Jul12 pts/8    00:00:00 vim dpi_mon.sh      
3  [etl@ll-etl-02 ~]$ kill -9 1758

  列出一種比較酷的快速殺程序的方式(先理解在使用,避免誤殺):
  ps -ef |grep "dss -s tm_user_*.tcl" | grep -v grep | awk '{print $2}' | xargs kill -9

  將程序放在先後臺執行
  cp file1 file2 &
  &與ctrl+z 你可使用&或ctrl+z來將命令放在後臺執行.
  fg 是將放在後臺執行的程序再放回前臺.
  jobs

15.dd命令備份
  dd if="input_file" of="out_file" bs="block_size" count="number"
  參數:
  if:就是input file能夠是設備
  of:就是output file也能夠是設備
  bs:規劃的一個block的大小,若是沒有設定時,預設是512bytes
  count:多少個bs的意思.
  dd if=/etc/password of=/tmp/passwd.bak 備份
 
16.mount 加載一個硬件設備
  用法:mount [參數] 要加載的設備 載入點
  eg: mount /dev/cdrom
  cd /mnt/cdrom //進入光盤目錄
   u盤:
   mkdir /mnt/usb;(注:建立掛載目錄)
   mount /mnt/sda1 /mnt/usb;(注:掛載U盤)
   如今就可使用U盤了,在/mnt/usb目錄下的內容就是U盤裏的內容了;
   使用完後,用如下命令卸載U盤便可。
   umount /mnt/usb
   mount     列出系統全部的分區
   mount -t iso9660 /dev/cdrom /mnt/cdrom   掛載光盤
   mount -t vfat /dev/fd0 /mnt/floppy       掛載軟盤
   mount -t vfat -o iocharset=utf8,umask=000 /dev/hda2 /mnt/hda2   掛載fat32分區
   mount -t ntfs -o nls=utf8,umask=000 /dev/hda3 /mnt/hda3         掛載ntfs分區
   Linux-NTFS Project: http://linux-ntfs.sourceforge.net/
   umount /mnt/hda3 缷載
   注:掛載設備前,請先fdisk -l 看一下.

17.su在不退出登錄的狀況下,切換到另外一個身份
    用法: su -l 用戶名(若是用戶名缺省,則切換到root狀態)
  eg:su -l netseek (切換到netseek這個用戶,將提示輸入密碼),加上-表示切換到用戶的環境變量.
    sudo 利用他能夠執行root執行的權限

    su -      切換到root用戶

18.whoami,id,w,lastlog,users,groups
   w       查看用戶登錄信息
   who     查看當前登錄用戶
   last    最近一個月用戶登錄狀況
   lastlog 檢查某特定用戶上次登陸的時間,並格式化輸出上次登陸日誌/var/log/lastlog的內容
   whoami  確認本身身份.
   id      打印出本身的UID以及GID.(UID:用戶身份惟一標識.GID:用戶組身份惟一標識.每個用戶只能有一個惟一的UID和GID.)
   users
   groups  用戶所歸屬的用戶組查詢;
   finger -l netseek root
   finger -s 或者直接finger
   可讓使用者查詢一些其餘使用者的資料
  eg: finger //查看所用用戶的使用資料
  finger root //查看root的資料

19.用戶用過的命令和執行歷史執行的命令
   history 顯示用戶過去命用的命令,用於查找之前執行過的命令,避免重複編寫命令,配合grep使用
   !!執行最近一次的命令

   !vi  執行前一次的vi命令,參數也是上一次執行的(經常使用)

20.uname 查看linux系統信息
   參數:-a 全部信息 -r 版本號 -n 主機名
   cat /etc/issue   查看系統分發版本

21.創建軟鏈接
   ln [-sf] source target
   ln souce-file hard-link
   ln -sf source-file soft-link
   s表示軟鏈接,f表示,如有同名文件在,則將它覆蓋過去.
   注:硬連接不能爲目錄建立,只有文件才能建立硬連接。

22.查看目錄
   du -sh   目錄或者文件(經常使用)
   du -m    du系統默認輸出是以KB,以參數-m表示以MB顯示.
   cat /etc/fstab   查看分區列表
   fdisk -l 
   df -h
   df -ah

23.查看linux系統佔用的資源(top,free,uptime)都是很是實用的,固然還有外部命令如nmon,也是很優秀的。
   top   查看後臺程序,監控系統性能(經常使用)
   top -d 2 每兩秒列新一次
   top -d -2 -p3690 查看某個PID
   top -b -n 2 >/tmp/top.txt 將top的信息進行2次,而後將結果輸出到/tmp/top.txt
  
   free -m 查看系統內存使用狀況

1    [etl@ll-etl-02 ~]$ free -m
2                 total       used       free     shared    buffers     cached
3    Mem:        129040      57877      71163          0         31       6654
4    -/+ buffers/cache:      51190      77850
5    Swap:        81919        231      81687

 uptime  顯示目前系統開機時間(查看開機多久,多少人登錄,過去1,5,15分鐘系統的負載)

1    [etl@ll-etl-02 ~]$ uptime
2    11:38:17 up 102 days, 14:19, 11 users,  load average: 1.43, 1.57, 2.27

24.文件比軟件(文本文件比較明顯):
   cmp  cmp(「compare」的縮寫)命令用來簡要指出兩個文件是否存在差別,它的使用權限是全部用戶
   diff diff命令用於兩個文件之間的比較,並指出二者的不一樣,它的使用權限是全部用戶

25.遠程操做與文件傳輸
   ssh user@remote.machine   遠程登陸主機(經常使用)
   scp user@remote.machine:/remote/path /local/path  遠程拷貝文件
   scp /local/path user@remote.machine:/remote/path

26.編譯c/c++文件
   gcc
   gcc -v 查看GCC版本
   gcc -o test test.c 2>errfile 編譯test.c時如有錯誤信息,則將錯誤信息重定向到errfile

27.chattr +i filename 禁止刪除,chattr -i filename 取消禁止
   lsattr 查看隱藏檔屬性

28.任務自動化執行
   at 執行一次
   crontab 定時循環執行程序(經常使用)
   crontab 介紹
   1 以root登陸
   2 # crontab -e
   3 加入一行
   1 */12 * * * /usr/sbin/ntpdate pool.ntp.org
   分鐘 (0-59)
   小時 (0-23)
   日 期 (1-31)
   月份 (1-12)
   星期 (0-6)//0表明星期天
   
   經常使用命令(查看、編輯):

1    [etl@ll-etl-02 ~]$ crontab -l
2    [etl@ll-etl-02 ~]$ crontab -e

 

29.關機和重啓(非管理員勿動):
   shutwond [-t 秒數] [-rkhncff] 時間 [警告信息]
   -t 秒數:設置在切換至不一樣的runlevel以前,警告和刪除兩信號之彰間的延遲時間(秒)
   -k 發出警告信息,但不是真的要shutdown
   -r shutdown這後從新開機
   -h shutdown這後開機
   -n 不通過init,由shutdown命令自己來作開機工做(不建議你使用)
   -f 從新開機時,跳過fsck指令,不檢查文件系統.
   -F 從新開機時,強迫作fsck檢查.
   -c 將已經正在shutdown的動做取消
   shutdown -h now 馬上關機,其中now至關於時間爲0,halt,poweroff也能夠關機,或者直接init 0
   shutdown -h 20:30  系統將在今晚的8:30關機
   shutdown -h +10    系統再過十分鐘後自動關機.
   shutdown -t3 -r now  馬上從新開機,但在警告和刪除processes這間,
   shutdown -k now  'Hey! Go away! now...' 發出警告信息,但沒有真的關機.
  
   reboot:
   shutdown -r now 幾乎與reboot相同,不關建議用reboot執行以下:
   shutdown -r +30 'The system wiil reboot'
   shutdown -r +10 'Hey!Go away!'  10分鐘後系統重啓.
   #sync; sync; sync; reboot   注:sync將數據同步寫入硬盤
   halt命令至關於shutdown -h now ,表示馬上關機。
   reboot命令至關於shutown -r now ,表示馬上重起。
   
   last reboot命令能夠查看近期的機器重啓狀況

30.如何改變啓動模式運行級別
   vi /etc/inittab
   將5改爲3,啓動後就能夠變成字符模式。
   startx 或者 init 5 就能夠進入圖形化界面.
   runlevel 顯示當前運行級別

  如何切換至單用戶模式
  利用telinit或init(其實telinit只是一個synbol link to init)
  telinit 1 或者 init S 便可,固然telinit S也是能夠的.

  如何使ctrl+alt+del 三鍵失效的方法
  #vi /etc/inittab
  在ca::ctrlaltdel:/sbin/shutdonw -t3 -r now以前加上註釋#
  而後執行#telinit q ,參數q是要telinit從新檢查一次/etc/inittab

31.TAB  巧用tab鍵,當你不知道文件或命令的全名是請連續按兩下tab鍵.(經常使用)
 
32.clear 清屏

33.dmesg |more 顯示開機信息(查看系統啓動時硬件信息)
 
34.改變程序執行的優秀級
   nice    設置優先權 nice -n -5 vi & 用root給一個nice值爲-5,用於執行vi
   renice  調整已存在優先權

35.模塊相關的命令
   lsmod 顯示已經載入系統的模塊
   depmod 分析可載入系統的相依性
   modinfo 顯示kernel模塊的信息
   insmod  載入模塊
   modprobe 自動處理可載入模塊
   rmmod    刪除模塊
 
36.chkconfig --list 顯示各類服務的狀態,利用chkconfig能夠輕鬆管理init腳本.

37.linux的幾種解壓縮命令,很實用,對文本文件的壓縮比一般較高,建議大文件壓縮後下載
   compress aaa  將aaa文件壓縮成爲aaa.Z
   compress -d aaa.z 將aaa.z文件壓縮成aaa
  
   gzip aaa 壓縮命令(經常使用)
   gzip -d aaa.gz  解壓命令
  
   bzip2 -z filename 壓縮,同上加-d參數解壓
   bzcat filename.bz 查看壓縮文件內容
  
   tar -czvf aaa.tar.gz aaa 將目錄aaa壓縮成aaa.tar.gz   (經常使用)
   tar -N '2007/03/01' -zcvf home.tar.gz /home 在/home當中,比2007/03/01新的文件才備份.
   tar --exclude /home/cao -zxvf myfile.tar.gz /home/* /etc 要備份/home,/etc,但不要/home/cao
   cd /tmp; tar -cvf -/etc | tar -xvf - 將/etc/打包後直接解開/tmp底下,而不產生文件.
   tar zxvf aaa.tar.gz 解壓縮命令.
   tar jxvf aaa.tar.bz2 解壓命令
   tar zxvf aaa.tar.gz -C /var/www 將aaa.tar.gz解壓到/var/www目錄下
   cpio -covB > [file|device] 備份
   cpio -icduv < [file|device] 還原

38.網絡命令
   ifconfig 顯示或設置網絡設備,能夠查看當前ip,相似於windows裏的ipconfig(經常使用)
   service network restart(/etc/rc.d/init.d/network restart) 重啓網卡
   ifdown eth0 關閉網卡
   ifup eth0 開啓網卡
   route -n 查看路由表
   route add -net 192.168.20.1 netmask 255.255.255.0 dev eth0
  
   traceroute
   
   hostname 顯示主機名
   hostname -i 顯示當前主機名的IP.

39.系統集成管理菜單.
   setup   系統服務管理命令
   ntsysv  設置系統服務

40.fdisk /mbr 刪除GRUB

41.數據庫啓動,開源的mysql用的比較廣泛
 啓動mysql:
 service mysqld start(/etc/rc.d/init.d/mysqld start)
 mysql -uroot -p 輸入密碼便可操做mysql數據庫.

 啓動Oracle
 su - oracle
 $lsnrctl stop
 $lsnrctl start
 sqlplus /nolog
 conn /as sysdba(connected)
 startup

42.安裝軟件包放較多,其中rpm爲最簡單易用切不用連網
 rpm包安裝:
 rpm -ivh xxx.rpm         安裝rpm包
 rpm -qa --last | less    根據安裝日期顯示已經安裝的包
 rpm -qa |grep mysql -i   查詢系統是否安裝mysql包(-i,忽略大小寫)
 rpm -e                   刪除安裝的軟件包
 rpm -e mysql* --nodpes   強制刪除相關的軟件包
 rpm --test               測試安裝
 rpm -qi                  查詢mysql套件的說明資料
 rpm -qpl xxx.rpm         查看rpm包內含的內容.
 rpm -qc[d]               設定檔與說明檔
 rpm -Uvh                 升級安裝
 rpmbuild --bb SPECS/xxx.spec 從新裝將xxx.spec編譯成rpm包.
 rpmbuild --rebuild packagename.src.rpm 從新把.src.rpm編譯成rpm包.
 
 源碼編譯安裝(經典)
 ./configure              檢查系統信息(./configure --help | more 幫助信息,能夠看到相關的參數設定)
 make clean               清除以前留下的文件
 make                     編譯
 make install             安裝
 注:源碼包安裝,通常先將文件解壓,安裝過程大體上面幾步,具體說明通常看法壓後目錄裏的(INSTALL,READEME說明.)

43.查看系統的編碼
 locale  查看系統編碼設置,將crt軟件的編碼配置一致以保證遠程登陸正常顯示

1  [etl@ll-etl-02 ~]$ locale
2  LANG=zh_CN.UTF-8
3  LC_CTYPE="zh_CN.UTF-8"
4  LC_NUMERIC="zh_CN.UTF-8"

 

44.查看網絡端口的使用狀況
 netstat  查詢網絡鏈接、路由表、端口使用狀況、多播用戶關係等。
 一般服務器上應用都有本身專屬的偵聽端口,靈活地使用netstat能很好的知道端口的使用狀況。
   netstat 查看網絡鏈接狀況
   netstat -i 顯示網卡運行狀況
   netstat -r 查看主機的路由列表
 詳細的參數,請參見man page

1  [etl@ll-etl-02 ~]$ netstat -anp |grep 7502
2  (Not all processes could be identified, non-owned process info
3   will not be shown, you would have to be root to see it all.)
4  tcp        0      0 :::7502                     :::*                        LISTEN      11513/etl_realstream5  tcp   7663357      0 ::ffff:10.173.255.85:7502   ::ffff:10.168.33.97:59381   ESTABLISHED 11513/java          
6  tcp   7673984      0 ::ffff:10.173.255.85:7502   ::ffff:10.168.33.97:59363   ESTABLISHED 11513/java          
7  tcp   7678747      0 ::ffff:10.173.255.85:7502   ::ffff:10.168.33.97:59437   ESTABLISHED 11513/java    
相關文章
相關標籤/搜索