TranslateProject/translated/tech/20181107 How To Find The Execution Time Of A Command Or Process In Linux.md
2018-11-18 22:22:06 +08:00

186 lines
6.5 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

在linux中如何查找一个命令或进程的执行时间
======
![](https://www.ostechnix.com/wp-content/uploads/2018/11/time-command-720x340.png)
你可能知道一个命令或进程开始执行的时间和在类Unix系统中[**一个命令运行了多久**][1]。 但是,你如何知道这个命令或进程何时结束或者它完成运行所花费的总时间呢? 在类Unix系统中,这是非常容易的! 有一个程序专门为此设计名叫 **GNU time**。 使用time程序, 我们可以轻松地测量Linux操作系统中命令或程序的总执行时间。 time命令在大多数Linux发行版中都有预装, 所以你不必去安装它。
### 在Linux中查找一个命令或进程的执行时间
要测量一个命令或程序的执行时间,运行。
```
$ /usr/bin/time -p ls
```
或者,
```
$ time ls
```
输出样例:
```
dir1 dir2 file1 file2 mcelog
real 0m0.007s
user 0m0.001s
sys 0m0.004s
$ time ls -a
. .bash_logout dir1 file2 mcelog .sudo_as_admin_successful
.. .bashrc dir2 .gnupg .profile .wget-hsts
.bash_history .cache file1 .local .stack
real 0m0.008s
user 0m0.001s
sys 0m0.005s
```
以上命令显示出了 **ls** 命令的总执行时间。 你可以将 “ls” 替换为任何命令或进程,以查找总的执行时间。
输出详解:
1. **real** -指的是命令或程序所花费的总时间
2. **user** 指的是在用户模式下程序所花费的时间,
3. **sys** 指的是在内核模式下程序所花费的时间。
我们也可以将命令限制为仅运行一段时间。
### time vs /usr/bin/time
你可能注意到了, 我们在上面的例子中使用了两个命令 **time** and **/usr/bin/time** 。 所以,你可能会想知道他们的不同。
首先, 让我们使用 type 命令看看 time 命令到底是什么。对于那些我们不知道的Linux命令, **Type** 命令用于查找相关命令的信息。 更多详细信息, [**请参阅本指南**][2]。
```
$ type -a time
time is a shell keyword
time is /usr/bin/time
```
正如你在上面的输出中看到的一样, 这两个都是time,
* 一个是BASH shell中内建的关键字
* 一个是可执行文件 如 **/usr/bin/time**
由于shell关键字的优先级高于可执行文件, 当你没有给出完整路径只运行`time`命令时, 你运行的是shell内建的命令。 但是,当你运行 `/usr/bin/time`时, 你运行的是真正的 **GNU time** 命令。 因此,为了执行真正的命令你可能需要给出完整路径。
在大多数shell中如 BASH, ZSH, CSH, KSH, TCSH 等内建的关键字time是可用的。 time 关键字的选项少于可执行文件. 你可以使用的唯一选项是 **-p**。
你现在知道如何使用 time 命令查找给定命令或进程的总执行时间。 想进一步了解 GNU time 工具吗? 继续阅读吧!
### 关于 GNU time 程序的简要介绍
Gnu time程序运行带有给定参数的命令或程序并在命令完成后将系统资源使用情况汇总到标准输出。 与 time 关键字不同, Gnu time程序不仅显示命令或进程的执行时间还显示内存I/O和IPC调用等其他资源。
time 命令的语法是:
```
/usr/bin/time [options] command [arguments...]
```
语法中的options是指一组可以与time命令一起使用去执行特定功能的选项。 下面给出了可用的options
* **-f, format** 使用此选项可以根据需求指定输出格式。
* **-p, portability** 使用简要的输出格式。
* **-o file, output=FILE** 将输出写到指定文件中而不是到标准输出。
* **-a, append** 将输出追加到文件中而不是覆盖它。
* **-v, verbose** 此选项显示 time 命令输出的详细信息。
* **quiet** 此选项可以防止 time 命令报告程序的状态.
当不带任何选项使用 GNU time 命令时, 你将看到以下输出。
```
$ /usr/bin/time wc /etc/hosts
9 28 273 /etc/hosts
0.00user 0.00system 0:00.00elapsed 66%CPU (0avgtext+0avgdata 2024maxresident)k
0inputs+0outputs (0major+73minor)pagefaults 0swaps
```
如果你用shell关键字 time 运行相同的命令, 输出会有一点儿不同:
```
$ time wc /etc/hosts
9 28 273 /etc/hosts
real 0m0.006s
user 0m0.001s
sys 0m0.004s
```
有时,你可能希望将系统资源使用情况输出到文件中而不是终端上。 为此, 你可以使用 **-o** 选项,如下所示。
```
$ /usr/bin/time -o file.txt ls
dir1 dir2 file1 file2 file.txt mcelog
```
正如你看到的, time命令不会显示到终端上. 因为我们将输出写到了file.txt的文件中。 让我们看一下这个文件的内容:
```
$ cat file.txt
0.00user 0.00system 0:00.00elapsed 66%CPU (0avgtext+0avgdata 2512maxresident)k
0inputs+0outputs (0major+106minor)pagefaults 0swaps
```
当你使用 **-o** 选项时, 如果你没有一个文件名叫 file.txt, 它会创建一个并把输出写进去。 如果文件存在, 它会覆盖文件原来的内容。
你可以使用 **-a** 选项将输出追加到文件后面,而不是覆盖它的内容。
```
$ /usr/bin/time -a file.txt ls
```
**-f** 选项允许用户根据自己的喜好控制输出格式。 比如说, 以下命令的输出仅显示用户,系统和总时间。
```
$ /usr/bin/time -f "\t%E real,\t%U user,\t%S sys" ls
dir1 dir2 file1 file2 mcelog
0:00.00 real, 0.00 user, 0.00 sys
```
请注意shell中内建的 time 命令并不具有Gnu time程序的所有功能。
有关Gnu time程序的详细说明可以使用man命令来查看。
```
$ man time
```
想要了解有关Bash 内建 Time 关键字的更多信息, 请运行:
```
$ help time
```
就到这里吧。 希望对你有所帮助。
会有更多好东西分享哦。 请关注我们!
加油哦!
--------------------------------------------------------------------------------
via: https://www.ostechnix.com/how-to-find-the-execution-time-of-a-command-or-process-in-linux/
作者:[SK][a]
选题:[lujun9972][b]
译者:[caixiangyue](https://github.com/caixiangyue)
校对:[校对者ID](https://github.com/校对者ID)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]: https://www.ostechnix.com/author/sk/
[b]: https://github.com/lujun9972
[1]: https://www.ostechnix.com/find-long-process-running-linux/
[2]: https://www.ostechnix.com/the-type-command-tutorial-with-examples-for-beginners/