小白學習Linux命令

 

前幾天一氣之下怒刪win10,裝了最新版的ubuntu18.10。初步使用總結如下:html

一、雖然Ubuntu的UI作的也還能夠,也多了不少軟件,最明顯的就是自帶了中文輸入法,當年安裝14版的時候仍是下載的搜狗輸入法,Ubuntu18自帶輸入法雖然沒有那麼智能,可是湊和能用。使用linux就是爲了體驗一下Terminal的樂趣,想要只使用Terminal裝一下X。首先最迫切的就是熟悉各類經常使用命令。雖然命令繁多,可是使用熟練了以後會方便不少,並且若是對命令有點模糊記得不許確也不要緊,輸入記得的幾個字母而後Tab鍵能夠實現自動補全命令,按兩次Tab健能夠列出全部包含以上字母的命令。java

個人思想是邊用邊學,首先先掌握一些經常使用的,迫切須要的命令,以後用到哪一個再查找哪一個命令,Learn Vim Progressively 這篇介紹Vim的博客的思想就是這樣的,首先考慮如何在linux下survive。我14年就接觸了linux可是隻是安裝了下,而後就沒有而後了。node

目前主要的需求:linux

  • 一、關機、重啓操做;
  • 二、對文本文檔的增刪改查;
  • 三、文件和目錄
  • 四、對文件打包壓縮;
  • 五、記不住文件在哪以後須要對文件搜索;
  • 六、安裝的雙系統須要使用其餘盤裏的文件的話須要掛載一個文件系統 ;
  • 七、使用windows系統以後習慣了常看看磁盤還有多大空間。

這樣一看需求還挺多<-^->。接下來把主要的命令總結一下,目前我初步使用主要使用黑體的就OK了,等之後有需求了再查其餘命令。ubuntu

一、關機、重啓操做;

  • sync :把內存中的數據寫到磁盤中(關機、重啓前請先執行sync)
命令 含義

shutdown -h nowvim

或init 0windows

或telinit 0緩存

當即關機
shutdown -h hours:minutes

按預約時間關閉系統  如:安全

shutdown -h 20:00:預約時間關閉系統(晚上8點關機,若是如今超過8點,則明晚8點)bash

shutdown -h +10 :預約時間關閉系統(10分鐘後關機)

shutdown -c 取消按預約時間關閉系統 

shutdown -r now

reboot

重啓
logout 註銷 

二、對文本文檔的增刪改查;

跑偏一句,在Ubuntu想要使用右鍵新建文檔,能夠在主目錄(中文版的,英文版是home文件夾)下的模板(英文版 Templates)中放一個空的文本文件(不佔地),而後在文件夾中右鍵就能夠看見New Document選項,也能夠放其餘文件好比word、ppt等。

在GUI的桌面環境中,建立文件是很簡單的,例如Windows平臺中,大多數狀況下只須要點擊右鍵,就能夠新建文本文檔等各種文件。在終端中建立文件,大致有這麼三種方式,一、使用touch命令進行建立,二、使用文本編輯器進行建立,三、使用重定向符號進行建立:

一、使用touch命令進行建立

touch test.txt

touch命令最初的做用是對文件的「訪問時間」或「修改時間」進行修改,當touch命令指定的文件並不存在時,touch命令會新建一個指定名稱的文件。

二、使用文本編輯器進行建立

或vi test.txt
或vim test.txt

Linux發行版中,終端環境下大多帶有一個或多個文本編輯器,好比vi、vim、nano等文本編輯器,GUI的桌面環境中也會帶有一些文本編輯器,好比Ubuntu的Gedit等編輯器
大多數文件其實都是文本文檔,因此使用文本編輯器進行文件建立,是一種比較經常使用的文件建立方式,須要認真掌握。

三、使用重定向符號進行建立

> tedu_1.txt

重定向是終端中常常會用到的一種日誌保存方法,一般終端中的命令執行時,會即時的將執行結果輸出到終端中,實現用戶與終端的實時交互。可是許多時候,命令輸出的信息不少、很長,終端中並不能完整顯示,或者但願在關閉終端後依然可以查看該程序輸出的信息,此時就可使用重定向的方式,將輸出的信息重定向到其餘文件中進行保存。

以上只是單獨使用重定向符號進行文件的建立,更多的時候重定向符號是將命令執行的結果進行轉儲使用。

#使用ls命令輸出當前文件夾下的文件及目錄名稱
#同時將結果重定向到tedu_3.txt文件中
#注意,此時命令執行後並不會在終端中輸出任何信息
os@DESKTOP-2DHQBVS:~$ ls > tedu_3.txt
#執行ls命令,可見當前文件夾下已經建立了tedu_3.txt文件
os@DESKTOP-2DHQBVS:~$ ls
tedu_1.txt  tedu_2.txt  tedu_3.txt  tedu_nano.txt  tedu.txt
#使用nano編輯器打開tedu_3.txt文件,能夠看到,輸出內容爲原本應該由終端顯示的信息
os@DESKTOP-2DHQBVS:~$ nano tedu_3.txt
  GNU nano 2.5.3           File: tedu_3.txt                            
tedu_1.txt
tedu_2.txt
tedu_3.txt
tedu_nano.txt
tedu.txt

                           [ Read 5 lines ]
^G Get Help   ^O Write Out  ^W Where Is   ^K Cut Text   ^J Justify
^X Exit       ^R Read File  ^\ Replace    ^U Uncut Text ^T To Spell
  • 「>」操做符:當目標文件已存在時,「>」輸出的內容將覆蓋源文件中已有的內容;
  • 「>>」操做符:當目標文件已存在時,「>>」會將新內容追加到源文件內容的後面。

一般Linux系統中文件名中並無特殊要求,除NULL(「\0」)和「/」以外,全部字符均可以。可是因爲Linux終端中有不少指令操做符,因此在建立新文件時,文件名最好可以避免一些特殊字符,如「. ? > < ; & ! [ ] { } | \ ’ `」等,這些符號在終端中都有着特殊的意義,好比「.」開頭文件爲隱藏文件,「|」符號爲管道符。
這一小段稍有修改,主要來自簡書做者:vvaa01  連接:https://www.jianshu.com/p/002620cbdf4d 著做權歸做者全部,任何形式的轉載都請聯繫做者得到受權並註明出處。

三、文件和目錄

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 列出已知的編碼

四、對文件打包壓縮;

打包和壓縮文件 
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格式壓縮包 

五、文件搜索;

記不住文件在哪以後須要對文件進行搜索。

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網絡共享 

七、磁盤空間 

使用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類系統) 

 

其餘我目前不常用的命令:

系統信息

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 

用戶和羣組

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 顯示特殊的屬性 

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 從第一個字節開始正向查看文件的內容     cat命令參考講的很清楚: https://www.cnblogs.com/perfy/archive/2012/07/23/2605550.html
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命令。

 

詳細狀況請參考sun官方文檔。
http://java.sun.com/j2se/1.7.0/docs/tooldocs/share/jps.html

以上的命令總結來自博客園鴻燕藏鋒

連接:https://www.cnblogs.com/yjd_hycf_space/p/7730690.html

參考:http://www.cnblogs.com/caozy/p/9261224.html

相關文章
相關標籤/搜索