Linux文本模式下录制、回放和共享操作记录(script、scriptreplay、mkfifo)的妙用


在生产中,有时候需要把别人的操作过程录制下来,后期可以进行回放查看。还可以实时共享自己的操作,让另一个人在千里之外指导你进行操作。


环境:redhat 6.4

工具:script、scriptreplay、mkfifo
1
2
3
4
5
6
7
8
9
10
在redhat 6中自动带有scriptreplay指令,在redhat5中没有该指令,需要手动安装
从ftp://ftp.kernel.org/pub/linux/utils/util-linux/v2.14/下载util-linux-ng-2.14.1.tar.gz
从http://rpm.pbone.net中下载util-linux-2.13-0.44.el5.x86_64.rpm
安装rpm包
#rpm -ivh util-linux-2.13-0.44.el5.x86_64.rpm
解压util-linux-ng-2.14.1.tar.gz
#tar zxvf util-linux-ng-2.14.1.tar.gz
进入解压后的目录
然后运行
#./configure && make && make install

前言:
平时用history也能查自己操作过的命令,但是只能看自己输入的命令记录,系统的回显等等信息是看不了的。
而script工具可以记录在终端中所做的一切,包括回显信息等,就相当于是图形桌面环境下的录屏软件,不同的是,这里记录下来保存的文件是文本格式。
这些记录可以用来当作日志,保存终端所发生的一切,需要时回放查看。
也可以结合mkfifo,实时跟同事共享,协同工作。

一、script详解:
1、默认状态
默认情况下,我们可以通过在终端中输入script来启动scirpt命令:

1
2
3
4
5
6
[root@bing~]#script
Script started,file is typescript
[root@bing~]#                #进入录制状态,这期间输入的任何指令都会被记录
[root@bing~]#exit            #退出停止录制
Script doen,file is typescript
#如果script后面没有指定记录文件,默认会记录在当前目录下的typescript文件内

2、退出停止
#要退出记录活动,我们可以在终端中按下Ctrl+D,或者输入exit。

3、指定保存文件
平时最好还是指定保存的文件,如

1
[root@bing~]#script 20151031.log

4、查看编辑记录
可以用cat来查看保存下来的记录文件

1
[root@bing~]#cat 20151031.log

用vim查看编辑时,会有一些特殊字符,不是很友好。
单个记录文件是没办法用scriptreplay命令回放的,需要录制的时候一起保存时序文件,和时序文件一起才能回放。后面会讲。

5、实时保存
在退出script前,你会发现记录文件的大小为0 Kb,而在退出之后,文件大小会发生改变。
这说明默认不是实时记录的,一旦强制关闭了,就不会有记录。
所以平时需要加个-f参数,实时记录下来。

1
[root@bing~]#script -f 20151031.log

6、追加保存
如果保存完成之后,想继续用原来的文件保存,增加记录而不覆盖,需要加上-a参数

1
[root@bing~]#script -f -a 20151031.log

7、静默记录
-q选项可以让scirpt命令以静默模式运行

1
[root@bing~]#script -f -q 20151031.log

8、实例:静默开机启动,录制每个人的操作记录
写入环境配置文件中:

1
2
3
4
5
6
[root@bing~]#vim /etc/profile      
#如果只是想记录某一个用户的,写入用户的.bash_profile中即可,不能放在bashrc文件中
/usr/bin/script -qa /var/log/script.log
#-q以静默状态启动
#-a追加文件记录,不覆盖
[root@bing~]#source /etc/profile      #使环境变量生效,最好还是重启一下

二、scriptreplay详解:
scriptreplay的功能很简单,就是用来回放前面用script录制的记录。

1
[root@bing~]#scriptreplay timingfile typescript

timingfile就是时序文件,记录时间数据,记录每一个指令在何时运行
typescript就是记录操作步骤文件
这两个文件的名称和路径,可以任意指定。

所以录制的时候只有单个录制文件,没有录制时序,是没办法回放的。
这里就需要用到script的其它命令了

1
2
3
4
5
[root@bing~]#script -t 2>20151031.time -a 20151031.txt
#20151031.time 就是时序文件,记录操作的时间
#20151031.txt  记录操作步骤
-t选项用于将时序数据导入stderr
2>用于stderr重定向到20151031.time

现在就可以用scriptreplay来播放上面录制的操作了

1
[root@bing~]# scriptreplay 20151031.time 20151031.txt

三、script+mkfifo
mkfifo 使用指定的文件名创建FIFO(也称为”命名管道”).
“FIFO”是一种特殊的文件类型,它允许独立的进程通讯。 一个进程打开FIFO文件进行写操作,而另一个进程对之进行读操作, 然后数据便可以如同在shell或者其它地方常见的的匿名管道一样流线执行。
详细用法可man或百度。

这里主要是讲和script配合,达到多方协调配合。

1
[root@bing~]#mkfifo 20151031.log;script -f 20151031.log

然后同事可以远程在另一个终端登录,找到这个20151031.log文件,执行
cat 20151031.log
就会实时滚动输出你操作的内容

上一篇:Spring MVC url提交参数和获取参数


下一篇:Script:检查数据库当前是否有备份操作在执行中