天天看點

Linux學習(1)-常用指令

Linux學習(1)-常用指令

系統資訊 

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 建立一個指向檔案或目錄的實體連結 

檔案搜尋 

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 顯示一個二進制檔案或可執行檔案的完整路徑 

使用者和群組 

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格式壓縮包 

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 從CD光牒安裝/更新一個 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 比較兩個檔案的内容隻删除兩個檔案共有的部分 

初始化一個檔案系統 

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檔案系統 

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内容 

網絡 - (以太網和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 

 原文位址

https://blog.csdn.net/sunhuansheng/article/details/82107907

繼續閱讀