2020非常全的軟件測試linux常用命令全集,linux面試題及參考答案


一、前言:

作為一名軟件測試工程師,我相信大部分的人都和Linux打過交道,因為我們的服務器一般都是裝的Linux操作系統,包括各種雲服務器也都是用的Linux,目前主流是CentOS7,那么對於一個測試工程師來說,我們需要掌握哪些命令呢?我將我了解到的命令列舉一下,僅供大家參考:

二、Linux常用命令大全

1.系統信息

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

2.關機 (系統的關機、重啟以及登出 )

shutdown -h now 關閉系統

init 0 關閉系統

telinit 0 關閉系統

shutdown -h hours:minutes & 按預定時間關閉系統

shutdown -c 取消按預定時間關閉系統

shutdown -r now 重啟

reboot 重啟

logout 注銷

3.文件和目錄

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)

4.文件搜索

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

5.掛載一個文件系統

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網絡共享

6.磁盤空間

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類系統)

7.用戶和群組

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 登陸進一個新的群組以改變新創建文件的預設群組

8.文件的權限 - 使用 "+" 設置權限,使用 "-" 用於取消

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 位

9.打包和壓縮文件

bunzip2 file1.bz2 解壓一個叫做 'file1.bz2'的文件

bzip2 file1 壓縮一個叫做 'file1' 的文件

gunzip file1.gz 解壓一個叫做 'file1.gz'的文件

gzip file1 壓縮一個叫做 'file1'的文件

gzip -9 file1 最大程度壓縮

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

10.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 包

11.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 刪除所有緩存的包和頭文件

12.查看文件內容

cat file1 從第一個字節開始正向查看文件的內容

tac file1 從最后一行開始反向查看一個文件的內容

more file1 查看一個長文件的內容

less file1 類似於 'more' 命令,但是它允許在文件中和正向操作一樣的反向操作

head -2 file1 查看一個文件的前兩行

tail -2 file1 查看一個文件的最后兩行

tail -f /var/log/messages 實時查看被添加到一個文件中的內容

13.文本處理

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 比較兩個文件的內容只刪除兩個文件共有的部分

14.網絡 - (以太網和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 Example Domain lookup hostname to resolve name to ip address and viceversa

nslookup Example Domain 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 Example Domain lookup hostname to resolve name to ip address and viceversa

nslookup Example Domain lookup hostname to resolve name to ip address and viceversa

whois Example Domain lookup on Whois database

三、Linux最最最常用的面試題及答案

如果你覺得此文對你有幫助,如果你對此文有任何疑問,如果你對軟件測試、接口測試、自動化測試、面試經驗交流感興趣歡迎加入軟件測試技術群:695458161,群里發放的免費資料都是筆者十多年測試生涯的精華。還有同行大神一起交流技術哦。

1、你之前在公司使用linux命令做什么?

我們公司之前測試系統搭建在linux上,使用linux搭建和升級測試環境、查香后台日志等

2、在之前公司,測試環境使用的是哪個linux版本?

Centos7或更高版本(命令幾乎 一致,可以通用)

3、linux 下安裝軟件有那些方式?

常用的有4種方式:綠色安裝(解壓即可使用)、yum安裝(聯網安裝)、rpm包安裝(類似exe文件安裝)、源碼編譯安裝(gcc、perl 等)

4、在之前使用linux過程中,使用什么工具遠程連接?

可以講使用過的,一般常用xmanager,它集成了xshell xftp

5、vi編輯器如何使用?

Vi:接文件名參數進入文件內容界面,可進行編輯 i: 切換到編輯模式 esc: 切換到命令模式

/+搜索內容 :進行向下披索操作 set nu : 給每行加行號 跳轉到文本開頭: $ 跳轉到文本結尾 dd :刪除一行 yy:刪除一行

6、常用的linux命令有哪些?

目錄相關: cd mkdir rmdir pwd Is ll=ls-l mv cp

文件相關: rm-rf cat more tail head vi du find

網絡相關: ping ifconfig netstat

用戶相關: groupadd useradd passwd su

權限相關: chmod chgrp chown

系統相關: reboot shutdown mount free df

進程相關: top ps kill

壓縮相關: tar zip unzip gzip

其它: grep echo sh init(0-- 6)

7、如何使用linux命令查看后台日志?

使用tail-f日志文件名稱

8、如何使用tar命令壓縮和解壓gz包?

壓縮: tar -zcvf

tar zcvf FileName.tar.gz DirName

解壓: tar-zxvf

tar zxvf FileName.tar.gz

9、解釋命令的含義Is-la lgrep log、 ps -ef、kill -9 2543

Is -la lgrep log查找當前目錄含有log的文件

Ps -ef查看所有進程

Kill-9 2543強制終止2543進程

10、文件權限改為所有者讀、所在的組寫,其它用戶執行,如何寫命令?

Chmod u+r 文件 Chmod g+w 文件 Chmod o+x文件

或chmod 421文件

11、查看linux文件大小?

可以使用1s-1文件名或者 du文件名

12、重啟網絡服務的命令?

service network restart或systemctl restart network

network網絡服務 firewalld防火牆 mysql數據庫服務 httpd apache 服務

13、find命令如何使用?

Find查找目錄 -name 文件名稱 -type 文件類型

Type可以填寫f (文件) d (日錄) 1[鏈接文件)等

14、linux 如何清空日志文件的內容?

cat“”> test.log 其中test.log為日志文件

15、如何在linux上做被測系統代碼補丁的更新?

關閉目前的被測系統--- 先備份原有的被測系統的可執行代碼---然后通過工具xftp把解壓后的補丁中的可執行代碼文件分別覆蓋之前的可執行代碼文件---根據補丁升級文檔進行配置文件修改---清空日志文件內容 --- 啟動被測系統

16、查詢端口占用並殺掉占用端口的進程?

1)已知程序名稱查找占用了端口:舉例

