一些常用的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

掛載一個cdromdvdrom

mount /dev/hdc /mnt/cdrecorder

掛載一個cdrwdvdrom

mount /dev/hdb /mnt/cdrecorder

掛載一個cdrwdvdrom

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 -xvfj archive.tar.bz2

解壓一個bzip2格式的壓縮包

tar -cvfz archive.tar.gz dir1

創建一個gzip格式的壓縮包

tar -xvfz 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

 

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

 

 

IPTABLES (firewall)

iptables -t filter -L

show all chains of filtering table

iptables -t nat -L

show all chains of nat table

iptables -t filter -F

clear all rules from filtering table

iptables -t nat -F

clear all rules from table nat

iptables -t filter -X

delete any chains created by user

iptables -t filter -A INPUT -p tcp --dport telnet -j ACCEPT

allow telnet connections to input

iptables -t filter -A OUTPUT -p tcp --dport http -j DROP

block HTTP connections to output

iptables -t filter -A FORWARD -p tcp --dport pop3 -j ACCEPT

allow POP3 connections to forward chain

iptables -t filter -A INPUT -j LOG --log-prefix "DROP INPUT"

logging sulla chain di input  Logging on chain input

iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE

configure a PAT (Port Address Traslation) on eth0 masking outbound packets

iptables -t nat -A PREROUTING -d 192.168.0.1 -p tcp -m tcp --dport 22 -j DNAT --to-destination 10.0.0.2:22

redirect packets addressed to a host to another host

 

Monitoring and debugging

top

display linux tasks using most cpu

ps -eafw

displays linux tasks

ps -e -o pid,args --forest

displays linux tasks in a hierarchical mode

pstree 

Shows a tree system processes

kill -9 ID_Processo

force closure of the process and finish it

kill -1 ID_Processo

force a process to reload configuration

lsof -p $$

display a list of files opened by processes

lsof /home/user1

displays a list of open files in a given path system

strace -c ls >/dev/null

display system calls made and received by a process

strace -f -e open ls >/dev/null

display library calls

watch -n1 'cat /proc/interrupts'

display interrupts in real-time

last reboot

show history reboot

lsmod

display kernel loaded

free -m

displays status of RAM in megabytes

smartctl -A /dev/hda

monitoring reliability of a hard-disk through SMART

smartctl -i /dev/hda

check if SMART is active on a hard-disk

tail /var/log/dmesg

show events inherent to the process of booting kernel

tail /var/log/messages

show system events

 

Others useful commands

apropos ...keyword

display a list of commands that pertain to keywords of a program , useful when you know what your program does, but you don't know the name of the command

man ping

display the on-line manual pages for example on ping command - use '-k' option to find any related commands

whatis ...keyword

displays description of what a program does

mkbootdisk --device /dev/fd0 `uname -r`

create a boot floppy

gpg -c file1

encrypt a file with GNU Privacy Guard

gpg file1.gpg

decrypt a file with GNU Privacy Guard

wget -r www.example.com

download an entire web site

wget -c www.example.com/file.iso

download a file with the ability to stop the download and resume later

echo 'wget -c www.example.com/files.iso' | at 09:00

start a download at any given time

ldd /usr/bin/ssh

show shared libraries required by ssh program

alias hh='history'

set an alias for a command - hh = history

chsh

change shell command

chsh --list-shells

nice command to know if you have to remote into another box

who -a

show who is logged on, and print: time of last system boot, dead processes, system login processes, active processes spawned by init, current runlevel, last system clock change

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章