Linux screen使用技巧

我们知道,当用户注销(logout)或者网络断开时,终端会收到 HUP(hangup)信号从而关闭其所有子进程。因此,我们的解决办法就有两种途径:要么让进程忽略 HUP 信号,要么让进程运行在新的会话里从而成为不属于此终端的子进程。

此时最方便的方法就是 screen 了。简单的说,screen 提供了 ANSI/VT100 的终端模拟器,使它能够在一个真实终端下运行多个全屏的伪终端。

一、screen安装

1
2
sudo apt-get update
sudo apt-get install screen

二、常用命令介绍

1
2
3
4
5
6
screen -S name                   #启动一个名字为name的screen
screen -S session_name -X quit #使用screen名字,kill掉
screen -ls #是列出所有的screen
screen -r name/id #回到某个screen了
ctrl + a + d #回到前一个screen,当时在当前screen运行的程序不会停止
ctrl + Z #停止

三、Screen记录屏幕日志

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

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

1、第一种方法

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

1
screen -L -dmS test
  • screen -L -dmS test的意思是启动一个开始就处于断开模式的会话,会话的名称是test
  • screen -r test连接该会话,在会话中的所有屏幕输出都会记录到screenlog.0文件。

2、第二种方法

不加选项-L,启动后,在screen session下按ctrl+a H,同样会在当前目录下生成screenlog.0文件。

  • 第一次按下ctrl+a H,屏幕左下角会提示Creating logfile "screenlog.0".,开始记录日志。
  • 再次按下ctrl+a H,屏幕左下角会提示Logfile "screenlog.0" closed.,停止记录日志。

3、补充

上面两个方法有个缺点:当创建多个screen会话的时候,每个会话都会记录日志到screenlog.0文件。screenlog.0中的内容就比较混乱了。

解决方法如下,让每个screen会话窗口有单独的日志文件。

在screen配置文件/etc/screenrc最后添加下面一行:

1
logfile /tmp/screenlog_%t.log

%t是指window窗口的名称,对应screen的-t参数。所以我们启动screen的时候要指定窗口的名称,例如:

1
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 则是把日志文件记录到当前目录下。

4、一个例子

1
screen -L -t name -S name ./name
  • 第一个name是记录日志的名字
  • 第二个name是screen -ls 列表展示出来的名字
  • 第三个name是需要运行的程序

四、解决screen状态为Attached连不上的问题

当你挂起screen,下次想连上screen的时候,有时候会出现screen session的状态为Attached而怎么连也连不上的情况。下面给出解决方法。

列出状态为Attached的session id。

1
screen -ls

然后输入:

1
screen -D  -r <session-id>

-D -r代表:先踢掉前一用户,再登陆。

赞赏一杯咖啡
0%