看起來(lái)貌似沒(méi)有問(wèn)題。但是把“/”去掉肯定不行啊。根目錄都沒(méi)有了怎么搞。
創(chuàng)新互聯(lián)從2013年創(chuàng)立,先為福州等服務(wù)建站,福州等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為福州企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問(wèn)題。
就我知道的,一般對(duì)于tar包有兩種語(yǔ)法方式。舉個(gè)例子,就你的文件夾來(lái)說(shuō),我在/home/jie
有個(gè)Desktop文件,大包成test.tar。那么,
1.如果光大包不壓縮,則為:tar -cvf test.tar /home/jie/Desktop/
2.打包后,以dzip壓縮。那么:tar -zcvf test.tar.gz /home/jie/Desktop
我現(xiàn)在身邊沒(méi)有LINUX虛擬機(jī),好久沒(méi)用,忘記了。那么你再試試打包的時(shí)候加上路徑試試呢?比如寫(xiě)成/home/test.tar。
不好意思,忘記了。要是來(lái)得及,等我過(guò)兩天回去試試
Linux常用命令大全
系統(tǒng)信息
arch 顯示機(jī)器的處理器架構(gòu)(1)
uname -m 顯示機(jī)器的處理器架構(gòu)(2)
uname -r 顯示正在使用的內(nèi)核版本
dmidecode -q 顯示硬件系統(tǒng)部件 - (SMBIOS / DMI)
hdparm -i /dev/hda 羅列一個(gè)磁盤(pán)的架構(gòu)特性
hdparm -tT /dev/sda 在磁盤(pán)上執(zhí)行測(cè)試性讀取操作
cat /proc/cpuinfo 顯示CPU info的信息
cat /proc/interrupts 顯示中斷
cat /proc/meminfo 校驗(yàn)內(nèi)存使用
cat /proc/swaps 顯示哪些swap被使用
cat /proc/version 顯示內(nèi)核的版本
cat /proc/net/dev 顯示網(wǎng)絡(luò)適配器及統(tǒng)計(jì)
cat /proc/mounts 顯示已加載的文件系統(tǒng)
lspci -tv 羅列 PCI 設(shè)備
lsusb -tv 顯示 USB 設(shè)備
date 顯示系統(tǒng)日期
cal 2007 顯示2007年的日歷表
date 041217002007.00 設(shè)置日期和時(shí)間 - 月日時(shí)分年.秒
clock -w 將時(shí)間修改保存到 BIOS
關(guān)機(jī) (系統(tǒng)的關(guān)機(jī)、重啟以及登出 )
shutdown -h now 關(guān)閉系統(tǒng)(1)
init 0 關(guān)閉系統(tǒng)(2)
telinit 0 關(guān)閉系統(tǒng)(3)
shutdown -h hours:minutes 按預(yù)定時(shí)間關(guān)閉系統(tǒng)
shutdown -c 取消按預(yù)定時(shí)間關(guān)閉系統(tǒng)
shutdown -r now 重啟(1)
reboot 重啟(2)
logout 注銷
文件和目錄
cd /home 進(jìn)入 '/ home' 目錄'
cd .. 返回上一級(jí)目錄
cd ../.. 返回上兩級(jí)目錄
cd 進(jìn)入個(gè)人的主目錄
cd ~user1 進(jìn)入個(gè)人的主目錄
cd - 返回上次所在的目錄
pwd 顯示工作路徑
ls 查看目錄中的文件
ls -F 查看目錄中的文件
ls -l 顯示文件和目錄的詳細(xì)資料
ls -a 顯示隱藏文件
ls *[0-9]* 顯示包含數(shù)字的文件名和目錄名
tree 顯示文件和目錄由根目錄開(kāi)始的樹(shù)形結(jié)構(gòu)(1)
lstree 顯示文件和目錄由根目錄開(kāi)始的樹(shù)形結(jié)構(gòu)(2)
mkdir dir1 創(chuàng)建一個(gè)叫做 'dir1' 的目錄'
mkdir dir1 dir2 同時(shí)創(chuàng)建兩個(gè)目錄
mkdir -p /tmp/dir1/dir2 創(chuàng)建一個(gè)目錄樹(shù)
rm -f file1 刪除一個(gè)叫做 'file1' 的文件'
rmdir dir1 刪除一個(gè)叫做 'dir1' 的目錄'
rm -rf dir1 刪除一個(gè)叫做 'dir1' 的目錄并同時(shí)刪除其內(nèi)容
rm -rf dir1 dir2 同時(shí)刪除兩個(gè)目錄及它們的內(nèi)容
mv dir1 new_dir 重命名/移動(dòng) 一個(gè)目錄
cp file1 file2 復(fù)制一個(gè)文件
cp dir/* . 復(fù)制一個(gè)目錄下的所有文件到當(dāng)前工作目錄
cp -a /tmp/dir1 . 復(fù)制一個(gè)目錄到當(dāng)前工作目錄
cp -a dir1 dir2 復(fù)制一個(gè)目錄
ln -s file1 lnk1 創(chuàng)建一個(gè)指向文件或目錄的軟鏈接
ln file1 lnk1 創(chuàng)建一個(gè)指向文件或目錄的物理鏈接
touch -t 0712250000 file1 修改一個(gè)文件或目錄的時(shí)間戳 - (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 從 '/' 開(kāi)始進(jìn)入根文件系統(tǒng)搜索文件和目錄
find / -user user1 搜索屬于用戶 'user1' 的文件和目錄
find /home/user1 -name \*.bin 在目錄 '/ home/user1' 中搜索帶有'.bin' 結(jié)尾的文件
find /usr/bin -type f -atime +100 搜索在過(guò)去100天內(nèi)未被使用過(guò)的執(zhí)行文件
find /usr/bin -type f -mtime -10 搜索在10天內(nèi)被創(chuàng)建或者修改過(guò)的文件
find / -name \*.rpm -exec chmod 755 '{}' \; 搜索以 '.rpm' 結(jié)尾的文件并定義其權(quán)限
find / -xdev -name \*.rpm 搜索以 '.rpm' 結(jié)尾的文件,忽略光驅(qū)、捷盤(pán)等可移動(dòng)設(shè)備
locate \*.ps 尋找以 '.ps' 結(jié)尾的文件 - 先運(yùn)行 'updatedb' 命令
whereis halt 顯示一個(gè)二進(jìn)制文件、源碼或man的位置
which halt 顯示一個(gè)二進(jìn)制文件或可執(zhí)行文件的完整路徑
掛載一個(gè)文件系統(tǒng)
mount /dev/hda2 /mnt/hda2 掛載一個(gè)叫做hda2的盤(pán) - 確定目錄 '/ mnt/hda2' 已經(jīng)存在
umount /dev/hda2 卸載一個(gè)叫做hda2的盤(pán) - 先從掛載點(diǎn) '/ mnt/hda2' 退出
fuser -km /mnt/hda2 當(dāng)設(shè)備繁忙時(shí)強(qiáng)制卸載
umount -n /mnt/hda2 運(yùn)行卸載操作而不寫(xiě)入 /etc/mtab 文件- 當(dāng)文件為只讀或當(dāng)磁盤(pán)寫(xiě)滿時(shí)非常有用
mount /dev/fd0 /mnt/floppy 掛載一個(gè)軟盤(pán)
mount /dev/cdrom /mnt/cdrom 掛載一個(gè)cdrom或dvdrom
mount /dev/hdc /mnt/cdrecorder 掛載一個(gè)cdrw或dvdrom
mount /dev/hdb /mnt/cdrecorder 掛載一個(gè)cdrw或dvdrom
mount -o loop file.iso /mnt/cdrom 掛載一個(gè)文件或ISO鏡像文件
mount -t vfat /dev/hda5 /mnt/hda5 掛載一個(gè)Windows FAT32文件系統(tǒng)
mount /dev/sda1 /mnt/usbdisk 掛載一個(gè)usb 捷盤(pán)或閃存設(shè)備
mount -t smbfs -o username=user,password=pass //WinClient/share /mnt/share 掛載一個(gè)windows網(wǎng)絡(luò)共享
磁盤(pán)空間
df -h 顯示已經(jīng)掛載的分區(qū)列表
ls -lSr |more 以尺寸大小排列文件和目錄
du -sh dir1 估算目錄 'dir1' 已經(jīng)使用的磁盤(pán)空間'
du -sk * | sort -rn 以容量大小為依據(jù)依次顯示文件和目錄的大小
rpm -q -a --qf '%10{SIZE}t%{NAME}n' | sort -k1,1n 以大小為依據(jù)依次顯示已安裝的rpm包所使用的空間 (fedora, redhat類系統(tǒng))
dpkg-query -W -f='${Installed-Size;10}t${Package}n' | sort -k1,1n 以大小為依據(jù)顯示已安裝的deb包所使用的空間 (ubuntu, debian類系統(tǒng))
返回頂部索引 ^
用戶和群組
groupadd group_name 創(chuàng)建一個(gè)新用戶組
groupdel group_name 刪除一個(gè)用戶組
groupmod -n new_group_name old_group_name 重命名一個(gè)用戶組
useradd -c "Name Surname " -g admin -d /home/user1 -s /bin/bash user1 創(chuàng)建一個(gè)屬于 "admin" 用戶組的用戶
useradd user1 創(chuàng)建一個(gè)新用戶
userdel -r user1 刪除一個(gè)用戶 ( '-r' 排除主目錄)
usermod -c "User FTP" -g system -d /ftp/user1 -s /bin/nologin user1 修改用戶屬性
passwd 修改口令
passwd user1 修改一個(gè)用戶的口令 (只允許root執(zhí)行)
chage -E 2005-12-31 user1 設(shè)置用戶口令的失效期限
pwck 檢查 '/etc/passwd' 的文件格式和語(yǔ)法修正以及存在的用戶
grpck 檢查 '/etc/passwd' 的文件格式和語(yǔ)法修正以及存在的群組
newgrp group_name 登陸進(jìn)一個(gè)新的群組以改變新創(chuàng)建文件的預(yù)設(shè)群組
返回頂部索引 ^
文件的權(quán)限 - 使用 "+" 設(shè)置權(quán)限,使用 "-" 用于取消
ls -lh 顯示權(quán)限
ls /tmp | pr -T5 -W$COLUMNS 將終端劃分成5欄顯示
chmod ugo+rwx directory1 設(shè)置目錄的所有人(u)、群組(g)以及其他人(o)以讀(r )、寫(xiě)(w)和執(zhí)行(x)的權(quán)限
chmod go-rwx directory1 刪除群組(g)與其他人(o)對(duì)目錄的讀寫(xiě)執(zhí)行權(quán)限
chown user1 file1 改變一個(gè)文件的所有人屬性
chown -R user1 directory1 改變一個(gè)目錄的所有人屬性并同時(shí)改變改目錄下所有文件的屬性
chgrp group1 file1 改變文件的群組
chown user1:group1 file1 改變一個(gè)文件的所有人和群組屬性
find / -perm -u+s 羅列一個(gè)系統(tǒng)中所有使用了SUID控制的文件
chmod u+s /bin/file1 設(shè)置一個(gè)二進(jìn)制文件的 SUID 位 - 運(yùn)行該文件的用戶也被賦予和所有者同樣的權(quán)限
chmod u-s /bin/file1 禁用一個(gè)二進(jìn)制文件的 SUID位
chmod g+s /home/public 設(shè)置一個(gè)目錄的SGID 位 - 類似SUID ,不過(guò)這是針對(duì)目錄的
chmod g-s /home/public 禁用一個(gè)目錄的 SGID 位
chmod o+t /home/public 設(shè)置一個(gè)文件的 STIKY 位 - 只允許合法所有人刪除文件
chmod o-t /home/public 禁用一個(gè)目錄的 STIKY 位
返回頂部索引 ^
文件的特殊屬性 - 使用 "+" 設(shè)置權(quán)限,使用 "-" 用于取消
chattr +a file1 只允許以追加方式讀寫(xiě)文件
chattr +c file1 允許這個(gè)文件能被內(nèi)核自動(dòng)壓縮/解壓
chattr +d file1 在進(jìn)行文件系統(tǒng)備份時(shí),dump程序?qū)⒑雎赃@個(gè)文件
chattr +i file1 設(shè)置成不可變的文件,不能被刪除、修改、重命名或者鏈接
chattr +s file1 允許一個(gè)文件被安全地刪除
chattr +S file1 一旦應(yīng)用程序?qū)@個(gè)文件執(zhí)行了寫(xiě)操作,使系統(tǒng)立刻把修改的結(jié)果寫(xiě)到磁盤(pán)
chattr +u file1 若文件被刪除,系統(tǒng)會(huì)允許你在以后恢復(fù)這個(gè)被刪除的文件
lsattr 顯示特殊的屬性
返回頂部索引 ^
打包和壓縮文件
bunzip2 file1.bz2 解壓一個(gè)叫做 'file1.bz2'的文件
bzip2 file1 壓縮一個(gè)叫做 'file1' 的文件
gunzip file1.gz 解壓一個(gè)叫做 'file1.gz'的文件
gzip file1 壓縮一個(gè)叫做 'file1'的文件
gzip -9 file1 最大程度壓縮
rar a file1.rar test_file 創(chuàng)建一個(gè)叫做 'file1.rar' 的包
rar a file1.rar file1 file2 dir1 同時(shí)壓縮 'file1', 'file2' 以及目錄 'dir1'
rar x file1.rar 解壓rar包
unrar x file1.rar 解壓rar包
tar -cvf archive.tar file1 創(chuàng)建一個(gè)非壓縮的 tarball
tar -cvf archive.tar file1 file2 dir1 創(chuàng)建一個(gè)包含了 'file1', 'file2' 以及 'dir1'的檔案文件
tar -tf archive.tar 顯示一個(gè)包中的內(nèi)容
tar -xvf archive.tar 釋放一個(gè)包
tar -xvf archive.tar -C /tmp 將壓縮包釋放到 /tmp目錄下
tar -cvfj archive.tar.bz2 dir1 創(chuàng)建一個(gè)bzip2格式的壓縮包
tar -xvfj archive.tar.bz2 解壓一個(gè)bzip2格式的壓縮包
tar -cvfz archive.tar.gz dir1 創(chuàng)建一個(gè)gzip格式的壓縮包
tar -xvfz archive.tar.gz 解壓一個(gè)gzip格式的壓縮包
zip file1.zip file1 創(chuàng)建一個(gè)zip格式的壓縮包
zip -r file1.zip file1 file2 dir1 將幾個(gè)文件和目錄同時(shí)壓縮成一個(gè)zip格式的壓縮包
unzip file1.zip 解壓一個(gè)zip格式壓縮包
返回頂部索引 ^
RPM 包 - (Fedora, Redhat及類似系統(tǒng))
rpm -ivh package.rpm 安裝一個(gè)rpm包
rpm -ivh --nodeeps package.rpm 安裝一個(gè)rpm包而忽略依賴關(guān)系警告
rpm -U package.rpm 更新一個(gè)rpm包但不改變其配置文件
rpm -F package.rpm 更新一個(gè)確定已經(jīng)安裝的rpm包
rpm -e package_name.rpm 刪除一個(gè)rpm包
rpm -qa 顯示系統(tǒng)中所有已經(jīng)安裝的rpm包
rpm -qa | grep httpd 顯示所有名稱中包含 "httpd" 字樣的rpm包
rpm -qi package_name 獲取一個(gè)已安裝包的特殊信息
rpm -qg "System Environment/Daemons" 顯示一個(gè)組件的rpm包
rpm -ql package_name 顯示一個(gè)已經(jīng)安裝的rpm包提供的文件列表
rpm -qc package_name 顯示一個(gè)已經(jīng)安裝的rpm包提供的配置文件列表
rpm -q package_name --whatrequires 顯示與一個(gè)rpm包存在依賴關(guān)系的列表
rpm -q package_name --whatprovides 顯示一個(gè)rpm包所占的體積
rpm -q package_name --scripts 顯示在安裝/刪除期間所執(zhí)行的腳本l
rpm -q package_name --changelog 顯示一個(gè)rpm包的修改歷史
rpm -qf /etc/httpd/conf/httpd.conf 確認(rèn)所給的文件由哪個(gè)rpm包所提供
rpm -qp package.rpm -l 顯示由一個(gè)尚未安裝的rpm包提供的文件列表
rpm --import /media/cdrom/RPM-GPG-KEY 導(dǎo)入公鑰數(shù)字證書(shū)
rpm --checksig package.rpm 確認(rèn)一個(gè)rpm包的完整性
rpm -qa gpg-pubkey 確認(rèn)已安裝的所有rpm包的完整性
rpm -V package_name 檢查文件尺寸、 許可、類型、所有者、群組、MD5檢查以及最后修改時(shí)間
rpm -Va 檢查系統(tǒng)中所有已安裝的rpm包- 小心使用
rpm -Vp package.rpm 確認(rèn)一個(gè)rpm包還未安裝
rpm2cpio package.rpm | cpio --extract --make-directories *bin* 從一個(gè)rpm包運(yùn)行可執(zhí)行文件
rpm -ivh /usr/src/redhat/RPMS/`arch`/package.rpm 從一個(gè)rpm源碼安裝一個(gè)構(gòu)建好的包
rpmbuild --rebuild package_name.src.rpm 從一個(gè)rpm源碼構(gòu)建一個(gè) rpm 包
返回頂部索引 ^
YUM 軟件包升級(jí)器 - (Fedora, RedHat及類似系統(tǒng))
yum install package_name 下載并安裝一個(gè)rpm包
yum localinstall package_name.rpm 將安裝一個(gè)rpm包,使用你自己的軟件倉(cāng)庫(kù)為你解決所有依賴關(guān)系
yum update package_name.rpm 更新當(dāng)前系統(tǒng)中所有安裝的rpm包
yum update package_name 更新一個(gè)rpm包
yum remove package_name 刪除一個(gè)rpm包
yum list 列出當(dāng)前系統(tǒng)中安裝的所有包
yum search package_name 在rpm倉(cāng)庫(kù)中搜尋軟件包
yum clean packages 清理rpm緩存刪除下載的包
yum clean headers 刪除所有頭文件
yum clean all 刪除所有緩存的包和頭文件
返回頂部索引 ^
DEB 包 (Debian, Ubuntu 以及類似系統(tǒng))
dpkg -i package.deb 安裝/更新一個(gè) deb 包
dpkg -r package_name 從系統(tǒng)刪除一個(gè) deb 包
dpkg -l 顯示系統(tǒng)中所有已經(jīng)安裝的 deb 包
dpkg -l | grep httpd 顯示所有名稱中包含 "httpd" 字樣的deb包
dpkg -s package_name 獲得已經(jīng)安裝在系統(tǒng)中一個(gè)特殊包的信息
dpkg -L package_name 顯示系統(tǒng)中已經(jīng)安裝的一個(gè)deb包所提供的文件列表
dpkg --contents package.deb 顯示尚未安裝的一個(gè)包所提供的文件列表
dpkg -S /bin/ping 確認(rèn)所給的文件由哪個(gè)deb包提供
返回頂部索引 ^
APT 軟件工具 (Debian, Ubuntu 以及類似系統(tǒng))
apt-get install package_name 安裝/更新一個(gè) deb 包
apt-cdrom install package_name 從光盤(pán)安裝/更新一個(gè) deb 包
apt-get update 升級(jí)列表中的軟件包
apt-get upgrade 升級(jí)所有已安裝的軟件
apt-get remove package_name 從系統(tǒng)刪除一個(gè)deb包
apt-get check 確認(rèn)依賴的軟件倉(cāng)庫(kù)正確
apt-get clean 從下載的軟件包中清理緩存
apt-cache search searched-package 返回包含所要搜索字符串的軟件包名稱
返回頂部索引 ^
查看文件內(nèi)容
cat file1 從第一個(gè)字節(jié)開(kāi)始正向查看文件的內(nèi)容
tac file1 從最后一行開(kāi)始反向查看一個(gè)文件的內(nèi)容
more file1 查看一個(gè)長(zhǎng)文件的內(nèi)容
less file1 類似于 'more' 命令,但是它允許在文件中和正向操作一樣的反向操作
head -2 file1 查看一個(gè)文件的前兩行
tail -2 file1 查看一個(gè)文件的最后兩行
tail -f /var/log/messages 實(shí)時(shí)查看被添加到一個(gè)文件中的內(nèi)容
返回頂部索引 ^
文本處理
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 合并一個(gè)文件的詳細(xì)說(shuō)明文本,并將簡(jiǎn)介寫(xiě)入一個(gè)新文件中
cat file1 | command( sed, grep, awk, grep, etc...) result.txt 合并一個(gè)文件的詳細(xì)說(shuō)明文本,并將簡(jiǎn)介寫(xiě)入一個(gè)已有的文件中
grep Aug /var/log/messages 在文件 '/var/log/messages'中查找關(guān)鍵詞"Aug"
grep ^Aug /var/log/messages 在文件 '/var/log/messages'中查找以"Aug"開(kāi)始的詞匯
grep [0-9] /var/log/messages 選擇 '/var/log/messages' 文件中所有包含數(shù)字的行
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:]' 合并上下單元格內(nèi)容
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行內(nèi)容
sed -n '5p;5q' example.txt 查看第5行
sed -e 's/00*/0/g' example.txt 用單個(gè)零替換多個(gè)零
cat -n file1 標(biāo)示文件的行數(shù)
cat example.txt | awk 'NR%2==1' 刪除example.txt文件中的所有偶數(shù)行
echo a b c | awk '{print $1}' 查看一行第一欄
echo a b c | awk '{print $1,$3}' 查看一行的第一和第三欄
paste file1 file2 合并兩個(gè)文件或兩欄的內(nèi)容
paste -d '+' file1 file2 合并兩個(gè)文件或兩欄的內(nèi)容,中間用"+"區(qū)分
sort file1 file2 排序兩個(gè)文件的內(nèi)容
sort file1 file2 | uniq 取出兩個(gè)文件的并集(重復(fù)的行只保留一份)
sort file1 file2 | uniq -u 刪除交集,留下其他的行
sort file1 file2 | uniq -d 取出兩個(gè)文件的交集(只留下同時(shí)存在于兩個(gè)文件中的文件)
comm -1 file1 file2 比較兩個(gè)文件的內(nèi)容只刪除 'file1' 所包含的內(nèi)容
comm -2 file1 file2 比較兩個(gè)文件的內(nèi)容只刪除 'file2' 所包含的內(nèi)容
comm -3 file1 file2 比較兩個(gè)文件的內(nèi)容只刪除兩個(gè)文件共有的部分
返回頂部索引 ^
字符設(shè)置和文件格式轉(zhuǎn)換
dos2unix filedos.txt fileunix.txt 將一個(gè)文本文件的格式從MSDOS轉(zhuǎn)換成UNIX
unix2dos fileunix.txt filedos.txt 將一個(gè)文本文件的格式從UNIX轉(zhuǎn)換成MSDOS
recode ..HTML page.txt page.html 將一個(gè)文本文件轉(zhuǎn)換成html
recode -l | more 顯示所有允許的轉(zhuǎn)換格式
返回頂部索引 ^
文件系統(tǒng)分析
badblocks -v /dev/hda1 檢查磁盤(pán)hda1上的壞磁塊
fsck /dev/hda1 修復(fù)/檢查hda1磁盤(pán)上linux文件系統(tǒng)的完整性
fsck.ext2 /dev/hda1 修復(fù)/檢查hda1磁盤(pán)上ext2文件系統(tǒng)的完整性
e2fsck /dev/hda1 修復(fù)/檢查hda1磁盤(pán)上ext2文件系統(tǒng)的完整性
e2fsck -j /dev/hda1 修復(fù)/檢查hda1磁盤(pán)上ext3文件系統(tǒng)的完整性
fsck.ext3 /dev/hda1 修復(fù)/檢查hda1磁盤(pán)上ext3文件系統(tǒng)的完整性
fsck.vfat /dev/hda1 修復(fù)/檢查hda1磁盤(pán)上fat文件系統(tǒng)的完整性
fsck.msdos /dev/hda1 修復(fù)/檢查hda1磁盤(pán)上dos文件系統(tǒng)的完整性
dosfsck /dev/hda1 修復(fù)/檢查hda1磁盤(pán)上dos文件系統(tǒng)的完整性
返回頂部索引 ^
初始化一個(gè)文件系統(tǒng)
mkfs /dev/hda1 在hda1分區(qū)創(chuàng)建一個(gè)文件系統(tǒng)
mke2fs /dev/hda1 在hda1分區(qū)創(chuàng)建一個(gè)linux ext2的文件系統(tǒng)
mke2fs -j /dev/hda1 在hda1分區(qū)創(chuàng)建一個(gè)linux ext3(日志型)的文件系統(tǒng)
mkfs -t vfat 32 -F /dev/hda1 創(chuàng)建一個(gè) FAT32 文件系統(tǒng)
fdformat -n /dev/fd0 格式化一個(gè)軟盤(pán)
mkswap /dev/hda3 創(chuàng)建一個(gè)swap文件系統(tǒng)
返回頂部索引 ^
SWAP文件系統(tǒng)
mkswap /dev/hda3 創(chuàng)建一個(gè)swap文件系統(tǒng)
swapon /dev/hda3 啟用一個(gè)新的swap文件系統(tǒng)
swapon /dev/hda2 /dev/hdb3 啟用兩個(gè)swap分區(qū)
返回頂部索引 ^
備份
dump -0aj -f /tmp/home0.bak /home 制作一個(gè) '/home' 目錄的完整備份
dump -1aj -f /tmp/home0.bak /home 制作一個(gè) '/home' 目錄的交互式備份
restore -if /tmp/home0.bak 還原一個(gè)交互式備份
rsync -rogpav --delete /home /tmp 同步兩邊的目錄
rsync -rogpav -e ssh --delete /home ip_address:/tmp 通過(guò)SSH通道rsync
rsync -az -e ssh --delete ip_addr:/home/public /home/local 通過(guò)ssh和壓縮將一個(gè)遠(yuǎn)程目錄同步到本地目錄
rsync -az -e ssh --delete /home/local ip_addr:/home/public 通過(guò)ssh和壓縮將本地目錄同步到遠(yuǎn)程目錄
dd bs=1M if=/dev/hda | gzip | ssh user@ip_addr 'dd of=hda.gz' 通過(guò)ssh在遠(yuǎn)程主機(jī)上執(zhí)行一次備份本地磁盤(pán)的操作
dd if=/dev/sda of=/tmp/file1 備份磁盤(pán)內(nèi)容到一個(gè)文件
tar -Puf backup.tar /home/user 執(zhí)行一次對(duì) '/home/user' 目錄的交互式備份操作
( cd /tmp/local/ tar c . ) | ssh -C user@ip_addr 'cd /home/share/ tar x -p' 通過(guò)ssh在遠(yuǎn)程目錄中復(fù)制一個(gè)目錄內(nèi)容
( tar c /home ) | ssh -C user@ip_addr 'cd /home/backup-home tar x -p' 通過(guò)ssh在遠(yuǎn)程目錄中復(fù)制一個(gè)本地目錄
tar cf - . | (cd /tmp/backup ; tar xf - ) 本地將一個(gè)目錄復(fù)制到另一個(gè)地方,保留原有權(quán)限及鏈接
find /home/user1 -name '*.txt' | xargs cp -av --target-directory=/home/backup/ --parents 從一個(gè)目錄查找并復(fù)制所有以 '.txt' 結(jié)尾的文件到另一個(gè)目錄
find /var/log -name '*.log' | tar cv --files-from=- | bzip2 log.tar.bz2 查找所有以 '.log' 結(jié)尾的文件并做成一個(gè)bzip包
dd if=/dev/hda of=/dev/fd0 bs=512 count=1 做一個(gè)將 MBR (Master Boot Record)內(nèi)容復(fù)制到軟盤(pán)的動(dòng)作
dd if=/dev/fd0 of=/dev/hda bs=512 count=1 從已經(jīng)保存到軟盤(pán)的備份中恢復(fù)MBR內(nèi)容
返回頂部索引 ^
光盤(pán)
cdrecord -v gracetime=2 dev=/dev/cdrom -eject blank=fast -force 清空一個(gè)可復(fù)寫(xiě)的光盤(pán)內(nèi)容
mkisofs /dev/cdrom cd.iso 在磁盤(pán)上創(chuàng)建一個(gè)光盤(pán)的iso鏡像文件
mkisofs /dev/cdrom | gzip cd_iso.gz 在磁盤(pán)上創(chuàng)建一個(gè)壓縮了的光盤(pán)iso鏡像文件
mkisofs -J -allow-leading-dots -R -V "Label CD" -iso-level 4 -o ./cd.iso data_cd 創(chuàng)建一個(gè)目錄的iso鏡像文件
cdrecord -v dev=/dev/cdrom cd.iso 刻錄一個(gè)ISO鏡像文件
gzip -dc cd_iso.gz | cdrecord dev=/dev/cdrom - 刻錄一個(gè)壓縮了的ISO鏡像文件
mount -o loop cd.iso /mnt/iso 掛載一個(gè)ISO鏡像文件
cd-paranoia -B 從一個(gè)CD光盤(pán)轉(zhuǎn)錄音軌到 wav 文件中
cd-paranoia -- "-3" 從一個(gè)CD光盤(pán)轉(zhuǎn)錄音軌到 wav 文件中(參數(shù)-3)
cdrecord --scanbus 掃描總線以識(shí)別scsi通道
dd if=/dev/hdc | md5sum 校驗(yàn)一個(gè)設(shè)備的md5sum編碼,例如一張 CD
返回頂部索引 ^
網(wǎng)絡(luò) - (以太網(wǎng)和WIFI無(wú)線)
ifconfig eth0 顯示一個(gè)以太網(wǎng)卡的配置
ifup eth0 啟用一個(gè) 'eth0' 網(wǎng)絡(luò)設(shè)備
ifdown eth0 禁用一個(gè) 'eth0' 網(wǎng)絡(luò)設(shè)備
ifconfig eth0 192.168.1.1 netmask 255.255.255.0 控制IP地址
ifconfig eth0 promisc 設(shè)置 'eth0' 成混雜模式以嗅探數(shù)據(jù)包 (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 lookup hostname to resolve name to ip address and viceversa(1)
nslookup 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 lookup hostname to resolve name to ip address and viceversa
nslookup lookup hostname to resolve name to ip address and viceversa
whois lookup on Whois database
GO TOP INDEX ^
Microsoft Windows networks (SAMBA)
nbtscan ip_addr netbios name resolution
nmblookup -A ip_addr netbios name resolution
smbclient -L ip_addr/hostname show remote shares of a windows host
smbget -Rr smb://ip_addr/share like wget can download files from a host windows via smb
mount -t smbfs -o username=user,password=pass //WinClient/share /mnt/share mount a windows network share
echo "HelloWorld"
向控制臺(tái)輸出HelloWorld信息
Linux允許將命令執(zhí)行結(jié)果重定向到一個(gè)文件,本應(yīng)顯示在終端上的內(nèi)容保存到指定文件中。
ls test.txt
test.txt 如果不存在,則創(chuàng)建,存在則覆蓋其內(nèi)容
注意: 輸出重定向會(huì)覆蓋原來(lái)的內(nèi)容, 輸出重定向則會(huì)追加到文件的尾部
cat xxx.py 可以用來(lái)快速查看某個(gè)文件內(nèi)容,輸出到控制臺(tái)
cat test.txt haha.txt 將test.txt的內(nèi)容追加到haha.txt中
cat 1.txt 2.txt 1_2.txt 將1.txt 2.txt內(nèi)容合并到1_2.txt中
分屏顯示:more
查看內(nèi)容時(shí),在信息過(guò)長(zhǎng)無(wú)法在一屏上顯示時(shí),會(huì)出現(xiàn)快速滾屏,使得用戶無(wú)法看清文件的內(nèi)容,此時(shí)可以使用more命令,從頭開(kāi)始,每次只顯示一頁(yè),空格鍵顯示下一頁(yè),b鍵上一頁(yè),按下q鍵退出顯示,按下h鍵可以獲取幫助。
more xxx.py
管道:一個(gè)命令的輸出可以通過(guò)管道做為另一個(gè)命令的輸入。
管道我們可以理解現(xiàn)實(shí)生活中的管子,管子的一頭塞東西進(jìn)去,另一頭取出來(lái),這里“ | ”的左右分為兩端,左端塞東西(寫(xiě)),右端取東西(讀)。即管道左邊的輸出結(jié)果作為管道右側(cè)的參數(shù)
cat info.txt | more
tree | more
::: warning
more管道符讀到的內(nèi)容只能前進(jìn),不能后退;只能使用空格或回車向下看,不能使用b回看
:::
Linux鏈接文件類似于Windows下的快捷方式。
鏈接文件分為軟鏈接和硬鏈接。
ln -s 源文件 鏈接文件
ln 源文件 鏈接文件
沒(méi)有-s 選項(xiàng)代表建立一個(gè)硬鏈接文件,兩個(gè)文件占用相同大小的硬盤(pán)空間,即使刪除了源文件,鏈接文件還是存在,一般用于保護(hù)系統(tǒng)重要的文件。所以-s選項(xiàng)是更常見(jiàn)的形式。
::: warning 注意
如果軟鏈接文件和源文件不在同一個(gè)目錄,源文件要使用絕對(duì)路徑,不能使用相對(duì)路徑。
:::
find命令功能非常強(qiáng)大,通常用來(lái)在特定的目錄下搜索符合條件的文件,也可以用來(lái)搜索特定用戶屬主的文件。
常用用法:
Linux系統(tǒng)中g(shù)rep命令是一種強(qiáng)大的文本搜索工具,grep允許對(duì)文本文件進(jìn)行模式查找。如果找到匹配模式, grep打印包含模式的所有行。
grep一般格式為:
在grep命令中輸入字符串參數(shù)時(shí),最好用引號(hào)或雙引號(hào)括起來(lái)。
例如:
從某個(gè)文件搜索
搜索當(dāng)前目錄所有文件
常用選項(xiàng)說(shuō)明:**
grep搜索內(nèi)容串可以是正則表達(dá)式。
正則表達(dá)式是對(duì)字符串操作的一種邏輯公式,就是用事先定義好的一些特定字符、及這些特定字符的組合,組成一個(gè)“規(guī)則字符串”,這個(gè)“規(guī)則字符串”用來(lái)表達(dá)對(duì)字符串的一種過(guò)濾邏輯。
grep常用正則表達(dá)式:
計(jì)算機(jī)中的數(shù)據(jù)經(jīng)常需要備份,tar是Unix/Linux中最常用的備份工具,此命令可以把一系列文件歸檔到一個(gè)大文件中,也可以把檔案文件解開(kāi)以恢復(fù)數(shù)據(jù)。
tar使用格式:
tar [參數(shù)] 打包文件名 文件
tar命令很特殊,其參數(shù)前面可以使用“-”,也可以不使用。
常用參數(shù):
注意:除了f需要放在參數(shù)的最后,其它參數(shù)的順序任意。
常用命令:
tar與gzip命令結(jié)合使用實(shí)現(xiàn)文件打包、壓縮。 tar只負(fù)責(zé)打包文件,但不壓縮,用gzip壓縮tar打包后的文件,其擴(kuò)展名一般用xxxx.tar.gz。也會(huì)見(jiàn)到縮寫(xiě)的.tgz這種擴(kuò)展名。
gzip使用格式如下:
常用選項(xiàng):
tar這個(gè)命令并沒(méi)有壓縮的功能,它只是一個(gè)打包的命令,但是在tar命令中增加一個(gè)選項(xiàng) -z 可以調(diào)用gzip實(shí)現(xiàn)壓縮的功能,最終實(shí)行一個(gè)先打包后壓縮的過(guò)程。
-z :指定壓縮包的格式為 xxx.tar.gz
tar壓縮: tar zcvf xxx.tar.gz 文件1 文件2 ...
tar解壓: tar zxvf xxx.tar.gz
解壓到指定目錄: tar zxvf xxx.tar.gz -C target_dir/ (大寫(xiě)字母“C”)
tar與bzip2命令結(jié)合使用實(shí)現(xiàn)文件打包、壓縮(用法和gzip一樣)。
tar只負(fù)責(zé)打包文件,但不壓縮,用bzip2壓縮tar打包后的文件,其擴(kuò)展名一般用xxxx.tar.bz2。
在tar命令中增加一個(gè)選項(xiàng)(-j)可以調(diào)用bzip2實(shí)現(xiàn)了一個(gè)壓縮的功能,實(shí)行一個(gè)先打包后壓縮的過(guò)程。
壓縮用法 : tar -jcvf 壓縮包包名 文件1 文件2... (例: tar jcvf bak.tar.bz2 *.c )
解壓用法 : tar -jxvf 壓縮包包名 (例: tar jxvf bak.tar.bz2 )
通過(guò)zip壓縮文件的目標(biāo)文件不需要指定擴(kuò)展名,默認(rèn)擴(kuò)展名為zip。
壓縮文件 :zip [-r] 目標(biāo)文件(沒(méi)有擴(kuò)展名) 源文件
解壓文件 :unzip -d 解壓后目錄文件 壓縮文件
使用tree命令可以查看指定目錄的樹(shù)狀結(jié)構(gòu)
有時(shí)我們想知道被執(zhí)行的命令在哪個(gè)目錄,以方便切換或更新不同版本,如Python。可以使用 which 命令
文件內(nèi)容為:123 aaa bbb哈
執(zhí)行 echo "123 aaa bbb哈" xxx.txt
wc -l xxx.txt 文件內(nèi)容的行數(shù)1
wc -w xxx.txt 文件內(nèi)容的單詞數(shù)3
wc -c xxx.txt 文件內(nèi)容的字節(jié)數(shù)15
wc xxx.txt 文件內(nèi)容的行數(shù),單詞數(shù),字節(jié)數(shù)1 3 15
wc -m xxx.txt 文件的字符數(shù)13
sed 是一種流編輯器,它是文本處理中非常中的工具,能夠完美的配合正則表達(dá)式使用。一般用于自動(dòng)編輯轉(zhuǎn)換程序,動(dòng)態(tài)調(diào)整文件內(nèi)容。
sed 's/good/GOODS/' file 替換每行第一個(gè)指定字符串(輸出所有行)
sed -n 's/good/GOODS/p' file 替換每行第一個(gè)指定字符串(只輸出替換的行)
sed -i 's/good/GOODS/g' file 替換所有指定字符串,并應(yīng)用到文件
sed '2d' file 刪除第二行
sed '/^test/d' 刪除good開(kāi)頭的行
sed -n '3p' file 打印第3行
顯示當(dāng)前時(shí)間 # Tue May 7 14:35:31 DST 2019
當(dāng)前日期和時(shí)間 # 20190507-14:34:25
使用history命令可以查看之前輸過(guò)的命令及其id,
使用 !id 的形式,可以快速執(zhí)行指定歷史命令
Linux命令大全:
菜鳥(niǎo)Linux命令:
新手想要快速入門(mén)學(xué)習(xí)Linux,要制定合適的學(xué)習(xí)路線,這樣才可以達(dá)到事半功倍的效果。
第一階段:linux基礎(chǔ)入門(mén)
1. 開(kāi)班課程介紹-規(guī)章制度介紹-破冰活動(dòng);
2. Linux硬件基礎(chǔ)/Linux發(fā)展歷史;
3. Linux系統(tǒng)安裝/xshell連接/xshell優(yōu)化/SSH遠(yuǎn)程連接故障問(wèn)題排查
4. 第一關(guān)一大波命令及特殊字符知識(shí)考試題講解
5. L inux基礎(chǔ)優(yōu)化
6. Linux目錄結(jié)構(gòu)知識(shí)精講
7. 第二關(guān)一大波命令及特殊知識(shí)考試題講解(上)
8. 第二關(guān)一大波命令及特殊知識(shí)考試題講解(下)
9. Linux文件屬性一大堆知識(shí)精講
10. Linux通配符/正則表達(dá)式
11. 第三關(guān)一大波命令及重要知識(shí)考試題講解(上)
12. 第三關(guān)一大波命令及重要知識(shí)考試題講解(下)
13. Linux系統(tǒng)權(quán)限(上)
14. Linux系統(tǒng)權(quán)限(下)
15. 第一階段結(jié)束需要導(dǎo)師或講師對(duì)整體課程進(jìn)行回顧
第二階段:linux系統(tǒng)管理進(jìn)階
1. Linux定時(shí)任務(wù)
2. Linux用戶管理
3. Linux磁盤(pán)與文件系統(tǒng)(上)
4. Linux磁盤(pán)與文件系統(tǒng)(中下)
5. Linux三劍客之sed命令
第三階段:Linux Shell基礎(chǔ)
1. Shell編程基礎(chǔ)1
2. Shell編程基礎(chǔ)234
3. Linux三劍客之a(chǎn)wk命令
第四階段:Linux網(wǎng)絡(luò)基礎(chǔ)
1. 計(jì)算機(jī)網(wǎng)絡(luò)基礎(chǔ)上
2. 計(jì)算機(jī)網(wǎng)絡(luò)基礎(chǔ)下
3. 第二階段結(jié)束需要導(dǎo)師或講師對(duì)整體課程進(jìn)行回顧。
第五階段:Linux網(wǎng)絡(luò)服務(wù)
1. 集群實(shí)戰(zhàn)架構(gòu)開(kāi)始及環(huán)境準(zhǔn)備
2. rsync數(shù)據(jù)同步服務(wù)
3. Linux全網(wǎng)備份項(xiàng)目案例精講
4. nfs網(wǎng)絡(luò)存儲(chǔ)服務(wù)精講
5. inotify/sersync實(shí)時(shí)數(shù)據(jù)同步/nfs存儲(chǔ)實(shí)時(shí)備份項(xiàng)目案例精講
第六階段:Linux重要網(wǎng)絡(luò)服務(wù)
1. http協(xié)議/www服務(wù)基礎(chǔ)
2. nginx web介紹及基礎(chǔ)實(shí)踐
3. nginx web精講結(jié)束
4. lnmp環(huán)境部署/數(shù)據(jù)庫(kù)異機(jī)遷移/共享數(shù)據(jù)異機(jī)遷移到NFS系統(tǒng)
5. nginx負(fù)載均衡深入透徹
6. keepalived高可用深入透徹
第七階段:Linux中小規(guī)模集群構(gòu)建與優(yōu)化(50臺(tái))
1. 期中架構(gòu)開(kāi)戰(zhàn)說(shuō)明+期中架構(gòu)部署回顧
2. 全體晝夜兼程部署期中架構(gòu)并完成上臺(tái)述職演講(加上兩個(gè)周末共9天)
3. kickstart cobbler 批量自動(dòng)安裝系統(tǒng)
4. pptp vpn與ntp服務(wù)
5. memcached原理及部署/作為緩存及session會(huì)話共享
第八階段:Ansible自動(dòng)化運(yùn)維與Zabbix監(jiān)控
1. SSH服務(wù)秘鑰認(rèn)證
2. ansible批量自動(dòng)化管理集群(入門(mén)及深入)
3. zabbix監(jiān)控
第九階段:大規(guī)模集群高可用服務(wù)(Lvs、Keepalived)
1. Centos7系統(tǒng)自行安裝/centos6與7區(qū)別
2. lvs負(fù)載均衡集群/keepalived管理LVS集群
第十階段:Java Tomcat服務(wù)及防火墻Iptables
1. iptables防火墻精講上
2. iptables防火墻精講下
3. tomcat java應(yīng)用服務(wù)/nginx配合tomcat服務(wù)部署及優(yōu)化
第十一階段:MySQL DBA高級(jí)應(yīng)用實(shí)踐
1. MySQL數(shù)據(jù)庫(kù)入門(mén)基礎(chǔ)命令
2. MySQL數(shù)據(jù)庫(kù)進(jìn)階備份恢復(fù)
3. MySQL數(shù)據(jù)庫(kù)深入事務(wù)引擎
4. MySQL數(shù)據(jù)庫(kù)優(yōu)化SQL語(yǔ)句優(yōu)化
5. MySQL數(shù)據(jù)庫(kù)集群主從復(fù)制/讀寫(xiě)分離
6. MySQL數(shù)據(jù)庫(kù)高可用/mha/keepalved
第十二階段:高性能數(shù)據(jù)庫(kù)Redis和Memcached課程
第十三階段:Linux大規(guī)模集群架構(gòu)構(gòu)建(200臺(tái))
第十四階段:Linux Shell編程企業(yè)案例實(shí)戰(zhàn)
第十五階段:企業(yè)級(jí)代碼發(fā)布上線方案(SVN和Git)
1. GIT管理
2. 代碼上線項(xiàng)目案例
第十六階段企業(yè)級(jí)Kvm虛擬化與OpenStack云計(jì)算
1. KVM虛擬化企業(yè)級(jí)實(shí)戰(zhàn)
2. OpenStack云計(jì)算企業(yè)級(jí)實(shí)戰(zhàn)
第十七階段公有云阿里云8大組件構(gòu)建集群實(shí)戰(zhàn)
第十八階段:Docker技術(shù)企業(yè)應(yīng)用實(shí)踐
1. Docker容器與微服務(wù)深入實(shí)踐
2. 大數(shù)據(jù)Hadoop生態(tài)體系及實(shí)踐
第十九階段:Python自動(dòng)化入門(mén)及進(jìn)階
第二十階段:職業(yè)規(guī)劃與高薪就業(yè)指導(dǎo)