查進程ID ps-ef|grep 程序名[如tomcat)

根據上一步結果,查占用端口netstat -nap I grep pid(109)

2)已知占用了哪個端口,查程序名稱

查進程ID netstat -nap Igrep端口(8080)

根據上步結果,查應用程序名ps ef| grep pid

17、tomcat相關目錄用途?

bin目錄:主要用來存放Tomcat的命令

conf日錄:存放tomcat服務器全局配置的各種文件

lib目錄:存放Tomcat服務器所需要的所有Jar包

log目錄:存放tomcat執行時的日志文件

webapps目錄:Tonmcat默認部署路徑

18、測試環境如何搭建?

一般根據開發給的部署文檔指建, 都署文檔操作步驟如下:

1)安裝依賴軟件java (jak. tomcat. redis. mysql)等

2)導入基礎數據(建表,導入初始化的數據)

3)獲取代碼(編譯、打包),war包

4) 部署到tomcat的webapps目錄下

5) 修改配置文件

6)啟動服務

19、測試環境部署的注意事項?

1)基礎環境JDK MYSQL TOMCAT 版本要與生產環境保持一致

2)服務器部署架構、服務器型號也盡量與生產環境保持一致,配置可以等比例縮減

3)一般先把數據庫 表相關操作完成,再進行代碼部署

20、測試環境升級?

1)完全升級:根據開發人員給的升級文檔,查看代碼包、數據庫腳本包是否齊備,然后把測試環境的數據庫、被測系統代碼包先備份然后刷除,然后根據開發最新的文件和代碼進行升級部署操作。升級之后做個基本功能驗證,如果驗證失敗,測試環境按之前的備份包回滾

2)增量升級(補丁升級):從svn上拉取開發提交的測試補丁---停止tomcat---備份webapps下部署的項目代碼(各份名稱實例newdream 2019_08 27 16 _03.tar.gz) --- 使用升級補丁進行升級(升級數據庫補丁(sql文件)、代碼補丁(覆蓋))---清除日志---啟動tomcat (./startup.sh) - 驗證是否能進入被測試系統

 

四、總結

如果你此文你也有同感,如果你覺得此文對你有幫助,如果你對軟件測試、接口測試、自動化測試、面試經驗交流感興趣歡迎加入

軟件測試技術群:695458161,群里發放的免費資料都是筆者十多年測試生涯的精華。還有同行大神一起交流技術哦。

作者:來自公眾號:軟測之家
出處:https://www.cnblogs.com/csmashang/p/12660247.html
原創不易,歡迎轉載,但未經作者同意請保留此段聲明,並在文章頁面明顯位置給出原文鏈接。


免責聲明!

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



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