Linux中记录终端(Terminal)命令及执行结果并输出到文本文件

一、如何把命令运行的结果保存到文件当中?

这个问题太简单了,大家都知道,用 > 把输出转向就可以了
例子:

1
[lmmbao@iZ23b44crpgZ ~]$ ls > ls.txt
[lmmbao@iZ23b44crpgZ ~]$ cat ls.txt 
darkburn.vim
linux-3.10.28
linux-3.10.28.tar.xz
ls.txt
quartz_install.sh
rsync-3.1.1.tar.gz

说明: > 是把输出转向到指定的文件,如文件已存在的话也会重新写入,文件原内容不会保留。>> 是把输出附向到文件的后面,文件原内容会保留下来。

二、如何能在输出信息的同时把信息记录到文件中?

我们在上面的例子中可以看到,我们使用输出转向,命令在终端上的输出转向到了文件中,但如果我希望能同时在终端上看到输出信息怎么办?
我们可以使用这个命令: tee
解释一下tee的作用:
read from standard input and write to standard output and files
它从标准输入读取内容并将其写到标准输出和文件中
看例子:

1
[lmmbao@iZ23b44crpgZ ~]$ ls | tee ls_tee.txt
darkburn.vim
linux-3.10.28
linux-3.10.28.tar.xz
ls.txt
quartz_install.sh
rsync-3.1.1.tar.gz
[lmmbao@iZ23b44crpgZ ~]$ cat ls_tee.txt 
darkburn.vim
linux-3.10.28
linux-3.10.28.tar.xz
ls.txt
quartz_install.sh
rsync-3.1.1.tar.gz

备注:使用 tee时,如果想保留目标文件原有的内容怎么办?可以使用 -a参数。
-a, –append
append to the given FILEs, do not overwrite
附加至给出的文件,而不是覆盖它

三、多个命令的输出都需要记录,可以用script

script这个命令很强大,可以记录终端的所有输出到相应的文件中。
看例子:

1
[lmmbao@iZ23b44crpgZ ~]$ script
Script started, file is typescript
[lmmbao@iZ23b44crpgZ ~]$ ls
darkburn.vim   linux-3.10.28.tar.xz  ls.txt             rsync-3.1.1.tar.gz
linux-3.10.28  ls_tee.txt            quartz_install.sh  typescript
[lmmbao@iZ23b44crpgZ ~]$ exit
exit
Script done, file is typescript
[lmmbao@iZ23b44crpgZ ~]$ cat typescript 
Script started on Tue 13 Jan 2015 05:37:51 PM CST
[lmmbao@iZ23b44crpgZ ~]$ ls
darkburn.vim   linux-3.10.28.tar.xz  ls.txt             rsync-3.1.1.tar.gz
linux-3.10.28  ls_tee.txt            quartz_install.sh  typescript
[lmmbao@iZ23b44crpgZ ~]$ exit
exit

Script done on Tue 13 Jan 2015 05:38:24 PM CST
[lmmbao@iZ23b44crpgZ ~]$

说明:

  1. 我们在启动script时没有指定文件名,它会自动记录到当前目录下一个名为 typescript的文件中。也可以用-a参数 指定文件名
    例子:
    1
    [lmmbao@iZ23b44crpgZ ~]$ script -a example.txt
    Script started, file is example.txt
    [lmmbao@iZ23b44crpgZ ~]$ ls
    darkburn.vim  linux-3.10.28         ls_tee.txt  quartz_install.sh   typescript
    example.txt   linux-3.10.28.tar.xz  ls.txt      rsync-3.1.1.tar.gz
    [lmmbao@iZ23b44crpgZ ~]$ ls
    darkburn.vim  linux-3.10.28         ls_tee.txt  quartz_install.sh   typescript
    example.txt   linux-3.10.28.tar.xz  ls.txt      rsync-3.1.1.tar.gz
    [lmmbao@iZ23b44crpgZ ~]$ exit
    exit
    Script done, file is example.txt
    [lmmbao@iZ23b44crpgZ ~]$ cat example.txt 
    Script started on Tue 13 Jan 2015 05:44:33 PM CST
    [lmmbao@iZ23b44crpgZ ~]$ ls
    darkburn.vim  linux-3.10.28         ls_tee.txt  quartz_install.sh   typescript
    example.txt   linux-3.10.28.tar.xz  ls.txt      rsync-3.1.1.tar.gz
    [lmmbao@iZ23b44crpgZ ~]$ ls
    darkburn.vim  linux-3.10.28         ls_tee.txt  quartz_install.sh   typescript
    example.txt   linux-3.10.28.tar.xz  ls.txt      rsync-3.1.1.tar.gz
    [lmmbao@iZ23b44crpgZ ~]$ exit
    exit
    
    Script done on Tue 13 Jan 2015 05:44:39 PM CST
    [lmmbao@iZ23b44crpgZ ~]$

