很多初级测试人员,在进行执行测试用例这个步骤时,发现了bug,但不能更加准确地去定位bug。在这样的情况下就可以打开Linux服务器,通过命令查看操作进行中的实时日志,当系统报错时,可以截图日志在缺陷管理系统中,开发人员就知道什么地方错了,操作步骤一定要写明确。
主要常用的命令有:
tail、cat、less、more、head、vim
1、tail
命令格式:
tail [参数] [文件]
常用参数:
-f 循环读取
-q 不显示处理信息
-v 显示详细的处理信息
-c<数目> 显示的字节数
-n<行数> 显示文件的尾部 n 行内容
--pid=PID 与-f合用,表示在进程ID,PID死掉之后结束
-q, --quiet, --silent 从不输出给出文件名的首部
-s, --sleep-interval=S 与-f合用,表示在每次反复的间隔休眠S秒
例子:
tail -f info.log :动态查看实时输出info.log日志
tail -n 200 info.log:查看info.log日志后200行
tail -f info.log | grep "orderId":动态查看含有关键字orderId的日志
2、cat
命令格式:
cat [-AbeEnstTuv] [--help] [--version] 文件名
常用参数:
-n 或 --number:由 1 开始对所有输出的行数编号。
-b 或 --number-nonblank:和 -n 相似,只不过对于空白行不编号。
-s 或 --squeeze-blank:当遇到有连续两行以上的空白行,就代换为一行的空白行。
-v 或 --show-nonprinting:使用 ^ 和 M- 符号,除了 LFD 和 TAB 之外。
-E 或 --show-ends : 在每行结束处显示 $。
-T 或 --show-tabs: 将 TAB 字符显示为 ^I。
-A, --show-all:等价于 -vET。
-e:等价于"-vE"选项;
-t:等价于"-vT"选项;
例子:
cat info.log:查看info.log的全部日志内容
cat info.log | grep "java":查看info.log的java关键字关联的全部内容
cat info.log | grep -A 5 "java":查看info.log的java关键字后5行关联的全部内容
cat info.log | grep -B 10 "java":查看info.log的java关键字前10行关联的全部内容
cat info.log | grep -C 20 "java":查看info.log的java关键字前后20行关联的全部内容
3、less
命令格式:
less [参数] 文件
常用参数:
-b <缓冲区大小> 设置缓冲区的大小
-e 当文件显示结束后,自动离开
-f 强迫打开特殊文件,例如外围设备代号、目录和二进制文件
-g 只是标志最后搜索的关键词
-i 忽略搜索时的大小写
-m 显示类似more命令的百分比
-N 显示每行的行号
-o <文件名> 将less 输出的内容在指定文件中保存起来
-Q 不使用警告音
-s 显示连续空行为一行
-S 行过长时间将超出部分舍弃
-x <数字> 将"tab"键显示为规定的数字空格
/字符串:向下搜索"字符串"的功能
?字符串:向上搜索"字符串"的功能
n:重复前一个搜索(与 / 或 ? 有关)
N:反向重复前一个搜索(与 / 或 ? 有关)
b 向上翻一页
d 向后翻半页
h 显示帮助界面
Q 退出less 命令
u 向前滚动半页
y 向前滚动一行
空格键 滚动一页
回车键 滚动一行
[pagedown]:向下翻动一页
[pageup]:向上翻动一页
例子:
less info.log :从头开始查看info.log日志内容
4、more
命令格式:
more [-dlfpcsu] [-num] [+/pattern] [+linenum] [fileNames..]
常用参数:
-num 一次显示的行数
-d 提示使用者,在画面下方显示 [Press space to continue, 'q' to quit.] ,如果使用者按错键,则会显示 [Press 'h' for instructions.] 而不是 '哔' 声
-l 取消遇见特殊字元 ^L(送纸字元)时会暂停的功能
-f 计算行数时,以实际上的行数,而非自动换行过后的行数(有些单行字数太长的会被扩展为两行或两行以上)
-p 不以卷动的方式显示每一页,而是先清除萤幕后再显示内容
-c 跟 -p 相似,不同的是先显示内容再清除其他旧资料
-s 当遇到有连续两行以上的空白行,就代换为一行的空白行
-u 不显示下引号 (根据环境变数 TERM 指定的 terminal 而有所不同)
+/pattern 在每个文档显示前搜寻该字串(pattern),然后从该字串之后开始显示
+num 从第 num 行开始显示
fileNames 欲显示内容的文档,可为复数个数
例子:
more info.log:查看info.log的日志内容,按下方附加操作滚动日志内容
more info.log |grep "test":查看全部关键字test关联内容
5、head
命令格式:
head [参数] [文件]
常用参数:
-q 隐藏文件名
-v 显示文件名
-c<数目> 显示的字节数
-n<行数> 显示的行数
例子:
head -n 20 info.log:查看info.log日志的前20行内容
6、vim
命令格式:
vim [文件]
备注说明:一般VIM是用来编辑文件的,所以不是查看日志的常用命令。但是VIM也是可以实现日志文件内容查看的。
例子:
vim info.log:进入文件。然后,按?关键字,搜寻匹配关键字相关内容!如?getName,则会高亮显示关键字相关内容,按n或shift+n前后滚动日志内容。