用tee和script来记录终端输出

如何在输出信息的同时把数据保存到文件当中?

一,如何把命令运行的结果保存到文件当中?
这个问题太简单了,大家都知道,用 > 把输出转向就可以了

例子:
[[email protected] ~]$ ls > ls.txt
[[email protected] ~]$ cat ls.txt 
1.gtkrc-2.0                
2009                       
a                          
amsn_received                         
a.tar.gz

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

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

我们在上面的例子中可以看到,我们使用输出转向,命令在终端上的输出转向到了文件中,
但如果我希望能同时在终端上看到输出信息怎么办?
我们可以使用这个命令: tee

解释一下tee的作用:
read from standard input and write to standard output and files
它从标准输入读取内容并将其写到标准输出和文件中

看例子:
[[email protected] ~]$ ls | tee ls_tee.txt
1.gtkrc-2.0                        
2009                               
a                                  
amsn_received 
a.tar.gz 
[[email protected] ~]$ cat ls_tee.txt
1.gtkrc-2.0                   
2009                          
a                             
amsn_received                               
a.tar.gz

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

三,多个命令的输出都需要记录,可以用script
script这个命令很强大,可以记录终端的所有输出到相应的文件中

看例子:
[[email protected] ~]$ script
Script started, file is typescript
[[email protected] ~]$ ls
1.gtkrc-2.0                  c.tar                            kmess-2.0alpha2.tar.gz            secpanel-0.5.3-1.noarch.rpm 
2009                         DownZipAction.php                kmesslog                          secpanel-0.5.4-2.noarch.rpm 
[[email protected] ~]$ exit
exit
Script done, file is typescript
[[email protected] ~]$ cat typescript
Script started on 2009年02月08日 星期日 18时56分52秒
[[email protected] ~]$ ls
1.gtkrc-2.0                  c.tar                            kmess-2.0alpha2.tar.gz            secpanel-0.5.3-1.noarch.rpm 
2009                         DownZipAction.php                kmesslog                          secpanel-0.5.4-2.noarch.rpm 
[[email protected] ~]$ exit
exit

Script done on 2009年02月08日 星期日 18时57分00秒

说明:
1,我们在启动script时没有指定文件名,它会自动记录到当前目录下一个名为 typescript的文件中
也可以用 -a参数 指定文件名
例子:  
[[email protected] ~]$ script -a example.txt
Script started, file is example.txt
此时终端的输出内容被记录到 example.txt这个文件中
2,退出script时,用exit
感到奇怪吗?事实上script就是启动了一个shell
看一下ps auxfww 的信息就知道了
lhd      17738  0.1  3.2 152028 33328 begin_of_the_skype_highlighting              152028 33328      end_of_the_skype_highlighting ?        Sl   18:30   0:03 /usr/bin/konsole
lhd      17740  0.0  0.1   6372  1720 pts/1    Ss   18:30   0:00  \_ /bin/bash
lhd      17900  0.0  0.0   5344   628 pts/1    S+   19:01   0:00  |   \_ script
lhd      17901  0.0  0.0   5348   464 pts/1    S+   19:01   0:00  |       \_ script
lhd      17902  0.5  0.1   6372  1688 pts/2    Ss+  19:01   0:00  |           \_ bash -i

3,查看typescript的内容,可以看到它同时记录下了script的启动和结束时间

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

看例子:
[[email protected] ~]$ script -t 2>example.time -a example.txt
Script started, file is example.txt
[[email protected] ~]$ ls
说明:  -t 2>example.time   -t是把时间数据输出到标准错误(standard error)
所以我们使用 2>example.time 把数据转向到 example.time这个文件当中

如何播放所记录的内容?
第一步:安装scriptreplay
下载
wget ftp://ftp.kernel.org/pub/linux/utils/util-linux/util-linux-2.12r.tar.bz2
解压
tar -jxvf util-linux-2.12r.tar.bz2
之后复制文件到系统的命令目录中即可
[[email protected] 下载]# cp util-linux-2.12r/misc-utils/scriptreplay.pl /usr/bin/scriptreplay
[[email protected] 下载]# chmod 755 /usr/bin/scriptreplay
备注: fedora 10的util-linux-ng-2.14.1-3.2.fc10.i386.rpm  此包中已包含 scriptreplay,已无需另行安装

第二步:播放所录制的session内容
[[email protected] ~]$ scriptreplay example1.time example1.txt
[[email protected] ~]$ ls
1.gtkrc-2.0                  c.tar                            [email protected]           pass 
[[email protected] ~]$ abcd
bash: abcd: command not found
[[email protected] ~]$ exit

时间: 2024-10-06 06:39:30

用tee和script来记录终端输出的相关文章

记录终端输出的LOG到文件

