下面介绍如何记录screen屏幕日志。node
第一种方法:linux
启动时添加选项-L(Turn on output logging.),会在当前目录下生成screenlog.0文件。session
screen -L -dmS test的意思是启动一个开始就处于断开模式的会话,会话的名称是test。ide
screen -r test链接该会话,在会话中的全部屏幕输出都会记录到screenlog.0文件。ui
第二种方法:命令行
不加选项-L,启动后,在screen session下按ctrl+a H,一样会在当前目录下生成screenlog.0文件。日志
第一次按下ctrl+a H,屏幕左下角会提示Creating logfile "screenlog.0".,开始记录日志。blog
再次按下ctrl+a H,屏幕左下角会提示Logfile "screenlog.0" closed.,中止记录日志。get
上面两个方法有个缺点:当建立多个screen会话的时候,每一个会话都会记录日志到screenlog.0文件。screenlog.0中的内容就比较混乱了。it
解决方法以下,让每一个screen会话窗口有单独的日志文件。
在screen配置文件/etc/screenrc最后添加下面一行:
logfile /tmp/screenlog_%t.log
%t是指window窗口的名称,对应screen的-t参数。因此咱们启动screen的时候要指定窗口的名称,例如:
screen -L -t window1 -dmS test的意思是启动test会话,test会话的窗口名称为window1。屏幕日志记录在/tmp/screenlog_window1.log。若是启动的时候不加-L参数,在screen session下按ctrl+a H,日志也会记录在/tmp/screenlog_window1.log。
[root@linux-node1 ~]# screen -ls
There are screens on:
67495.test (Detached)
67752.test (Detached)
2 Sockets in /var/run/screen/S-root.
[root@linux-node1 ~]# screen -r 67495
进入67495窗口后,执行exit退出当前窗口。当一个会话中的全部窗口都被结束,则该会话会被自动终止,命令行会提示[screen is terminating]。此时在查看只有一个会话了:
[root@linux-node1 ~]# screen -ls
There is a screen on:
67752.test (Detached)
1 Socket in /var/run/screen/S-root.