The OpenNET Project / Index page

[ новости /+++ | форум | теги | ]




Версия для распечатки Пред. тема | След. тема
Новые ответы [ Отслеживать ]
Ввод пароля при помощи Shell скрипта, !*! Jinx, 14-Ноя-11, 17:04  [смотреть все]
Пытаюсь автоматизировать архивирование. На данный момент мне требуется подключаться к удаленным Линуксовым станциям/серверам и забирать оттуда некие файлы. Для этих целей решил использовать SSHFS.
Столкнулся с следующей проблемой - при подключении к удаленной машине требуется вводить пароль пользователя, но как автоматизировать его ввод я понять не могу.

Скажу заранее - авторизацию по ключах сделать не могу по нескольких причинах, которые называть не вижу смысла.

Итак, подключаюсь так:


sshfs root@192.168.1.1:/usr/ /mountpoint

После чего получаю:

root@192.168.1.1's password:

Куда и нужно скриптом ввести пароль.

Возможно-ли такое сделать?

  • Ввод пароля при помощи Shell скрипта, !*! DeadLoco, 17:34 , 14-Ноя-11 (1)

    cat "MyVeryStrongPass" | sshfs root@192.168.1.1:/usr/ /mountpoint

    • Ввод пароля при помощи Shell скрипта, !*! Jinx, 17:51 , 14-Ноя-11 (2)
      > cat "MyVeryStrongPass" | sshfs root@192.168.1.1:/usr/ /mountpoint

      Я что-то совсем не понял суть этого действия. cat это читалка файлов, как с его помощью ввести пароль?

      • Ввод пароля при помощи Shell скрипта, !*! DeadLoco, 17:59 , 14-Ноя-11 (3)
        > Я что-то совсем не понял суть этого действия. cat это читалка файлов,
        > как с его помощью ввести пароль?

        Кат - далеко не только читалка файлов. Кат - это выводитель в стдаут чего-нибудь. Если что-нибудь - путь к файлу, то выведется содержимое файла. А если что-нибудь - строка, то в стдаут выведется эта строка. Затем мы через перенаправление загоняем эту строку на стдин другой команды. Вуаля.

        Нетривиальное использование ката:

        # cat > /path/to/the/file.txt <ENTER>
        <CTRL-D>
        #

        Выводим "ничего" в файл. Если кат запустить без аргументов, то он ждет ввода строк или путей с стдина. Если стдин сразу закрыть по КТРЛ-Д, то кат не выведет ничего. Но перед этим он через > обнулит файл вывода. Таким образом удобно чистить длинные логи, которые нежелательно удалять/создавать заново (обычный источник гемора с апачем).

  • Ввод пароля при помощи Shell скрипта, !*! Square, 18:41 , 14-Ноя-11 (8)
    > Возможно-ли такое сделать?

    echo 'password' | sshfs user@remote.host:/somedir /somemydir -o password_stdin

  • Ввод пароля при помощи Shell скрипта, !*! elvenic, 19:41 , 14-Ноя-11 (9)

    > Столкнулся с следующей проблемой - при подключении к удаленной машине требуется вводить
    > пароль пользователя, но как автоматизировать его ввод я понять не могу.

    А вообще-то такие вещи делаются через expect (http://linux.die.net/man/1/expect)

  • Ввод пароля при помощи Shell скрипта, !*! Jinx, 15:36 , 15-Ноя-11 (14)
    Вот он - новый рабочий день. продолжаем мозговой штурм...


    > Ну, попробуйте в скрипте сделать так:

    С cat так и не свершилось - у меня постоянно требует пароль, и не важно каким-бы способом я не пытался.


    > echo 'password' | sshfs user@remote.host:/somedir /somemydir -o password_stdin

    Решение то вроди и рабочее, но вот только у меня не прокатило, при попытке подключения пишет следующее:


    remote host has disconnected

    При включении режима отладки получаю следующее:


    debug1: Authentications that can continue: publickey,password,keyboard-interactive
    debug1: Next authentication method: password
    debug1: read_passphrase: can't open /dev/tty: Device not configured
    debug1: Authentications that can continue: publickey,password,keyboard-interactive
    debug1: Next authentication method: keyboard-interactive
    debug1: Authentications that can continue: publickey,password,keyboard-interactive
    debug1: No more authentication methods to try.
    Permission denied (publickey,password,keyboard-interactive).
    remote host has disconnected

    Такое впечатление что пытается использовать ключи, которых нет, после чего пытается использовать пароль, но в итоге ругается что не настроено... Вообще странно, но похоже проблема на стороне машины, к которой подключаюсь.


    > Если девушка-оператор-с-бюстом-не-меньше-6 знает как писать скрипты на баше с expect для
    > ввода пароля, я думаю это будет только приветствоваться :)

    Если девушка-оператор-с-бюстом-не-меньше-6, то мне наверное не до шелла было-бы :)


    > Попробуй утилитку sshpass http://sourceforge.net/projects/sshpass/

    Как я понял для FreeBSD такого нет, толи так глючно работает что лучше считать что его нет.


    > ...ssh-agent и аутентификацию по ключу https://www.opennet.ru/tips/1763_ssh_cache_password.shtml
    > , второй вариант - с ControlMaster там тоже описан.

    М? А как на счет этого?

    > Скажу заранее - авторизацию по ключах сделать не могу по нескольких причинах,
    > которые называть не вижу смысла.

    Почему? Да много вариантов - например религия не позволяет, или я хочу делать бейкапы сайта, к котором доступ по ssh есть, но хостер услугу авторизации по ключах не предоставляет, или, или, или...
    Я-же сразу написал что такой вариант не проходит.


    > А вообще-то такие вещи делаются через expect (http://linux.die.net/man/1/expect)

    Признаюсь честно - не знал о существовании expect, и при этом что-то подобное искал уже довольно давно. Спасибо.


    Итак, спустя каких-то 5 часов мозгового штурма решение все таки было найдено. Сделал все через expect.
    Вот он, мой чудный скрипт:


    #!/usr/local/bin/expect

    spawn -ignore HUP /usr/local/bin/sshfs root@192.168.1.1:/usr/ /mountpoint
    expect "*assword*"
    send "SuperPass\r"
    expect "\n"


    При чем без "-ignore HUP" в системе творятся вообще странные вещи - после выполнения скрипта диск вроди и подмонтировался, но df диск не видит, а при попытке или открыть точку монтирования, или считать содержимое или отмонтировать, терминал наглухо вис. Больше часа головой об эту проблему бился, но как говорится "Если долго мучится, то что нибудь получится", в итоге история все-же закончилась хеппи ендом.

    Скрипт вроди работает нормально, проблем пока не замечено. Всем спасибо за помощь!

    • Ввод пароля при помощи Shell скрипта, !*! GTAlex.ru, 13:04 , 12-Фев-13 (16)
      >[оверквотинг удален]
      > send "SuperPass\r"
      > expect "\n"
      >

      > При чем без "-ignore HUP" в системе творятся вообще странные вещи -
      > после выполнения скрипта диск вроди и подмонтировался, но df диск не
      > видит, а при попытке или открыть точку монтирования, или считать содержимое
      > или отмонтировать, терминал наглухо вис. Больше часа головой об эту проблему
      > бился, но как говорится "Если долго мучится, то что нибудь получится",
      > в итоге история все-же закончилась хеппи ендом.
      > Скрипт вроди работает нормально, проблем пока не замечено. Всем спасибо за помощь!

      ТЫ ГЕНИЙ!
      СПАСИБО ОГРОМНОЕ!!!

  • Ввод пароля при помощи Shell скрипта, !*! blackpepper, 08:21 , 17-Ноя-11 (15)
    > Пытаюсь автоматизировать архивирование. На данный момент мне требуется подключаться к
    > удаленным Линуксовым станциям/серверам и забирать оттуда некие файлы. Для этих целей
    > решил использовать SSHFS.
    > Столкнулся с следующей проблемой - при подключении к удаленной машине требуется вводить
    > пароль пользователя, но как автоматизировать его ввод я понять не могу.
    > Скажу заранее - авторизацию по ключах сделать не могу по нескольких причинах,
    > которые называть не вижу смысла.
    > Итак, подключаюсь так:
    >
     
    > sshfs root@192.168.1.1:/usr/ /mountpoint

    а так проходит? sshfs root:пароль@192.168.1.1:/usr/ /mountpoint
    >


    > После чего получаю:
    >
     
    > root@192.168.1.1's password:
    >

    > Куда и нужно скриптом ввести пароль.
    > Возможно-ли такое сделать?



Партнёры:
PostgresPro
Inferno Solutions
Hosting by Hoster.ru
Хостинг:

Закладки на сайте
Проследить за страницей
Created 1996-2024 by Maxim Chirkov
Добавить, Поддержать, Вебмастеру