此时终端的输出内容被记录到example.txt这个文件中

  1. 退出script时,用exit
    感到奇怪吗?事实上script就是启动了一个shell
    看一下ps auxfww 的信息就知道了

    1
    [lmmbao@iZ23b44crpgZ ~]$ ps auxfww | grep lmmbao
    root     17468  0.0  0.0 163908  2152 pts/2    S    16:00   0:00  |       \_ su lmmbao
    lmmbao   17470  0.0  0.0 108392  1852 pts/2    S    16:00   0:00  |           \_ bash
    root     17713  0.0  0.0  98428  4232 ?        Ss   16:08   0:00  \_ sshd: lmmbao [priv]
    lmmbao   17720  0.0  0.0  98428  1720 ?        S    16:09   0:00  |   \_ sshd: lmmbao@pts/1
    lmmbao   17721  0.0  0.0 108392  1840 pts/1    Ss   16:09   0:00  |       \_ -bash
    root     19346  0.0  0.0  98428  4232 ?        Ss   17:24   0:00  \_ sshd: lmmbao [priv]
    lmmbao   19349  0.0  0.0  98428  1724 ?        S    17:24   0:00      \_ sshd: lmmbao@pts/4
    lmmbao   19350  0.0  0.0 108392  1844 pts/4    Ss   17:24   0:00          \_ -bash
    lmmbao   19852  0.0  0.0 110348  1140 pts/4    R+   17:49   0:00              \_ ps auxfww
    lmmbao   19853  0.0  0.0 103304   804 pts/4    S+   17:49   0:00              \_ grep lmmbao
  2. 查看example.txt的内容,可以看到它同时记录下了script的启动和结束时间。

四、用script录制并播放session的内容

我们可以用 script把整个终端会话的所有操作和输出录制下来,然后再用scriptreplay进行播放。
如果录制时记录下来了操作时的时间数据,那么播放时和操作时的使用时间完全相同。
这个很有用吧,比如:我们可以把安装软件时编译的过程记录下来,然后给别人进行演示
看例子:

1
[lmmbao@iZ23b44crpgZ ~]$ script -t 2>example.time -a example.txt
Script started, file is example.txt
[lmmbao@iZ23b44crpgZ ~]$ ls
darkburn.vim  example.txt    linux-3.10.28.tar.xz  ls.txt             rsync-3.1.1.tar.gz
example.time  linux-3.10.28  ls_tee.txt            quartz_install.sh  typescript
[lmmbao@iZ23b44crpgZ ~]$

说明: -t 2>example.time -t是把时间数据输出到标准错误(standard error),所以我们使用 2>example.time 把数据转向到 example.time这个文件当中
如何播放所记录的内容?
第一步:安装scriptreplay
下载

1
wget linux/utils/util-linux/util-linux-2.12r.tar.bz2">ftp://ftp.kernel.org/pub/linux/utils/util-linux/util-linux-2.12r.tar.bz2

解压

1
tar -jxvf util-linux-2.12r.tar.bz2

之后复制文件到系统的命令目录中即可

1
[lmmbao@iZ23b44crpgZ 下载]# cp util-linux-2.12r/misc-utils/scriptreplay.pl /usr/bin/scriptreplay
lmmbao@iZ23b44crpgZ 下载]# chmod 755 /usr/bin/scriptreplay

备注: fedora 10的util-linux-ng-2.14.1-3.2.fc10.i386.rpm 此包中已包含 scriptreplay,已无需另行安装
第二步:播放所录制的session内容

1
[lmmbao@iZ23b44crpgZ ~]$ scriptreplay example1.time example1.txt
[lmmbao@iZ23b44crpgZ ~]$ ls
1.gtkrc-2.0 c.tar zzzz@hotmail.com pass
[lmmbao@iZ23b44crpgZ ~]$ abcd
bash: abcd: command not found

[lmmbao@iZ23b44crpgZ ~]$ exit