Linux Screen技巧:记录屏幕日志
screen是Linux窗口管理器,用户可以建立多个screen会话,每个screen会话又可以建立多个window窗口,每一个窗口就像一个可操作的真实的ssh终端一样。
screen详解:http://www.linuxidc.com/Linux/2013-10/91612.htm
Linux Screen超简明教程 http://www.linuxidc.com/Linux/2014-04/100040.htm
Linux下Screen的常用命令 http://www.linuxidc.com/Linux/2012-07/65358.htm
Zabbix通过邮件发送Screen图形报表实现 http://www.linuxidc.com/Linux/2013-06/85759.htm
Linux虚拟终端命令Screen用法详解 http://www.linuxidc.com/Linux/2013-07/87415.htm
Linux 技巧:使用 Screen 管理你的远程会话 http://www.linuxidc.com/Linux/2013-10/91612.htm
下面介绍如何记录screen屏幕日志。
第一种方法:
启动时添加选项-L(Turn on output logging.) 会在当前目录下生成screenlog.0文件。
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的意思是启动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是需要运行的程序。
附录:
源码编译安装 screen
[root@web1 soft]# wget ftp://ftp.gnu.org/pub/gnu/screen/screen-4.0.3.tar.gz
[root@web1 soft]# tar -xvf screen-4.0.3.tar.gz
[root@web1 soft]# cd screen-4.0.3
[root@web1 screen-4.0.3]# ./configure
[root@web1 screen-4.0.3]# make
[root@web1 screen-4.0.3]# make install
[root@web1 screen-4.0.3]# install -m 644 etc/etcscreenrc /etc/screenrc
[root@web1 screen-4.0.3]# cp ./screen /bin
请注意:与一般程序的安装过程有所不同,后面这两条指令一定要执行
补充: 一次新安装 screen时,按照上述步骤,make时报错:
configure: error: !!! no tgetent - no screen
make: *** [install] 错误 1
解决方法如下:
yum -y install ncurses-devel
更多推荐
所有评论(0)