18

У меня установлен Cygwin на Windows 7. Я сделал установку по умолчанию. Я хотел бы использовать конфигурационный файл ssh (~/.ssh/config) для установки хоста и параметров для подключения.

Обычная команда ssh не может найти конфигурацию, когда я пытаюсь подключиться: ssh host Если я явно указываю файл конфигурации, все в порядке: ssh -F ~/.ssh/config

Я не могу найти никакой опции для установки клиента ssh, что-то вроде /etc /ssh

Может быть, ssh не знает, где находится моя домашняя папка? (Я установил переменную среды HOME в мою домашнюю папку)

6 ответов6

17

Сначала вы должны запустить ssh-host-config . Он сгенерирует файл "ssh_config" в /etc/ .

4

Я была такая же проблема. Я хотел использовать ~/.ssh/config, потому что я уже использовал этот каталог для других приложений и не хотел сохранять 2 копии. Поэтому создание каталога /etc/ssh_config не было идеальным решением.

Как упоминает Fujimoto Youichi, ssh ищет в /etc/passwd домашний каталог, а не переменную среды $ HOME .

Текущие версии cygwin (я использую 2.6) больше не создает /etc/passwd как часть установки. Тем не менее, легко создать новый:

    mkpasswd -c -p "$(cygpath -H)" > /etc/passwd
  • -c Добавляет текущего пользователя в файл passwd
  • -p "$(cygpath -H)" Добавляет ваш текущий домашний каталог

https://cygwin.com/cygwin-ug-net/mkpasswd.html содержит более подробную информацию о доступных флагах.

Я не смотрел на код, но кажется, что ssh предпочитает:

  1. / И т.д. / ssh_config
  2. ~ / .Ssh / конфигурации

Поэтому, если вы хотите использовать только информацию о конфигурации ssh из ~/.ssh/config, обязательно удалите /etc/ssh_config.

Также обязательно внесите изменения в новое окно терминала Cygwin после внесения изменений, чтобы они стали доступны.

1

Команда ssh ищет свой конфигурационный файл в домашнем каталоге из /etc /passwd. Поэтому установка переменной HOME не будет работать.

Есть много способов, но мы можем это исправить, просто сделав символическую ссылку следующим образом.

ln -s ~ /home

0

Согласно принятому ответу, используйте команду для инициализации:

ssh-host-config

Вы также можете создать пустой /etc/ssh_config в Cygwin, который будет работать так же.

/etc/ssh_config создаваемый ssh-host-config , также пуст со всеми строками комментариев.


Перезагрузите SSH с новым конфигом:

Чтобы выполнить настройку, вы можете просто закончить редактирование /etc/ssh_config без перезапуска службы.

0

Cygwin ssh ожидает, что конфигурация будет в /home/$USER . Но домашний каталог "~" в cygwin - это C:/Users/$USER , действительно, /home пуст. Вы можете иметь как C:/Users/$USER/.ssh и /home/$USER/.ssh быть действительным путем, путем создания символической ссылки:

ln -s ~ /home/$USER
0

Другие ответы не сработали для меня. Я только что создал c:\cygwin64\etc\ssh_config и вставил его в следующий файл по умолчанию / пример:

# This is the ssh client system-wide configuration file.  See
# ssh_config(5) for more information.  This file provides defaults for
# users, and the values can be changed in per-user configuration files
# or on the command line.

# Configuration data is parsed as follows:
#  1. command line options
#  2. user-specific file
#  3. system-wide file
# Any configuration value is only changed the first time it is set.
# Thus, host-specific definitions should be at the beginning of the
# configuration file, and defaults at the end.

# Site-wide defaults for some commonly used options.  For a comprehensive
# list of available options, their meanings and defaults, please see the
# ssh_config(5) man page.

# Host *
#   ForwardAgent no
#   ForwardX11 no
#   RhostsRSAAuthentication no
#   RSAAuthentication yes
#   PasswordAuthentication yes
#   HostbasedAuthentication no
#   GSSAPIAuthentication no
#   GSSAPIDelegateCredentials no
#   BatchMode no
#   CheckHostIP yes
#   AddressFamily any
#   ConnectTimeout 0
#   StrictHostKeyChecking ask
#   IdentityFile ~/.ssh/identity
#   IdentityFile ~/.ssh/id_rsa
#   IdentityFile ~/.ssh/id_dsa
#   Port 22
#   Protocol 2,1
#   Cipher 3des
#   Ciphers aes128-ctr,aes192-ctr,aes256-ctr,arcfour256,arcfour128,aes128-cbc,3des-cbc
#   MACs hmac-md5,hmac-sha1,umac-64@openssh.com,hmac-ripemd160
#   EscapeChar ~
#   Tunnel no
#   TunnelDevice any:any
#   PermitLocalCommand no
#   VisualHostKey no
#   ProxyCommand ssh -q -W %h:%p gateway.example.com
#
#
Host *
    Port 22

Надеюсь, что поможет следующему человеку.

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .