Linux面試匯總


1. 硬鏈接和軟連接區別

* 硬鏈接: 與普通文件沒什么不同,inode 都指向同一個文件在硬盤中的區塊

* 軟鏈接: 保存了其代表的文件的絕對路徑,是另外一種文件,在硬盤上有獨立的區塊,訪問時替換自身路徑。

 

  2. kill用法,某個進程殺不掉的原因(進入內核態,忽略kill信號)

  * 先用ps查找進程:ps -ef|grep vim 

  * 列出所有信號名稱: kill -l

  * 徹底殺死進程: kill -9

  * 殺死指定用戶的進程: kill -u

 

Linux系統的特點?

穩定的系統 :打個比方,安裝Linux的主機連續運行一年以上不曾宕機、不必關機是很平常的事,我的windows系統今早打開時是黑屏,強行關機之后才恢復,原因不明

安全性和漏洞的快速修補 :Linux有眾多電腦高手在使用,所以維護者眾多,更新維護很快,而windows則是所有人都會用,且不開源

多任務,多用戶 :你可以在一個Linux主機上規划出不同等級的用戶,而且每個用戶登錄系統時工作環境可以不同,此外你還可以允許不同用戶在同一時間登陸主機以使用主機的資源

用戶和用戶組的規划 :在linux的機器上,文件可分為可讀可寫可執行三類(windows上也可以設置這些屬性,在命令行里,會在以后的windows博客里寫出來)此外,這些屬性還可以分為三類:分別是文件擁有者、文件所屬用戶組、其他非擁有着與用戶組者,這對於項目或者其他項目開發者具有良好的保密性

相對較少的系統資源占用 :這是最吸引眼球的地方,目前市面上任何一款個人計算機都可以達到使用Linux搭建一個服務上百人以上的主機

可定制裁剪,移植到嵌入式平台(如安卓設備) 

可選擇的多種圖形用戶界面(如GNOME,KDE)

 Linux與win的區別

windows平台:數量和質量的優勢,不過大部分為收費軟件;由微軟官方提供重要支持和服務                                                                                                                     

linux平台:大都為開源自由軟件,用戶可以修改定制和再發布,由於基本免費沒有資金支持,部分軟件質量和體驗欠缺;有全球所有的Linux開發者和自由軟件社區提供支持

 

·安全性

Windows平台:三天兩頭打補丁安裝系統安全更新,還是會中病毒木馬什么的,各位用戶自己感受。 

Linux平台:要說linux沒有安全問題,那當然是不可能的,不會中病毒什么的,也不可能,這一點仁者見仁智者見智,相對來說肯定比Windows平台要更加安全,使用linux你也不用裝殺毒軟件了。

系統信息 
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 



