主頁 > 作業系統 > 常用Linux命令

常用Linux命令

2020-09-12 21:28:50 作業系統

Linux常用命令大全(非常全!!!)

 轉自:https://www.cnblogs.com/yjd_hycf_space/p/7730690.html

系統資訊 
arch 顯示機器的處理器架構
uname -m 顯示機器的處理器架構
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 關閉系統
init 0 關閉系統
telinit 0 關閉系統
shutdown -h hours:minutes & 按預定時間關閉系統 
shutdown -c 取消按預定時間關閉系統 
shutdown -r now 重啟
reboot 重啟
logout 注銷 



檔案和目錄 
cd /home 進入 '/ home' 目錄' 
cd .. 回傳上一級目錄 
cd ../.. 回傳上兩級目錄 
cd 進入個人的主目錄 
cd ~user1 進入個人的主目錄 
cd - 回傳上次所在的目錄 
pwd 顯示作業路徑 
ls 查看目錄中的檔案 
ls -F 查看目錄中的檔案 
ls -l 顯示檔案和目錄的詳細資料 
ls -a 顯示隱藏檔案 
ls *[0-9]* 顯示包含數字的檔案名和目錄名 
tree 顯示檔案和目錄由根目錄開始的樹形結構
lstree 顯示檔案和目錄由根目錄開始的樹形結構
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' 
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
nslookup www.example.com lookup hostname to resolve name to ip address and viceversa
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

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

轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/17209.html

標籤:Linux

上一篇:qemu 如何退出qemu

