Лучшие ответы привели к ошибке в моем коде, когда в первом месяце он установил будущую дату в текущем месяце. Вот что я сделал,
curDate = new Date(); // Took current date as an example
prvDate = new Date(0); // Date set to epoch 0
prvDate.setUTCMilliseconds((curDate - (5 * 24 * 60 * 60 * 1000))); //Set epoch time
Используйте следующий, ssc
, вместо ssh
. Если вы просто наберете « ssc remote.com
», он отобразит список существующих сеансов экрана. Дайте ему третий аргумент, и он подключится к этому сеансу экрана или создаст его и подключится к нему. В любом случае, если вы отключились, вы можете просто выполнить «стрелку вверх, войти» в оболочке для повторного подключения. Требуется нулевое знание экрана!
Изменить: спасибо @klochner за расширение этого для обработки произвольных параметров ssh. Теперь вы можете использовать это так же, как ssh!
#!/usr/bin/env perl
# Use 'ssc' (this script) instead of 'ssh' to log into a remote machine.
# Without an argument after the hostname it will list available screens.
# Add an argument after the hostname to attach to an existing screen, or
# specify a new screen. Eg, ssc remote.com foo
# The numbers in front of the screen tag can usually be ignored.
# ssh option parsing by @klochner
my $optstring = "";
while ($val = shift) {
if ($val =~ /^-\w$/) { $optstring .= " ".$val.(shift); }
elsif ($val =~ /^-\w+$/) { $optstring .= " ".$val; }
elsif ($machine) { $tag = $val; }
else { $machine = $val; }
}
if (!$machine) {
print "USAGE: ssc [ssh options] remote.com [screen name]\n";
} elsif (!$tag) {
@screens = split("\n", `ssh $optstring $machine screen -ls`);
for(@screens) {
if(/^\s*(\d+)\.(\S+)\s+\(([^\)]*)\)/) {
($num, $tag, $status) = ($1, $2, $3);
if($status =~ /attached/i) { $att{"$num.$tag"} = 1; }
elsif($status =~ /detached/i) { $att{"$num.$tag"} = 0; }
else { print "Couldn't parse this: $_\n"; }
# remember anything weird about the screen, like shared screens
if($status =~ /^(attached|detached)$/i) {
$special{"$num.$tag"} = "";
} else {
$special{"$num.$tag"} = "[$status]";
}
}
}
print "ATTACHED:\n";
for(sort { ($a=~/\.(\w+)/)[0] cmp ($b=~/\.(\w+)/)[0] } keys(%att)) {
($tag) = /\.(\w+)/;
print " $tag\t($_)\t$special{$_}\n" if $att{$_};
}
print "DETACHED:\n";
for(sort { ($a=~/\.(\w+)/)[0] cmp ($b=~/\.(\w+)/)[0] } keys(%att)) {
($tag) = /\.(\w+)/;
print " $tag\t($_)\t$special{$_}\n" unless $att{$_};
}
} else {
system("ssh $optstring -t $machine \"screen -S $tag -dr || screen -S $tag\"");
}
Кстати, есть уловка, заставляющая сеанс ssh завершиться и возвращать подсказку локального терминала при потере сетевого подключения:
https://superuser.com/questions / 147873 / ssh-sessions-in-xterms-freeze-for-many-minutes-when-they-disconnect
Зависит от вашей оболочки, но как насчет .bashrc? (Если вы используете bash "screen -rd")
У меня есть следующее в моем .bashrc
if [ "$PS1" != "" -a "${_STARTED_SCREEN:-x}" = x -a "${SSH_TTY:-x}" ]
then
export _STARTED_SCREEN=1;
sleep 1
screen -RR && exit 0
# normally, execution of this rc script ends here...
echo "Screen failed! continuing with normal bash startup"
fi
Я нашел его где-то в Интернете некоторое время назад, не знаю где.
Обновление Исправлена ошибка, указанная в комментариях. Спасибо Р. Пэйт
Фактически screen устанавливает для переменной TERM значение screen. Так что сценарий еще проще. Вот что я использую:
if [ "$TERM" != "screen" ]; then
screen -xRR
fi
Работает как шарм, -x
гарантирует, что даже если экран прикреплен где-то еще, я прикреплю его сюда. Таким образом, у меня будет только один экран, на котором я могу все отслеживать.
есть autossh
, который автоматически повторно подключает отключенные ssh-сессии.
Он поставляется с примером скрипта под названием rscreen
, который делает именно это. Это просто:
#!/bin/sh
autossh -M 0 -t $1 "screen -e^Aa -D -R"
Затем вам нужно переучить пальцы набирать rscreen hostname
вместо ssh hostname