Linux Screen记录屏幕日志

本文介绍在Linux环境下使用screen窗口管理器记录会话日志的方法,包括启动时添加选项-L,以及在session中通过快捷键开启和关闭日志记录。同时,提供了解决多个会话日志混淆的方案,确保每个会话窗口有独立的日志文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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是需要运行的程序
### 如何在 Linux 中使用 `screen` 命令 #### 启动 `screen` 为了创建一个新的 `screen` 会话,可以直接输入 `screen` 命令。这将会开启一个新的 shell 窗口,在这里可以像平常一样执行任何命令[^3]。 ```bash screen ``` #### 列出会话 当有多个 `screen` 会话正在运行时,可以通过 `-ls` 参数来查看当前所有的会话列表: ```bash screen -ls ``` 此命令将显示所有可用的 `screen` 会话及其 ID 和名称[^5]。 #### 连接到已有的会话 要重新连接到之前已经存在的 `screen` 会话,可利用其唯一的标识符(ID),并通过如下方式实现: ```bash screen -r <session_id> ``` 这里的 `<session_id>` 是指由上述列出的会话所对应的唯一编号或名字的一部分。 #### 断开会话而不终止进程 有时候可能想要暂时离开当前的工作环境而不想结束正在进行的任务,则只需按下组合键 `Ctrl+A`, 接着按 `D` 键即可分离当前会话但仍让程序继续在后台工作。此时可以从任意位置再次接入该会话而不会丢失进度[^1]。 #### 关闭 `screen` 会话 一旦完成了所需的操作并且不再需要保持这个特定的 `screen` 实例活跃,那么就可以安全地退出它。为此,先返回至 `screen` 的提示符处(`Ctrl+A`), 然后再敲击`:quit` 或者直接打字 `exit` 来彻底停止整个 session 并清除资源[^2]。 #### 使用 `screen` 执行持续输出脚本 假设有一个名为 `test.sh` 的 Bash 脚本文件,内容为每隔十秒钟打印一次带有时间戳的信息。为了让这样的长期任务能够在无人值守的情况下稳定运作,应该将其放置在一个新的 `screen` 环境里去执行: ```bash cat <<EOL > ~/test.sh #!/bin/bash while true; do echo "输出\$(date +%F-%T)" sleep 10 done EOL chmod +x ~/test.sh screen -S myscript ./test.sh ``` 这段代码首先构建了一个简单的循环打印日期时间的日志记录器,并赋予了可执行权限;接着以指定的名字 (`myscript`) 开启了一次性的 `screen` 容器来承载我们的自定义指令集[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值