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

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

例子:
[lhd@hongdi ~]$ ls > ls.txt
[lhd@hongdi ~]$ 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
它从标准输入读取内容并将其写到标准输出和文件中

看例子:
[lhd@hongdi ~]$ ls | tee ls_tee.txt
1.gtkrc-2.0                        
2009                               
a                                  
amsn_received 
a.tar.gz 
[lhd@hongdi ~]$ 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这个命令很强大,可以记录终端的所有输出到相应的文件中

看例子:
[lhd@hongdi ~]$ script
Script started, file is typescript
[lhd@hongdi ~]$ 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 
[lhd@hongdi ~]$ exit
exit
Script done, file is typescript
[lhd@hongdi ~]$ cat typescript
Script started on 2009年02月08日 星期日 18时56分52秒
[lhd@hongdi ~]$ 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 
[lhd@hongdi ~]$ exit
exit

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

说明:
1,我们在启动script时没有指定文件名,它会自动记录到当前目录下一个名为 typescript的文件中
也可以用 -a参数 指定文件名
例子:  
[lhd@hongdi ~]$ 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进行播放。
如果录制时记录下来了操作时的时间数据,那么播放时和操作时的使用时间完全相同,
这个很有用吧,比如:我们可以把安装软件时编译的过程记录下来,然后给别人进行演示

看例子:
[lhd@hongdi ~]$ script -t 2>example.time -a example.txt
Script started, file is example.txt
[lhd@hongdi ~]$ 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
之后复制文件到系统的命令目录中即可
[root@hongdi 下载]# cp util-linux-2.12r/misc-utils/scriptreplay.pl /usr/bin/scriptreplay
[root@hongdi 下载]# chmod 755 /usr/bin/scriptreplay
备注: fedora 10的util-linux-ng-2.14.1-3.2.fc10.i386.rpm  此包中已包含 scriptreplay,已无需另行安装

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

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

  1. 【转】 Linux中记录终端输出到txt文本文件

    转载: http://blog.csdn.net/tengh/article/details/41823883 一,把命令运行的结果保存到文件当中:用 > 把输出转向就可以了 例子: $ ls ...

  2. 记录终端输出的LOG到文件

    先要说明为什么要记录终端会话,因为常会遇到这样的情况,终端是有缓存大小限制的,当在终端打印的消息超出缓存范围,它前面的打印消息就自动丢失了,这对于我们调试程序会造成障碍,所以有记录完整终端打印消息的必 ...

  3. Linux中记录终端(Terminal)输出到文本文件(转载)

    一,如何把命令运行的结果保存到文件当中? 这个问题太简单了,大家都知道,用 > 把输出转向就可以了 例子: [lhd@hongdi ~]$ ls > ls.txt [lhd@hongdi ...

  4. Linux记录屏幕输出log

    应用场景: 请专家通过Console处理问题时,保留console输出无疑是非常有意义的.一来可留着作为维护日志,二来可供事后学习. 最简洁的方式是通过系统自带的script命令去记录. $ scri ...

  5. 微软BI 之SSIS 系列 - 通过 ROW_NUMBER 或 Script Component 为数据流输出添加行号的方法

    开篇介绍 上午在天善回答看到这个问题 - SSIS 导出数据文件,能否在第一列增加一个行号,很快就帮助解决了,方法就是在 SQL 查询的时候加一个 ROW_NUMBER() 就可以了. 后来想起在两年 ...

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

    转载自:http://www.cnblogs.com/clover-toeic/p/4031618.html 在Linux终端下调试程序时,有时需要输出大量信息.若能控制字体的颜色和显示方式,可使输出 ...

  7. linux 终端输出颜色

    在Linux终端下调试程序时,有时需要输出大量信息.若能控制字体的颜色和显示方式,可使输出信息对比鲜明,便于调试时观察数据. 终端的字符颜色由转义序列(Escape Sequence)控制,是文本模式 ...

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

    使用Jsch执行命令,并读取终端输出 jsch http://www.jcraft.com/jsch/ Jsch是java实现的一个SSH客户端.开发JSCH的公司是 jcraft: JCraft成立 ...

  9. 花里胡哨,如何在Linux终端输出带有颜色的字体,将带颜色的字体赋值给变量

    背景 ​ 在日常操作Linux的情况下,总会遇到一些需求,比如说,把输出的内容用不同颜色标注出来,以达到醒目.提示的目的,那么如何在Linux终端输出带有颜色的字体呢? Linux终端输出字符颜色 ​ ...

随机推荐

  1. 认识Android

    安卓的特点开放性平等性无界性方便性硬件的丰富性 Android操作系统之中,一共将体系结构划分为四层:应用层(Application).应用框架层(Application Framework).系统运 ...

  2. Protel 的自动推挤功能

    大家都在用PROTEL99SE...有时候要修改布好的线...一条条的去拆,这样很麻烦.其实PROTEL99SE是有推挤功能的...虽然不是很强...但是可以给大家带来方便.下面我就发个自己制作的教程 ...

  3. 关于URL编码/javascript/js url 编码/url的三个js编码函数

    关于URL编码/javascript/js url 编码/url的三个js编码函数escape(),encodeURI(),encodeURIComponent() 本文为您讲述关于js(javasc ...

  4. Linux企业级项目实践之网络爬虫(30)——通过查阅RFC文档扩充更加复杂的功能

    HTTP是一种很简单的请求.响应式协议,客户端发送一个请求.服务器返回一个响应.HTTP 1.1 版本规范由 RFC2616 定义.了解了 HTTP请求.响应消息在TCP数据流中的格式,很容易使用纯 ...

  5. MFC单文档自定义扩展名及添加图标报Assertion错误

    忽然无聊的想给自己写的程序保存的文件使用自己的名字简写作为后缀,于是有了下文. IDR_MAINFRAME格式介绍 IDR_MAINFRAME字符串资源中包含7个子串,分别以/n结束,即如下格式: & ...

  6. 《Node.js开发指南》知识整理

    Node.js简介 Node是一个可以让JavaScript运行在服务器端的平台,抛弃了传统平台依靠多线程来实现高并发的设计思路,而采用单线程.异步式I/O.事件驱动式的程序设计模型. 安装和配置No ...

  7. Codeforce 221 div1

    A 只要打个表就能发现,1,6,8,9的所有排列就可以产生0~6的余数了... 所以...走不下去的时候一定要打表... #define rep(i,n) for(int i=0 ; i<(n) ...

  8. [原创]Python入门到简单网站目录扫描器编写(上)

    1.字符串,整型,浮点型.区别以及用法 |------字符串是 Python 中最常用的数据类型.我们可以使用引号('或")来创建字符串. 可以不严格的说,你可以认为引号包括的,都属于字符串 ...

  9. 【C#通用类】日志记录类

    using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Tex ...

  10. struts2.1.3之后使用自定义Filter

    struts2中 ActionContextCleanUp, StrutsPrepareAndExecuteFilter, StrutsPrepareFilter,StrutsExecuteFilte ...