赞
踩
screen为多重视窗管理程序。此处所谓的视窗,是指一个全屏幕的文字模式画面。通常只有在使用telnet或者ssh登入主机或是使用老式的终端机时,才有可能用到screen程序。(简单理解就是后台执行任务)
screen的功能大体有三个
-A 将所有的视窗都调整为目前终端机的大小。
-d<作业名称> 将指定的screen作业离线。
-h<行数> 指定视窗的缓冲区行数。
-m 即使目前已在作业中的screen作业,仍强制建立新的screen作业。
-r<作业名称> 恢复离线的screen作业。
-R 先试图恢复离线的作业。若找不到离线的作业,即建立新的screen作业。
-s 指定建立新视窗时,所要执行的shell。
-S<作业名称> 指定screen作业的名称。
-v 显示版本信息。
-x 恢复之前离线的screen作业。
-ls或–list 显示目前所有的screen作业。
-wipe 检查目前所有的screen作业,并删除已经无法使用的screen作业
因为screen是“元老级”的GNU计划项目,所以不管是apt软件源、或者是yum软件源等其他软件源,都存在screen,只需要使用软件源安装命令即可:
# CentOS
yum install screen
# Debian/Ubuntu
apt install screen
安装完可以使用screen -v查看
查看已经存在的screen终端使用命令:
screen -ls
没有创建screen的话是这样的
screen官方推荐的创建虚拟终端的方法是:
# 创建一个叫Hello的虚拟终端
screen -S Hello
这个时候,我们按Ctrl+a,再按d,即可保持这个screen到后台并回到主终端:
# 使用screen -r命令
screen -r [pid/name]
其中12880为pid,Hello为name
# 退出终端
exit
或者可以使用ctrl + D
使用screen恢复会话时出现There is no screen to be resumed matching错误解决办法
后来发现是因为突然断网,虽然重新连接,但之前的screen还是处于打开状态(1个screen无法同时打开2次),所以无法重新打开screen,解决方法如下:
2.首先使用screen -d *****(pid),先退出,然后再使用 screen -r *****(pid)重新连接
我来分享一个我在生产环境中遇到的问题,我开screen跑了一个监控脚本,但是监控脚本把mysql的端口3306占用了,我得先把监控脚本停掉,才能重新启动mysql。
里面的脚本ctrl c停不掉,建立的screen ctrl d退不出
只能先ctrl a+d退出,然后kill -9杀掉
这个时候就提示用screen -wipe再清理一下
这样就清理掉了,端口也放开了
再启动数据库就起来了
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。