后台终端Screen使用

1、查看sreen状态

screen -ls

Attached:表示当前screen正在作为主终端使用,为活跃状态。
Detached:表示当前screen正在后台使用,为非激发状态。

2、查询命令提示

screen -help

3、创建终端

(1)使用-R创建,如果之前有创建唯一一个同名的screen,则直接进入之前创建的screen
(2)使用-S创建和直接输入screen创建的虚拟终端,不会检录之前创建的screen(也就是会创建同名的screen)

### 法1:创建一个名称为 Hello的虚拟终端
screen -R Hello
### 法2 :
screen -S Hello

要在开启时记录屏幕日志

(1)启动时添加选项-L(Turn on output logging.),会在当前目录下生成screenlog.0文件。如果执行-L命令后看不到新建的日志,可能是文件读写权限不够,e.g. sudo chmod 777 filename可以修改文件读写权限。

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.,停止记录日志。
上面两个方法有个缺点:当创建多个screen会话的时候,每个会话都会记录日志到screenlog.0文件。screenlog.0中的内容就比较混乱了。
(3)在screen配置文件/etc/screenrc最后添加下面一行:

logfile /tmp/screenlog_%t.log

注意,如果写成:logfile ./screenlog_%t.log 则是把日志文件记录到当前目录下
%t是指window窗口的名称,对应screen的-t参数。所以我们启动screen的时候要指定窗口的名称,例如:

screen -L -t window1 -S test

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

4、退出当前虚拟终端

按Ctril+a+d,screen运行的进程转到后台运行并回到主终端

5、使用-R或者-r命令回到创建的虚拟终端:

# 使用screen -r命令
screen -r [pid/name]

pid/name:为虚拟终端PID或Name

6、清除虚拟终端:

(1)法1:在虚拟终端内输入:

# 退出终端
exit

(2)法2:主终端内,使用命令释放:

# 使用-R/-r/-S均可
screen -R [pid/Name] -X quit

无法进入Attached状态的问题

screen有两种状态,Attached状态的意思是当前虚拟终端用户正在使用,这个时候,是无法进入的。但是并没有使用Ctril+a再按d退出并挂起虚拟终端的时候,因为一些原因长时间没操作,或者本地网络掉包等问题,非正常退出虚拟终端,用户并没有在虚拟终端内,却出现Attached状态:

screen -d [pid/Name]
posted @ 2023-11-05 16:25  亦痕  阅读(122)  评论(0编辑  收藏  举报
//点击特效
//为右下角推荐推荐区域添加关注按钮 // 生成目录索引列表 //返回顶部