Я написал код ниже для получения листинга с удаленного сервера.
echo "set xfer:log yes" > batchfile.txt
echo "set xfer:log-file Templogfile1.txt">> batchfile.txt
echo "open -p $rport -u $ruser,$rpass sftp://$ripaddress">> batchfile.txt
echo "cache flush">> batchfile.txt
echo "cd $rrdir">> batchfile.txt
echo "pwd">> batchfile.txt
echo "ls -l $srfile">> batchfile.txt
echo "quit">> batchfile.txt
exec 3>&1 4>&2
exec > TempSessionLog.txt 2>&1
set -x
(
lftp -f batchfile.txt >TempLogFile.log <<- EndFTP
EndFTP
)
retval1="$?"
exec 1>&3 2>&4
set +x
Я передал неправильное имя каталога. Стандартный sftp возвращает код ошибки, ($? != 0)
но lftp отправляет (retval1 = 0)
код успешного возврата.
Выше TempSessionLogFile
я вижу сообщение об ошибке cd: Access failed: No such file (<<Directory Path>>)
с успешным возвращаемым значением.
Есть ли способ зафиксировать ошибки в lftp по кодам возврата? Если нет, то какие у меня есть альтернативы?
решение1
Если вы не делаете ничего тонкого с протоколом FTP, что в данном случае не так, то проще всего использовать обычные команды копирования иустанавливатьFTP-сервер в каталог. Вы можете использоватьLftpFS, который являетсяПРЕДОХРАНИТЕЛЬФайловая система, которая использует lftp под капотом. Альтернативы включаютCurlFtpFS. Для SFTP вместо FTP используйтеСШФС.
#!/bin/sh
trap 'fusermount -u mnt; rmdir mnt' EXIT INT TERM HUP
set -e
mkdir mnt
sshpass -p"$rpass" sshfs "$ruser@$ripaddress:/" mnt
cd "mnt/$rrdir"
ls -l "$srfile"