先要说明为什么要记录终端会话,因为常会遇到这样的情况,终端是有缓存大小限制的,当在终端打印的消息超出缓存范围,它前面的打印消息就自动丢失了,这对于我们调试程序会造成障碍,所以有记录完整终端打印消息的必要! 1使用script记录Linux终端会话 script是大多数Linux产品util-linux软件包的一部分. script记录会话的一切内容:你输入的内容和你看到的内容.它甚至记录颜色:因此如果你的命令提示符或程序输出中包含颜色,script将记录它. 要使用script,简单执行以下命令

xshell putty等终端,如何记录终端输入输出

如何记录终端输出? 试试使用script命令行工具来为你的终端输出创建输出记录. script caimz.terminal.session #caimz.terminal.session 就是随便起一个名字,我利于认识我起了能认识的名字 [[email protected] ~]# script caimz.terminal.session  #开启Script started, file is caimz.terminal.session[[email protected] ~]# ls1 

Linux命令备忘实例(1)——终端输出

终端是用户与shell环境进行交互的窗口,所有命令的交互结果大部分都是从终端直接显示给用户,因此这部分是友好显示结果的基础. 1.命令概览 echo是基本的终端输出命令,直接将传入的参数输入,命令格式如下: echo [options] toBeOutput 详细说明如下: 2.特性与实例说明 1.换行符 默认情况下会在每次调用之后添加一个换行符.使用-n选项可以消除这个默认值. [email protected]:~$ echo test a line [email protected]:~$

shell在终端输出彩色文本

echo -e "\e[1;31m this is red text \e[0m" \e[1;31m 将颜色设置成红色,\e[0m"将颜色重置. 每种颜色都有对应的颜色码,重置0,黑色30,红色31,绿色32,蓝色34,洋红35,青色36,白色37 要设置彩色背景,经常使用的颜色码有:重置0,黑丝40,红色41,绿色42,***43,蓝色44,洋红45,青色46,白色47. echo -e "\e[1;42m this is green background \e[

通过printf设置Linux终端输出的颜色和显示方式

前言 在Linux终端下调试程序时,有时需要输出大量信息.若能控制字体的颜色和显示方式,可使输出信息对比鲜明,便于调试时观察数据. 终端的字符颜色由转义序列(Escape Sequence)控制,是文本模式下的系统显示功能,与具体语言无关. 本文简要介绍C语言中通过printf改变终端输出的颜色和显示方式.文中涉及的代码运行环境如下: 正文 转义序列以控制字符'ESC'开头.该字符的ASCII码十进制表示为27,十六进制表示为0x1B,八进制表示为033.多数转义序列超过两个字符,故通常以'ES

linux 终端输出颜色

在Linux终端下调试程序时,有时需要输出大量信息.若能控制字体的颜色和显示方式,可使输出信息对比鲜明,便于调试时观察数据. 终端的字符颜色由转义序列(Escape Sequence)控制,是文本模式下的系统显示功能,与具体语言无关. 转义序列以控制字符'ESC'开头.该字符的ASCII码十进制表示为27,十六进制表示为0x1B,八进制表示为033.多数转义序列超过两个字符,故通常以'ESC'和左括号'['开头.该起始序列称为控制序列引导符(CSI,Control Sequence Intro)

c++之改变终端输出的颜色

c++之改变终端输出的颜色 #include <iostream> int main(int argc, char** argv) { std::cout << "\033[0;30m This is black color text ! \033[0m" << std::endl; std::cout << "\033[0;31m This is red color text ! \033[0m" <<

Shell免交互处理、忽略无关输出、记录错误输出(三)

一.免交互的处理●需要输入交互的可执行操作-passwd改密码-ssh远程登录-vim文本编辑器-图形化的安装/配置过程 1.passwd改密的免交互●选项 --stdin-从标准输入读取密码子串-可以从键盘.也可以由另一个命令给出 二.忽略无关输出●黑洞设备 /dev/null-相当于只能写入.不能读出的单向文件-存放到其中的数据就会丢失-用法:可执行语句 &> /dev/null 三.记录错误输出●根据需要,可以将出错的信息保存到指定文件-针对后台脚本的有效拍错手段-适用于不便交互有需要

使用JSCH执行命令并读取终端输出的一些使用心得

使用Jsch执行命令,并读取终端输出 jsch http://www.jcraft.com/jsch/ Jsch是java实现的一个SSH客户端.开发JSCH的公司是 jcraft: JCraft成立于1998年3月,是一家致力于Java应用程序和Internet / Intranet服务的应用程序开发公司. Jcraft的总裁兼首席执行官是Atsuhiko Yamanaka博士 在Yamanaka博士于1998年3月创立JCraft之前,他已经加入NEC公司两年了,从事软件的研究和开发. Ya