ssh
предоставляет подключенный поток из локальной системы, на которой выполняется rsync
, в другой экземпляр, запущенный на удаленном сервере. Локальный rsync
запускает его как часть процесса подключения ssh
- это не тот же экземпляр rsync
, который может выполняться как демон на этом удаленном сервере.
Что такое ssh stream ?
ssh stream - это то, что используется при ssh
в удаленной системе. Возможно, вы предпочтете назвать его ssh сеансом . Хорошо. Например, ssh snow@grumpy.example.net
соединит вас с этой удаленной системой и даст вам интерактивный сеанс. Все, что вы ввели локально, будет приниматься и действовать удаленно, и все, что создано удаленно, будет представлено вам локально.
Аналогично, ssh -t snow@doc.example.net vi/etc/hosts
установит соединение для запуска vi/etc/hosts
в удаленной системе, как если бы вы использовали его локально. (Флаг -t
указывает ssh
на то, что удаленная команда vi
выполняется на псевдотерминале; в противном случае он пропустит этот уровень сложности.)
Теперь для rsync
подключение устанавливается локальным экземпляром с помощью чего-то вроде ssh snow@bashful.example.net rsync --server -nlogDtpre.iLsf {local_path} {remote_path}
. Это позволяет локальному rsync
взаимодействовать с удаленным rsync
по соединению так же, как для доступа к тому же удаленному серверу. Удаленный экземпляр rsync
знает, что он является сервером, из-за флагов, которые он был предоставлен при запуске локальным экземпляром.
Вы можете увидеть, как rsync
был вызван удаленно, запустив что-то вроде ssh snow@dopey.example.net 'ps -ef | grep [r] sync'
во время выполнения rsync
.
Почему бы просто не rsync
говорить напрямую без ssh
?
Преимущество использования ssh
в двух случаях
rsync
придется либо реализовать собственное шифрование, либо игнорировать проблему. И то и другое опасно в современном мире, подключенном к Интернету. Host *
IdentityFile ~/.ssh/my_key_rsa.pub
Здесь указан неверный файл ключа. Необходимо указать файл закрытого ключа , а не файл открытого ключа . Файл закрытого ключа имеет расширение .pub
:
Host *
IdentityFile ~/.ssh/my_key_rsa
-121--289883- #!/bin/bash
file=""
max=0
for f in /OEBPS/image/*{png,jpg,jpeg}
do
id=$(identify "$f")
size=$(echo ${id} | sed -r 's/.* (JPEG|PNG) ([0-9]+)x([0-9]+) .*/\2*\3/')
area=$(($size))
if (( area >= max ))
then
max=$area
file="$f"
fi
done
echo $max $file
Определение потребностей ImageMagick .
Ошибка команды sed , если имя файла выглядит слишком близко, как в выходных данных identify .
Как насчет использования systemd. Я немного поискал, и, поскольку systemd заменяет upstart для более новых версий Ubuntu, это может быть полезно. Ссылка ниже может быть полезной.
Digital Ocean :Как настроить службу Linux для автоматического запуска после сбоя или перезагрузки
#!/bin/bash
#I am just like a system daemon...
#I do not need nohup for work, and I should not be called from cron.
#My name is main_safe
#I will become a separeted process even if my father dies...
#i will check if main is still alive, and if dies i will restart it
#nohup is not needed inside shell script.
#IMPORTANT: to die is very different from to freeze
main_safe(){
trap "" HUP
while sleep 120; do
main&
wait
done
}
#My name is main I like to keep restarting php master.php
#everytime it go away... remove wait and I will keep starting master.php with absolutely no reason.
#If you are paranoid you can program me to restart main_safe,
#But what will happen if you try to stop me? Bad things.. so...
#IMPORTANT: to die is very different from to freeze
main(){
trap "" HUP
while sleep 60; do
php master.php &
#do whatever you want here
#uncomment this to prevent two instances of master.php from going up maybe it is necessary:
wait
done
}
#nohup is not needed in shell script
main_safe&
pstree -p | grep $!
Это приемлемо?