Linux录制、回放和共享终端操作

时间:2024-08-03 10:04:14

另一篇终端会话共享的文章:Linux终端会话实时共享(kibitz)

使用script命令录制,使用scriptreplay播放录制的操作。共享终端的操作,则需要使用命名管道来实现。

1.1 录制

[root@xuexi ~]# cd /tmp

[root@xuexi tmp]# script -t > timing.log -a output.session  # 开始录制
Script started, file is output.session
[root@xuexi tmp]# ls                 # 执行一个操作:命令ls
abc.sh ab.sh index.html lost+found output.session scriptfifo test test1 timing.log vmware-root [root@xuexi tmp]# cd /tmp/test # 再执行一个操作:命令cd
[root@xuexi test]# exit  # 结束录制
exit
Script done, file is output.session

其中"-t 2> timing.log"是要回放的必须选项,不加"2>"将导致开启录制后的任何输入都是乱码状态,不加"-t timing.log"将不能使用scriptreplay来回放。timing.log记录的是每个时间段输入了多少字符。通过timing.log和output.session配合可以实现回放。

注意点是,录制前保证timing.log和output.session是空文件,否则将导致回放时操作不一致。

1.2 回放

[root@xuexi test]# scriptreplay timing.log output.session

如果觉得回放的速度过慢(录制时有些地方停顿,比如输入了一个命令后,隔了一段时间才输入另一个命令,这段时间对于回放来说显得慢很正常),可以修改timing.log文件。这个文件中分两个字段,第一个字段记录的是从上次输出后到该次输出的时间间隔,第二个字段是从output.session中读取的字符数。要修改回放速度,只需将第一个字段较长的间隔改短一点就可以。但是不应该改的太短,否则回放速度过快。我觉得将间隔较长的改成0.3-0.7秒,效果还不错。

[root@xuexi ~]# cat timing.log
0.117244
0.007955
0.298074 # 此处将原来的2.298074改为0.3秒
0.216628
0.092781
0.081659
0.083258
0.419445
0.314128
0.100810
0.083998
0.491283
0.266129 # 此处原来也是2.266129秒,显然经过一次命令输出之后停顿了2秒多
0.099767
0.127625
0.078809
0.181493
0.147795
0.115808
0.077416
0.274658
0.257042
0.524460
0.297133
0.458018
0.416350
0.187270
0.125467
0.100756

1.3 终端屏幕分享

通过管道来传输信息实现。需要一个pipe文件,并在需要展示的终端打开这个管道文件。

在终端1(作为主终端,即演示操作的终端)上使用mkfifo创建管道文件。

[root@xuexi tmp]# mkfifo scriptfifo

[root@xuexi tmp]# ll scriptfifo
prw-r--r-- root root Sep : scriptfifo # 权限位前面的第一个p代表的就是pipe文件。

Linux录制、回放和共享终端操作

在终端2上打开pipe文件。

[root@xuexi ~]# cat /tmp/scriptfifo

Linux录制、回放和共享终端操作

在终端1上使用script -f开始记录操作,之后的操作将会分享在终端2上。

[root@xuexi tmp]# script -f scriptfifo

Linux录制、回放和共享终端操作

Linux录制、回放和共享终端操作

使用exit即可停止分享并退出记录行为。

[root@xuexi tmp]# exit
exit
Script done, file is scriptfifo

在被分享终端上参与分享状态后将不能执行任何操作,执行的操作会被记录下来,并在主终端停止分享后自动执行。

需要注意的是,只能给一个会话共享会话终端。如果多个会话 cat scriptfifo ,会导致共享切开显示在多个不同会话上。