screen是Linux窗口管理器,用户可以建立多个screen会话,每个screen会话又可以建立多个window窗口,每一个窗口就像一个可操作的真实的ssh终端一样。
下面介绍如何记录screen屏幕日志。
第一种方法
启动时添加选项-L(Turn on output logging.)
会在当前目录下生成screenlog.0
文件。
screen -L -dmS test
screen -L -dmS test
的意思是启动一个开始就处于断开模式的会话,会话的名称是test
。screen -r test
连接该会话,在会话中的所有屏幕输出都会记录到screenlog.0
文件。
第二种方法
不加选项-L
,启动后,在screen session下按ctrl+a H
,同样会在当前目录下生成screenlog.0
文件。
- 第一次按下
ctrl+a H
,屏幕左下角会提示Creating logfile "screenlog.0".
,开始记录日志。 - 再次按下
ctrl+a H
,屏幕左下角会提示Logfile "screenlog.0" closed.
,停止记录日志。
补充
上面两个方法有个缺点:当创建多个screen会话的时候,每个会话都会记录日志到screenlog.0
文件。screenlog.0
中的内容就比较混乱了。
解决方法如下,让每个screen会话窗口有单独的日志文件。
在screen配置文件/etc/screenrc
最后添加下面一行:
logfile /tmp/screenlog_%t.log
%t
是指window窗口的名称,对应screen的-t
参数。所以我们启动screen的时候要指定窗口的名称,例如:
screen -L -t window1 -dmS test
screen -L -t window1 -dmS test
的意思是启动test会话,test会话的窗口名称为window1。屏幕日志记录在/tmp/screenlog_window1.log
。如果启动的时候不加-L参数,在screen session下按ctrl+a H
,日志也会记录在/tmp/screenlog_window1.log
。
注意,如果写成:logfile ./screenlog_%t.log
则是把日志文件记录到当前目录下。
一个例子
screen -L -t name -S name ./name
- 第一个name是记录日志的名字
- 第二个name是
screen -ls
列表展示出来的名字 - 第三个name是需要运行的程序