一般情况下,每个 Unix/Linux 命令运行时都会打开三个文件:
- 标准输入文件(stdin):stdin的文件描述符为0,Unix程序默认从stdin读取数据。
- 标准输出文件(stdout):stdout 的文件描述符为1,Unix程序默认向stdout输出数据。
- 标准错误文件(stderr):stderr的文件描述符为2,Unix程序会向stderr流中写入错误信息。
默认情况下,command > file 将 stdout 重定向到 file,command < file 将stdin 重定向到 file。
如果希望 stderr 重定向到 file,可以这样写:
$ command 2 > file
time命令最常用的使用方式就是在其后面直接跟上命令和参数:
time <command> [<arguments...>]
在命令执行完成之后就会打印出CPU的使用情况:
real 0m5.064s <== 实际使用时间(real time)
user 0m0.020s <== 用户态使用时间(the process spent in user mode)
sys 0m0.040s <== 内核态使用时间(the process spent in kernel mode)
time命令跟上-p参数可以只打印时间数值(秒数),不打印单位。
使用type -a来看一下。这个shell内建命令
[root@web186 root]# type -a time
time is a shell keyword
time is /usr/bin/time
time是一个Shell关键字,还有一个外部命令/usr/bin/time
我们随便测试一个.sh文件
[admin@pro-deploy monitor_script]$ /usr/bin/time ./monitor_course.sh
0.00user 0.01system 0:00.01elapsed 92%CPU (0avgtext+0avgdata 1896maxresident)k
0inputs+0outputs (0major+2349minor)pagefaults 0swaps
发现有点不一样
还有一个参数 -v
[admin@pro-deploy monitor_script]$ /usr/bin/time -v ./monitor_course.sh
Command being timed: "./monitor_course.sh"
User time (seconds): 0.00
System time (seconds): 0.00
Percent of CPU this job got: 81%
Elapsed (wall clock) time (h:mm:ss or m:ss): 0:00.01
Average shared text size (kbytes): 0
Average unshared data size (kbytes): 0
Average stack size (kbytes): 0
Average total size (kbytes): 0
Maximum resident set size (kbytes): 1892
Average resident set size (kbytes): 0
Major (requiring I/O) page faults: 0
Minor (reclaiming a frame) page faults: 2354
Voluntary context switches: 12
Involuntary context switches: 11
Swaps: 0
File system inputs: 0
File system outputs: 0
Socket messages sent: 0
Socket messages received: 0
Signals delivered: 0
Page size (bytes): 4096
Exit status: 0
解决time命令输出信息的重定向问题
time命令的输出信息是打印在标准错误输出上的 (标准错误文件(stderr))
time ./monitor_course.sh > text.txt
time ./monitor_course.sh 2> text.txt
# 发现都不可以 !
# 发现无法将time的输出信息重定向到文件里面为什么?因为time是shell的关键字,shell做了特殊处理,
它会把time命令后面的命令行作为一个整体来进行处理,在重定向时,实际上是针对后面的命令来的,
time命令本身的输出并不会被重定向的
解决办法:
# 带空格 加分号
{ time find . -name "mysql.sh"; } 2>file.txt
# 或者是 小括号,不加分号
(time find . -name "mysql.sh") 2>file2.txt