關機 (系統的關機、重啟以及登出
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 顯示一個二進制文件或可執行文件的完整路徑 



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



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



用戶和群組 
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格式壓縮包 



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/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/linuxps命令。

 

 

問題一:

絕對路徑用什么符號表示?當前目錄、上層目錄用什么表示?主目錄用什么表示? 切換目錄用什么命令?

絕對路徑: 如/etc/init.d

當前目錄和上層目錄: ./  ../

主目錄: ~/

切換目錄: cd

 

問題二:

怎么查看當前進程?怎么執行退出?怎么查看當前路徑?

查看當前進程: ps

執行退出: exit

查看當前路徑: pwd

 

問題三:

怎么清屏?怎么退出當前命令?怎么執行睡眠?怎么查看當前用戶 id?查看指定幫助用什么命令?

清屏: clear

退出當前命令: ctrl+c 徹底退出

執行睡眠 : ctrl+z 掛起當前進程fg 恢復后台

查看當前用戶 id: ”id“:查看顯示目前登陸賬戶的 uid 和 gid 及所屬分組及用戶名

查看指定幫助: 如 man adduser 這個很全 而且有例子; adduser --help 這個告訴你一些常用參數; info adduesr;

 

問題四

Ls 命令執行什么功能? 可以帶哪些參數,有什么區別?

ls 執行的功能: 列出指定目錄中的目錄,以及文件

哪些參數以及區別: a 所有文件l 詳細信息,包括大小字節數,可讀可寫可執行的權限等

 

問題五:

建立軟鏈接(快捷方式),以及硬鏈接的命令。

軟鏈接: ln -s slink source

硬鏈接: ln link source

 

問題六:

目錄創建用什么命令?創建文件用什么命令?復制文件用什么命令?

創建目錄: mkdir

創建文件:典型的如 touch,vi 也可以創建文件,其實只要向一個不存在的文件輸出,都會創建文件

復制文件: cp 7. 文件權限修改用什么命令?格式是怎么樣的?

文件權限修改: chmod

格式如下:

$ chmod u+x file 給 file 的屬主增加執行權限

$ chmod 751 file 給 file 的屬主分配讀、寫、執行(7)的權限,給 file 的所在組分配讀、執行(5)的權限,給其他用戶分配執行(1)的權限

$ chmod u=rwx,g=rx,o=x file 上例的另一種形式

$ chmod =r file 為所有用戶分配讀權限

$ chmod 444 file 同上例

$ chmod a-wx,a+r file同上例

$ chmod -R u+r directory 遞歸地給 directory 目錄下所有文件和子目錄的屬主分配讀的權限

 

問題八:

查看文件內容有哪些命令可以使用?

vi 文件名 #編輯方式查看,可修改

cat 文件名 #顯示全部文件內容

more 文件名 #分頁顯示文件內容

less 文件名 #與 more 相似,更好的是可以往前翻頁

tail 文件名 #僅查看尾部,還可以指定行數

head 文件名 #僅查看頭部,還可以指定行數

 

問題九:

隨意寫文件命令?怎么向屏幕輸出帶空格的字符串,比如”hello world”?

寫文件命令:vi

 

向屏幕輸出帶空格的字符串:echo hello world

 

 

 

問題十:

 

終端是哪個文件夾下的哪個文件?黑洞文件是哪個文件夾下的哪個命令?

答案:

終端  /dev/tty

 

黑洞文件  /dev/null

 

問題十一:

 

移動文件用哪個命令?改名用哪個命令?

答案:

mv mv

 

問題十二:

 

復制文件用哪個命令?如果需要連同文件夾一塊復制呢?如果需要有提示功能呢?

答案:

cp cp -r  ????

 

問題十三:

 

刪除文件用哪個命令?如果需要連目錄及目錄下文件一塊刪除呢?刪除空文件夾用什么命令?

答案:

rm rm -r rmdir

 

問題十四:

 

Linux 下命令有哪幾種可使用的通配符?分別代表什么含義?

答案:

“?”可替代單個字符。

 

“*”可替代任意多個字符。

 

方括號“[charset]”可替代 charset 集中的任何單個字符,如[a-z],[abABC]

 

 

 

問題十五:

 

用什么命令對一個文件的內容進行統計?(行號、單詞數、字節數)

答案:

 

wc 命令 - c 統計字節數 - l 統計行數 - w 統計字數。

 

問題十六:

 

Grep 命令有什么用? 如何忽略大小寫? 如何查找不含該串的行?

答案:

是一種強大的文本搜索工具,它能使用正則表達式搜索文本,並把匹 配的行打印出來。

grep [stringSTRING] filename grep [^string] filename

 

問題十七:

 

Linux 中進程有哪幾種狀態?在 ps 顯示出來的信息中,分別用什么符號表示的?

答案:

(1)、不可中斷狀態:進程處於睡眠狀態,但是此刻進程是不可中斷的。不可中斷, 指進程不響應異步信號。

(2)、暫停狀態/跟蹤狀態:向進程發送一個 SIGSTOP 信號,它就會因響應該信號 而進入 TASK_STOPPED 狀態;當進程正在被跟蹤時,它處於 TASK_TRACED 這個特殊的狀態。

“正在被跟蹤”指的是進程暫停下來,等待跟蹤它的進程對它進行操作。

 

(3)、就緒狀態:在 run_queue 隊列里的狀態

 

(4)、運行狀態:在 run_queue 隊列里的狀態

(5)、可中斷睡眠狀態:處於這個狀態的進程因為等待某某事件的發生(比如等待 socket 連接、等待信號量),而被掛起

(6)、zombie 狀態(僵屍):父親沒有通過 wait 系列的系統調用會順便將子進程的屍體(task_struct)也釋放掉

(7)、退出狀態

 

D 不可中斷 Uninterruptible(usually IO)

R 正在運行,或在隊列中的進程

S 處於休眠狀態

T 停止或被追蹤

Z 僵屍進程

W 進入內存交換(從內核 2.6 開始無效)

X 死掉的進程

 

 

 

問題十八:

 

怎么使一個命令在后台運行?

答案:

一般都是使用 & 在命令結尾來讓程序自動運行。(命令后可以不追加空格)

 

 

問題十九:

 

利用 ps 怎么顯示所有的進程? 怎么利用 ps 查看指定進程的信息?

答案:

ps -ef (system v 輸出)

 

ps -aux bsd 格式輸出

 

ps -ef | grep pid

 

問題二十:

 

哪個命令專門用來查看后台任務?

 

答案:

 

job -l

 

 

問題二十一:

 

把后台任務調到前台執行使用什么命令?把停下的后台任務在后台執行起來用什么命令?

答案:

把后台任務調到前台執行 fg

 

把停下的后台任務在后台執行起來 bg

 

 

 

問題二十二:

 

終止進程用什么命令? 帶什么參數?

 

答案:

 

kill [-s <信息名稱或編號>][程序] 或 kill [-l <信息編號>]

 

kill-9 pid

 

 

 

問題二十三:

 

怎么查看系統支持的所有信號?

 

答案:

 

kill -l

 

問題二十四:

 

搜索文件用什么命令? 格式是怎么樣的?

 

答案:

 

find <指定目錄> <指定條件> <指定動作>

 

whereis 加參數與文件名

 

locate 只加文件名

 

find 直接搜索磁盤,較慢。

 

find / -name "string*"

 

 

 

問題二十五:

 

查看當前誰在使用該主機用什么命令? 查找自己所在的終端信息用什么命令?

答案:

查找自己所在的終端信息:who am i

 

查看當前誰在使用該主機:who

 

 

 

問題二十六:

 

使用什么命令查看用過的命令列表?

 

答案:

 

history

 

 

問題二十七:

 

使用什么命令查看磁盤使用空間? 空閑空間呢?

 

答案:

 

df -hl

文件系統 容量 已用 可用 已用% 掛載點

Filesystem Size Used Avail Use% Mounted on /dev/hda2 45G 19G 24G 44% /

/dev/hda1 494M 19M 450M 4% /boot

 

問題二十八:

 

使用什么命令查看網絡是否連通?

答案:

netstat

 

問題二十九:

 

使用什么命令查看 ip 地址及接口信息?

 

答案:

 

ifconfig

 

問題三十:

 

查看各類環境變量用什么命令?

 

答案:

 

查看所有 env

查看某個,如 home: env $HOME

 

問題三十一:

 

通過什么命令指定命令提示符?

 

答案:

 

\u:顯示當前用戶賬號

 

\h:顯示當前主機名

 

\W:只顯示當前路徑最后一個目錄

 

\w:顯示當前絕對路徑(當前用戶目錄會以~代替)

 

$PWD:顯示當前全路徑

 

\$:顯示命令行’$'或者’#'符號

 

\#:下達的第幾個命令

 

\d:代表日期,格式為week day month date,例如:"MonAug1"

 

\t:顯示時間為24小時格式,如:HH:MM:SS

 

\T:顯示時間為12小時格式

 

\A:顯示時間為24小時格式:HH:MM

 

\v:BASH的版本信息 如export PS1=’[\u@\h\w\#]\$‘

 

 

 

問題三十二:

 

查找命令的可執行文件是去哪查找的? 怎么對其進行設置及添加?

 

答案:

 

whereis [-bfmsu][-B <目錄>...][-M <目錄>...][-S <目錄>...][文件...]

 

補充說明:whereis 指令會在特定目錄中查找符合條件的文件。這些文件的烈性應屬於原始代碼,二進制文件,或是幫助文件。

 

-b   只查找二進制文件。

 

-B<目錄> 只在設置的目錄下查找二進制文件。 -f 不顯示文件名前的路徑名稱。

-m   只查找說明文件。

-M<目錄> 只在設置的目錄下查找說明文件。 -s 只查找原始代碼文件。

-S<目錄> 只在設置的目錄下查找原始代碼文件。 -u 查找不包含指定類型的文件。

which 指令會在 PATH 變量指定的路徑中,搜索某個系統命令的位置,並且返回第一個搜索結果。

-n 指定文件名長度,指定的長度必須大於或等於所有文件中最長的文件名。

-p 與-n 參數相同,但此處的包括了文件的路徑。 -w 指定輸出時欄位的寬度。

-V   顯示版本信息

 

 

 

問題三十三:

 

通過什么命令查找執行命令?

答案:

which 只能查可執行文件

 

whereis 只能查二進制文件、說明文檔,源文件等

 

 

問題三十四:

 

怎么對命令進行取別名?

答案:

alias la='ls -a'

 

問題三十五:

 

du 和 df 的定義,以及區別?

答案:

 

du 顯示目錄或文件的大小

 

df 顯示每個<文件>所在的文件系統的信息,默認是顯示所有文件系統。

(文件系統分配其中的一些磁盤塊用來記錄它自身的一些數據,如 i 節點,磁盤分布圖,間接塊,超級塊等。這些數據對大多數用戶級的程序來說是不可見的,通常稱為 Meta Data。) du 命令是用戶級的程序,它不考慮 Meta Data,而 df 命令則查看文件系統的磁盤分配圖並考慮 Meta Data。

df 命令獲得真正的文件系統數據,而 du 命令只查看文件系統的部分情況。

 

問題三十六:

 

awk 詳解。

答案:

 

awk '{pattern + action}' {filenames}

#cat /etc/passwd |awk -F ':' '{print $1"\t"$7}' //-F 的意思是以':'分隔 root /bin/bash

daemon /bin/sh 搜索/etc/passwd 有 root 關鍵字的所有行

 

#awk -F: '/root/' /etc/passwd root:x:0:0:root:/root:/bin/bash

 

 

 

問題三十七:

 

當你需要給命令綁定一個宏或者按鍵的時候,應該怎么做呢?

 

答案:

 

可以使用bind命令,bind可以很方便地在shell中實現宏或按鍵的綁定。

 

在進行按鍵綁定的時候,我們需要先獲取到綁定按鍵對應的字符序列。

 

比如獲取F12的字符序列獲取方法如下:先按下Ctrl+V,然后按下F12 .我們就可以得到F12的字符序列 ^[[24~。

 

接着使用bind進行綁定。

 

[root@localhost ~]# bind ‘”\e[24~":"date"'

 

注意:相同的按鍵在不同的終端或終端模擬器下可能會產生不同的字符序列。

 

【附】也可以使用showkey -a命令查看按鍵對應的字符序列。

 

 

 

問題三十八:

 

如果一個linux新手想要知道當前系統支持的所有命令的列表,他需要怎么做?

 

答案:

 

使用命令compgen ­-c,可以打印出所有支持的命令列表。

 

[root@localhost ~]$ compgen -c

 

l.

 

ll

 

ls

 

which

 

if

 

then

 

else

 

elif

 

fi

 

case

 

esac

 

for

 

select

 

while

 

until

 

do

 

done

 

 

 

 

問題三十九:

 

如果你的助手想要打印出當前的目錄棧,你會建議他怎么做?

 

答案:

 

使用Linux 命令dirs可以將當前的目錄棧打印出來。

 

[root@localhost ~]# dirs

 

/usr/share/X11

 

【附】:目錄棧通過pushd popd 來操作。

 

 

 

問題四十:

 

你的系統目前有許多正在運行的任務,在不重啟機器的條件下,有什么方法可以把所有正在運行的進程移除呢?

 

答案:

 

使用linux命令 ’disown -r ’可以將所有正在運行的進程移除。

 

 

 

問題四十一:

 

bash shell 中的hash 命令有什么作用?

 

答案:

 

linux命令’hash’管理着一個內置的哈希表,記錄了已執行過的命令的完整路徑, 用該命令可以打印出你所使用過的命令以及執行的次數。

 

[root@localhost ~]# hash

 

hits command

 

2 /bin/ls

 

2 /bin/su

 

 

 

問題四十二:

 

哪一個bash內置命令能夠進行數學運算。

 

答案:

 

bash shell 的內置命令let 可以進行整型數的數學運算。

 

#! /bin/bash

let c=a+b

 

 

 

問題四十三:

 

怎樣一頁一頁地查看一個大文件的內容呢?

 

答案:

 

通過管道將命令”cat file_name.txt” 和 ’more’ 連接在一起可以實現這個需要.

 

[root@localhost ~]# cat file_name.txt | more

 

 

 

問題四十四:

 

數據字典屬於哪一個用戶的?

 

答案:

 

數據字典是屬於’SYS’用戶的,用戶‘SYS’ 和 ’SYSEM’是由系統默認自動創建的

 

 

 

問題四十五:

 

怎樣查看一個linux命令的概要與用法?假設你在/bin目錄中偶然看到一個你從沒見過的的命令,怎樣才能知道它的作用和用法呢?

 

答案:

 

使用命令whatis 可以先出顯示出這個命令的用法簡要,比如,你可以使用whatis zcat 去查看‘zcat’的介紹以及使用簡要。

 

[root@localhost ~]# whatis zcat

 

zcat [gzip] (1) – compress or expand files

 

 

 

問題四十六:

 

使用哪一個命令可以查看自己文件系統的磁盤空間配額呢?

 

答案:

 

使用命令repquota 能夠顯示出一個文件系統的配額信息

 

【附】只有root用戶才能夠查看其它用戶的配額。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM