注:本文轉載自瘋狂的矩陣一文,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