另外一篇終端會話共享的文章:Linux終端會話實時共享(kibitz)html
使用script命令錄製,使用scriptreplay播放錄製的操做。共享終端的操做,則須要使用命名管道來實現。session
[root@xuexi ~]# cd /tmp [root@xuexi tmp]# script -t 2> 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配合能夠實現回放。spa
注意點是,錄製前保證timing.log和output.session是空文件,不然將致使回放時操做不一致。code
[root@xuexi test]# scriptreplay timing.log output.session
若是以爲回放的速度過慢(錄製時有些地方停頓,好比輸入了一個命令後,隔了一段時間才輸入另外一個命令,這段時間對於回放來講顯得慢很正常),能夠修改timing.log文件。這個文件中分兩個字段,第一個字段記錄的是從上次輸出後到該次輸出的時間間隔,第二個字段是從output.session中讀取的字符數。要修改回放速度,只需將第一個字段較長的間隔改短一點就能夠。可是不該該改的過短,不然回放速度過快。我以爲將間隔較長的改爲0.3-0.7秒,效果還不錯。htm
[root@xuexi ~]# cat timing.log 0.117244 16 0.007955 1 0.298074 1 # 此處將原來的2.298074改成0.3秒 0.216628 1 0.092781 1 0.081659 1 0.083258 1 0.419445 1 0.314128 1 0.100810 1 0.083998 30 0.491283 1 0.266129 1 # 此處原來也是2.266129秒,顯然通過一次命令輸出以後停頓了2秒多 0.099767 1 0.127625 1 0.078809 1 0.181493 1 0.147795 1 0.115808 1 0.077416 1 0.274658 1 0.257042 1 0.524460 4 0.297133 38 0.458018 1 0.416350 1 0.187270 1 0.125467 1 0.100756 8
經過管道來傳輸信息實現。須要一個pipe文件,並在須要展現的終端打開這個管道文件。blog
在終端1(做爲主終端,即演示操做的終端)上使用mkfifo建立管道文件。ip
[root@xuexi tmp]# mkfifo scriptfifo [root@xuexi tmp]# ll scriptfifo prw-r--r-- 1 root root 0 Sep 26 13:04 scriptfifo # 權限位前面的第一個p表明的就是pipe文件。
在終端2上打開pipe文件。get
[root@xuexi ~]# cat /tmp/scriptfifo
在終端1上使用script -f開始記錄操做,以後的操做將會分享在終端2上。it
[root@xuexi tmp]# script -f scriptfifo
使用exit便可中止分享並退出記錄行爲。pip
[root@xuexi tmp]# exit exit Script done, file is scriptfifo
在被分享終端上參與分享狀態後將不能執行任何操做,執行的操做會被記錄下來,並在主終端中止分享後自動執行。
須要注意的是,只能給一個會話共享會話終端。若是多個會話 cat scriptfifo ,會致使共享切開顯示在多個不一樣會話上。