首页 > 代码库 > linux screen技巧:记录屏幕日志

linux screen技巧:记录屏幕日志

    screen是Linux窗口管理器,用户可以建立多个screen会话,每个screen会话又可以建立多个window窗口,每一个窗口就像一个可操作的真实的ssh终端一样。

    screen详解:http://www.ibm.com/developerworks/cn/linux/l-cn-screen/

    下面介绍如何记录screen屏幕日志。

    第一种方法:

    启动时添加选项-L(Turn on output logging.),会在当前目录下生成screenlog.0文件。

wKioL1QJQ1-zsceYAABrE371q_I797.jpg

    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的时候要指定窗口的名称,例如:

wKioL1QJSYOCbu7oAAB1Zw9Tfew071.jpg

    screen -L -t window1 -dmS test的意思是启动test会话,test会话的窗口名称为window1。屏幕日志记录在/tmp/screenlog_window1.log。如果启动的时候不加-L参数,在screen session下按ctrl+a H,日志也会记录在/tmp/screenlog_window1.log。


本文出自 “启程-Linux技术博客” 博客,请务必保留此出处http://qicheng0211.blog.51cto.com/3958621/1549201

linux screen技巧:记录屏幕日志