Próbowałem użyć uwierzytelniania za pomocą klucza publicznego na nowym serwerze i napotkałem ten problem.
$ ssh -v -i .ssh/server 192.168.1.100
OpenSSH_5.6p1, OpenSSL 0.9.8r 8 Feb 2011
debug1: Reading configuration data .ssh/config
debug1: Applying options for *
debug1: Reading configuration data /etc/ssh_config
debug1: Applying options for *
debug1: Connecting to 192.168.1.100 [192.168.1.100] port 22.
debug1: Connection established.
debug1: identity file .ssh/server type -1
debug1: identity file .ssh/server-cert type -1
debug1: Remote protocol version 2.0, remote software version OpenSSH_5.8p1 Debian-1ubuntu3
debug1: match: OpenSSH_5.8p1 Debian-1ubuntu3 pat OpenSSH*
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_5.6
debug1: SSH2_MSG_KEXINIT sent
debug1: SSH2_MSG_KEXINIT received
debug1: kex: server->client aes128-ctr hmac-md5 none
debug1: kex: client->server aes128-ctr hmac-md5 none
debug1: SSH2_MSG_KEX_DH_GEX_REQUEST(1024<1024<8192) sent
debug1: expecting SSH2_MSG_KEX_DH_GEX_GROUP
debug1: SSH2_MSG_KEX_DH_GEX_INIT sent
debug1: expecting SSH2_MSG_KEX_DH_GEX_REPLY
debug1: Host '192.168.1.100' is known and matches the RSA host key.
debug1: Found key in .ssh/known_hosts:1
debug1: ssh_rsa_verify: signature correct
debug1: SSH2_MSG_NEWKEYS sent
debug1: expecting SSH2_MSG_NEWKEYS
debug1: SSH2_MSG_NEWKEYS received
debug1: Roaming not allowed by server
debug1: SSH2_MSG_SERVICE_REQUEST sent
debug1: SSH2_MSG_SERVICE_ACCEPT received
debug1: Authentications that can continue: publickey,password
debug1: Next authentication method: publickey
debug1: Trying private key: .ssh/server
debug1: read PEM private key done: type RSA
debug1: Authentications that can continue: publickey,password
debug1: Next authentication method: password
a następnie muszę wprowadzić hasło, aby się zalogować.
Ale jeśli mam już jedną sesję podłączoną do tego serwera (który jest połączony hasłem), to następujące połączenie używa uwierzytelniania klucza, aby uniknąć wprowadzania hasła.
Jeśli nie ma już ustanowionego połączenia SSH, nie mogę połączyć się bez hasła wejściowego.
To jest dla mnie naprawdę dziwne, sprawdziłem MD5 /usr/sbin/sshd
między nowym serwerem a innym normalnym serwerem, jest taki sam. Potem właśnie skopiowałem /etc/ssh/sshd_config
inny z normalnego serwera na nowy serwer i uruchomiłem service ssh restart
. Problem nadal istnieje.
Jak mam to naprawić?
Naprawiłem własny przypadek tego błędu usuwając
id_rsa.pub
z .ssh.Skopiowałem
id_rsa
z innej maszyny i rozdzieliłem ją między kilku fałszywych klientów. W związku z tym,id_rsa
iid_rsa.pub
są rzeczywiście różne klucze, co uniemożliwia wykorzystanieid_rsa
całkowicie.Brak komunikatu o błędzie, który wyraźnie to wskazuje. Zrozumiałem to zasadniczo przez przypadek, próbując doprowadzić różne maszyny do identycznego stanu.
źródło
Z mojego odkrycia wynika, że najmniejsze pozwolenie dyrektora macierzystego celu jest
750
. Jeśli świat nie jest0
, nie będzie działać.Na przykład. dla katalogu głównego:
Następne jest
/root/.ssh
Następnie
/root/.ssh/authorized_keys
źródło
W moim przypadku uprawnienia do katalogu domowego były
775
zamiast0755
lub niższe.Cała ścieżka do pliku autoryzowanych_kluczy, tzn.
/home/user/.ssh/
Musi być0755
niższa.źródło
Po wielu kłopotach mam rozwiązanie problemu:
Katalog domowy użytkownika nie powinien mieć uprawnień
777
ani zapisu na całym świecie. W takim przypadku weryfikacja klucza SSH nie powiedzie się i musisz podać hasło do logowania.źródło
Upewnij się tylko, że konto, na które próbujesz ssh, jest użytkownikiem z hasłem na zdalnym serwerze. Właśnie uderzyłem głową w ścianę przez pół godziny, zanim znalazłem tę odpowiedź tutaj: /programming//a/14421105/758174
źródło
Jeśli twoja
/etc/ssh/sshd_config
linia nie skomentowała, to konfiguracja SSH pozwala tylko ssh na ustaloną listę użytkowników w systemie i musisz dodać do niej nowe konta:Każdy inny użytkownik niż wymieniony powyżej, próbujący zalogować się za pośrednictwem SSH, otrzyma te tajemnicze komunikaty o błędach:
źródło
Dowiedziałem się, że po zmianie nazwy użytkownika i grupy (ale nie identyfikatorów)
/etc/passwd
i/etc/group
, ale zapominając o/etc/shadow
odpowiedniej zmianie , otrzymałem ten sam komunikat „Niedozwolony roaming”.źródło