下一篇:教你在 Linux 下時光穿梭

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • CA和證書

    1、在 CentOS7 中使用 gpg 創建 RSA 非對稱密鑰對 gpg --gen-key #Centos上生成公鑰/密鑰對(存放在家目錄.gnupg/) 2、將 CentOS7 匯出的公鑰,拷貝到 CentOS8 中,在 CentOS8 中使用 CentOS7 的公鑰加密一個檔案 gpg -a ......

    uj5u.com 2020-09-10 00:09:53 more
  • Kubernetes K8S之資源控制器Job和CronJob詳解

    Kubernetes的資源控制器Job和CronJob詳解與示例 ......

    uj5u.com 2020-09-10 00:10:45 more
  • VMware下安裝CentOS

    VMware下安裝CentOS 一、軟硬體準備 1 Centos鏡像準備 1.1 CentOS鏡像下載地址 下載地址 1.2 CentOS鏡像下載程序 點擊下載地址進入如下圖的網站,選擇需要下載的版本,這里選擇的是Centos8,點擊如圖所示。 決定選擇Centos8后,選擇想要的鏡像源進行下載,此 ......

    uj5u.com 2020-09-10 00:12:10 more
  • 如何使用Grep命令查找多個字串

    如何使用Grep 命令查找多個字串 大家好,我是良許! 今天向大家介紹一個非常有用的技巧,那就是使用 grep 命令查找多個字串。 簡單介紹一下,grep 命令可以理解為是一個功能強大的命令列工具,可以用它在一個或多個輸入檔案中搜索與正則運算式相匹配的文本,然后再將每個匹配的文本用標準輸出的格式 ......

    uj5u.com 2020-09-10 00:12:28 more
  • git配置http代理

    git配置http代理 經常遇到克隆 github 慢的問題,這里記錄一下幾種配置 git 代理的方法,解決 clone github 過慢。 目錄 git配置代理 git單獨配置github代理 git配置全域代理 配置終端環境變數 git配置代理 主要使用 git config 命令 git單獨 ......

    uj5u.com 2020-09-10 00:12:33 more
  • Linux npm install 裝包時提示Error EACCES permission denied解

    npm install 裝包時提示Error EACCES permission denied解決辦法 ......

    uj5u.com 2020-09-10 00:12:53 more
  • Centos 7下安裝nginx,使用yum install nginx,提示沒有可用的軟體包

    Centos 7下安裝nginx,使用yum install nginx,提示沒有可用的軟體包。 18 (flaskApi) [root@67 flaskDemo]# yum -y install nginx 19 已加載插件:fastestmirror, langpacks 20 Loading ......

    uj5u.com 2020-09-10 00:13:13 more
  • Linux查看服務器暴力破解ssh IP

    在公網的服務器上經常遇到別人爆破你服務器的22埠,用來挖礦或者干其他嘿嘿嘿的事情~ 這種情況下正確的做法是: 修改默認ssh的22埠 使用設定密鑰登錄或者白名單ip登錄 建議服務器密碼為復雜密碼 創建普通用戶登錄服務器(root權限過大) 建立堡壘機,實作統一管理服務器 統計爆破IP [root ......

    uj5u.com 2020-09-10 00:13:17 more
  • CentOS 7系統常見快捷鍵操作方式

    Linux系統中一些常見的快捷方式,可有效提高操作效率,在某些時刻也能避免操作失誤帶來的問題。 ......

    uj5u.com 2020-09-10 00:13:31 more
  • CentOS 7作業系統目錄結構介紹

    作業系統存在著大量的資料檔案資訊,相應檔案資訊會存在于系統相應目錄中,為了更好的管理資料資訊,會將系統進行一些目錄規劃,不同目錄存放不同的資源。 ......

    uj5u.com 2020-09-10 00:13:35 more
最新发布
  • vim的常用命令

    Vim的6種基本模式 1. 普通模式在普通模式中,用的編輯器命令,比如移動游標,洗掉文本等等。這也是Vim啟動后的默認模式。這正好和許多新用戶期待的操作方式相反(大多數編輯器默認模式為插入模式)。 2. 插入模式在這個模式中,大多數按鍵都會向文本緩沖中插入文本。大多數新用戶希望文本編輯器編輯程序中一 ......

    uj5u.com 2023-04-20 08:43:21 more
  • vim的常用命令

    Vim的6種基本模式 1. 普通模式在普通模式中,用的編輯器命令,比如移動游標,洗掉文本等等。這也是Vim啟動后的默認模式。這正好和許多新用戶期待的操作方式相反(大多數編輯器默認模式為插入模式)。 2. 插入模式在這個模式中,大多數按鍵都會向文本緩沖中插入文本。大多數新用戶希望文本編輯器編輯程序中一 ......

    uj5u.com 2023-04-20 08:42:36 more
  • docker學習

    ###Docker概述 真實專案部署環境可能非常復雜,傳統發布專案一個只需要一個jar包,運行環境需要單獨部署。而通過Docker可將jar包和相關環境(如jdk,redis,Hadoop...)等打包到docker鏡像里,將鏡像發布到Docker倉庫,部署時下載發布的鏡像,直接運行發布的鏡像即可。 ......

    uj5u.com 2023-04-19 09:26:53 more
  • 設定Windows主機的瀏覽器為wls2的默認瀏覽器

    這里以Chrome為例。 1. 準備作業 wsl是可以使用Windows主機上安裝的exe程式,出于安全考慮,默認情況下改功能是無法使用。要使用的話,終端需要以管理員權限啟動。 我這里以Windows Terminal為例,介紹如何默認使用管理員權限打開終端,具體操作如下圖所示: 2. 操作 wsl ......

    uj5u.com 2023-04-19 09:25:49 more
  • docker學習

    ###Docker概述 真實專案部署環境可能非常復雜,傳統發布專案一個只需要一個jar包,運行環境需要單獨部署。而通過Docker可將jar包和相關環境(如jdk,redis,Hadoop...)等打包到docker鏡像里,將鏡像發布到Docker倉庫,部署時下載發布的鏡像,直接運行發布的鏡像即可。 ......

    uj5u.com 2023-04-19 09:19:04 more
  • Linux學習筆記

    IP地址和主機名 IP地址 ifconfig可以用來查詢本機的IP地址,如果不能使用,可以通過install net-tools安裝。 Centos系統下ens33表示主網卡;inet后表示IP地址;lo表示本地回環網卡; 127.0.0.1表示代指本機;0.0.0.0可以用于代指本機,同時在放行設 ......

    uj5u.com 2023-04-18 06:52:01 more
  • 解決linux系統的kdump服務無法啟動的問題

    問題:專案麒麟系統服務器的kdump服務無法啟動,沒有相關日志無法定位問題。 1、查看服務狀態是關閉的,重啟系統也無法啟動 systemctl status kdump 2、修改grub引數,修改“crashkernel”為“512M(有的機器數值太大太小都會導致報錯,建議從128M開始試,或者加個 ......

    uj5u.com 2023-04-12 09:59:50 more
  • 解決linux系統的kdump服務無法啟動的問題

    問題:專案麒麟系統服務器的kdump服務無法啟動,沒有相關日志無法定位問題。 1、查看服務狀態是關閉的,重啟系統也無法啟動 systemctl status kdump 2、修改grub引數,修改“crashkernel”為“512M(有的機器數值太大太小都會導致報錯,建議從128M開始試,或者加個 ......

    uj5u.com 2023-04-12 09:59:01 more
  • 你是不是暴露了?

    作者:袁首京 原創文章,轉載時請保留此宣告,并給出原文連接。 如果您是計算機相關從業人員,那么應該經歷不止一次網路安全專項檢查了,你肯定是收到過資訊系統技術檢測報告,要求你加強風險監測,確保你提供的系統服務堅實可靠了。 沒檢測到問題還好,檢測到問題的話,有些處理起來還是挺麻煩的,尤其是線上正在運行的 ......

    uj5u.com 2023-04-05 16:52:56 more
  • 細節拉滿,80 張圖帶你一步一步推演 slab 記憶體池的設計與實作

    1. 前文回顧 在之前的幾篇記憶體管理系列文章中,筆者帶大家從宏觀角度完整地梳理了一遍 Linux 記憶體分配的整個鏈路,本文的主題依然是記憶體分配,這一次我們會從微觀的角度來探秘一下 Linux 內核中用于零散小記憶體塊分配的記憶體池 —— slab 分配器。 在本小節中,筆者還是按照以往的風格先帶大家簡單 ......

    uj5u.com 2023-04-05 16:44:11 more