liunx time 统计命令执行的时间

一般情况下,每个 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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值