文本模式下录制、回放和共享操作记录(script、scriptreplay、mkfifo)的妙用
环境:redhat 6.4 工具:script、scriptreplay、mkfifo
在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命令:
[root@itbing~]#script
Script started,file is typescript
[root@itbing~]# #进入录制状态,这期间输入的任何指令都会被记录
[root@itbing~]#exit #退出停止录制
Script doen,file is typescript
#如果script后面没有指定记录文件,默认会记录在当前目录下的typescript文件内
2、退出停止
#要退出记录活动,我们可以在终端中按下Ctrl+D,或者输入exit。
3、指定保存文件
平时最好还是指定保存的文件,如
`[root@itbing~]#script 20151031.log``
4、查看编辑记录
可以用cat来查看保存下来的记录文件
#cat 20151031.log
用vim查看编辑时,会有一些特殊字符,不是很友好。 单个记录文件是没办法用scriptreplay命令回放的,需要录制的时候一起保存时序文件,和时序文件一起才能回放。后面会讲。
5、实时保存
在退出script前,你会发现记录文件的大小为0 Kb,而在退出之后,文件大小会发生改变。 这说明默认不是实时记录的,一旦强制关闭了,就不会有记录。 所以平时需要加个-f参数,实时记录下来。
#script -f 20151031.log
6、追加保存
如果保存完成之后,想继续用原来的文件保存,增加记录而不覆盖,需要加上-a参数
#script -f -a 20151031.log
7、静默记录
-q选项可以让scirpt命令以静默模式运行
#script -f -q 20151031.log
8、实例:静默开机启动,录制每个人的操作记录
写入环境配置文件中:
[root@itbing~]#vim /etc/profile
#如果只是想记录某一个用户的,写入用户的.bash_profile中即可,不能放在bashrc文件中
/usr/bin/script -qa /var/log/script.log
#-q以静默状态启动
#-a追加文件记录,不覆盖
[root@itbing~]#source /etc/profile #使环境变量生效,最好还是重启一下
二、scriptreplay详解:
scriptreplay的功能很简单,就是用来回放前面用script录制的记录。
#scriptreplay timingfile typescript
timingfile就是时序文件,记录时间数据,记录每一个指令在何时运行 typescript就是记录操作步骤文件 这两个文件的名称和路径,可以任意指定。
所以录制的时候只有单个录制文件,没有录制时序,是没办法回放的。 这里就需要用到script的其它命令了
#script -t 2>20151031.time -a 20151031.txt
#20151031.time 就是时序文件,记录操作的时间
#20151031.txt 记录操作步骤
-t选项用于将时序数据导入stderr
2>用于stderr重定向到20151031.time
现在就可以用scriptreplay来播放上面录制的操作了
# scriptreplay 20151031.time 20151031.txt
三、script+mkfifo
mkfifo 使用指定的文件名创建FIFO(也称为"命名管道"). “FIFO"是一种特殊的文件类型,它允许独立的进程通讯。 一个进程打开FIFO文件进行写操作,而另一个进程对之进行读操作, 然后数据便可以如同在shell或者其它地方常见的的匿名管道一样流线执行。 详细用法可man或百度。
这里主要是讲和script配合,达到多方协调配合。
#mkfifo 20151031.log;script -f 20151031.log
然后同事可以远程在另一个终端登录,找到这个20151031.log文件,执行 cat 20151031.log 就会实时滚动输出你操作的内容