git - password - SSH Key pide contraseña
password git (4)
Me quedé aquí por 2 días a la semana.
Tengo una máquina CentOs con Gitlab4 y gitolite. Todo funcionó bien durante semanas, pero repentinamente, el fin de semana pasado, algo extraño sucedió, todas las binarias desaparecieron de la mashine (como ñam, pitón, rubí, mysql ect.) Realmente no tengo ni idea de cómo puede suceder ... Después de horas de reinstalación y La compilación de gitlab estaba funcionando de nuevo.
Pero no puedo obtener las claves ssh entre el gitlab y el usuario git trabajando. Ya eliminé y recreé el usuario de git, configuré nuevamente todos los permisos, recreé las claves ssh, reinstalé gitolite ect. Pero nada funcionó, sigo recibiendo el mismo error.
carpeta .ssh del usuario git
-rwx------ 1 git git 557 Mar 27 16:46 authorized_keys
carpeta .ssh del usuario gitlab
-rw------- 1 gitlab gitlab 1671 Mar 27 16:45 id_rsa
-rw-r--r-- 1 gitlab gitlab 406 Mar 27 16:45 id_rsa.pub
-rw-r--r-- 1 gitlab gitlab 391 Mar 27 16:50 known_hosts
Error SSH:
ssh -vvvT git@localhost
OpenSSH_4.3p2, OpenSSL 0.9.8e-fips-rhel5 01 Jul 2008
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: Applying options for *
debug2: ssh_connect: needpriv 0
debug1: Connecting to localhost [127.0.0.1] port 22.
debug1: Connection established.
debug1: identity file /home/gitlab/.ssh/identity type -1
debug3: Not a RSA1 key file /home/gitlab/.ssh/id_rsa.
debug2: key_type_from_name: unknown key type ''-----BEGIN''
debug3: key_read: missing keytype
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug3: key_read: missing whitespace
debug2: key_type_from_name: unknown key type ''-----END''
debug3: key_read: missing keytype
debug1: identity file /home/gitlab/.ssh/id_rsa type 1
debug1: identity file /home/gitlab/.ssh/id_dsa type -1
debug1: Remote protocol version 2.0, remote software version OpenSSH_4.3p2
debug1: match: OpenSSH_4.3p2 pat OpenSSH*
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_4.3p2
debug1: SSH2_MSG_KEXINIT sent
debug1: SSH2_MSG_KEXINIT received
debug2: kex_parse_kexinit: diffie-hellman-group-exchange-sha1,diffie-hellman-group1-sha1
debug2: kex_parse_kexinit: ssh-rsa,ssh-dss
debug2: kex_parse_kexinit: aes128-cbc,3des-cbc,blowfish-cbc,cast128-cbc,arcfour,aes192-cbc,aes256-cbc,[email protected],aes128-ctr,aes192-ctr,aes256-ctr
debug2: kex_parse_kexinit: aes128-cbc,3des-cbc,blowfish-cbc,cast128-cbc,arcfour,aes192-cbc,aes256-cbc,[email protected],aes128-ctr,aes192-ctr,aes256-ctr
debug2: kex_parse_kexinit: hmac-md5,hmac-sha1,hmac-ripemd160,[email protected],hmac-sha1-96,hmac-md5-96
debug2: kex_parse_kexinit: hmac-md5,hmac-sha1,hmac-ripemd160,[email protected],hmac-sha1-96,hmac-md5-96
debug2: kex_parse_kexinit: none,zlib
debug2: kex_parse_kexinit: none,zlib
debug2: kex_parse_kexinit:
debug2: kex_parse_kexinit:
debug2: kex_parse_kexinit: first_kex_follows 0
debug2: kex_parse_kexinit: reserved 0
debug2: kex_parse_kexinit: diffie-hellman-group-exchange-sha1,diffie-hellman-group1-sha1
debug2: kex_parse_kexinit: ssh-rsa,ssh-dss
debug2: kex_parse_kexinit: aes128-cbc,3des-cbc,blowfish-cbc,cast128-cbc,arcfour,aes192-cbc,aes256-cbc,[email protected],aes128-ctr,aes192-ctr,aes256-ctr
debug2: kex_parse_kexinit: aes128-cbc,3des-cbc,blowfish-cbc,cast128-cbc,arcfour,aes192-cbc,aes256-cbc,[email protected],aes128-ctr,aes192-ctr,aes256-ctr
debug2: kex_parse_kexinit: hmac-md5,hmac-sha1,hmac-ripemd160,[email protected],hmac-sha1-96,hmac-md5-96
debug2: kex_parse_kexinit: hmac-md5,hmac-sha1,hmac-ripemd160,[email protected],hmac-sha1-96,hmac-md5-96
debug2: kex_parse_kexinit: none,zlib
debug2: kex_parse_kexinit: none,zlib
debug2: kex_parse_kexinit:
debug2: kex_parse_kexinit:
debug2: kex_parse_kexinit: first_kex_follows 0
debug2: kex_parse_kexinit: reserved 0
debug2: mac_init: found hmac-md5
debug1: kex: server->client aes128-cbc hmac-md5 none
debug2: mac_init: found hmac-md5
debug1: kex: client->server aes128-cbc hmac-md5 none
debug1: SSH2_MSG_KEX_DH_GEX_REQUEST(1024<1024<8192) sent
debug1: expecting SSH2_MSG_KEX_DH_GEX_GROUP
debug2: dh_gen_key: priv key bits set: 132/256
debug2: bits set: 502/1024
debug1: SSH2_MSG_KEX_DH_GEX_INIT sent
debug1: expecting SSH2_MSG_KEX_DH_GEX_REPLY
debug3: check_host_in_hostfile: filename /home/gitlab/.ssh/known_hosts
debug3: check_host_in_hostfile: match line 1
debug1: Host ''localhost'' is known and matches the RSA host key.
debug1: Found key in /home/gitlab/.ssh/known_hosts:1
debug2: bits set: 505/1024
debug1: ssh_rsa_verify: signature correct
debug2: kex_derive_keys
debug2: set_newkeys: mode 1
debug1: SSH2_MSG_NEWKEYS sent
debug1: expecting SSH2_MSG_NEWKEYS
debug2: set_newkeys: mode 0
debug1: SSH2_MSG_NEWKEYS received
debug1: SSH2_MSG_SERVICE_REQUEST sent
debug2: service_accept: ssh-userauth
debug1: SSH2_MSG_SERVICE_ACCEPT received
debug2: key: /home/gitlab/.ssh/identity ((nil))
debug2: key: /home/gitlab/.ssh/id_rsa (0x848ba50)
debug2: key: /home/gitlab/.ssh/id_dsa ((nil))
debug1: Authentications that can continue: publickey,password
debug3: start over, passed a different list publickey,password
debug3: preferred publickey,keyboard-interactive,password
debug3: authmethod_lookup publickey
debug3: remaining preferred: keyboard-interactive,password
debug3: authmethod_is_enabled publickey
debug1: Next authentication method: publickey
debug1: Trying private key: /home/gitlab/.ssh/identity
debug3: no such identity: /home/gitlab/.ssh/identity
debug1: Offering public key: /home/gitlab/.ssh/id_rsa
debug3: send_pubkey_test
debug2: we sent a publickey packet, wait for reply
debug1: Authentications that can continue: publickey,password
debug1: Trying private key: /home/gitlab/.ssh/id_dsa
debug3: no such identity: /home/gitlab/.ssh/id_dsa
debug2: we did not send a packet, disable method
debug3: authmethod_lookup password
debug3: remaining preferred: ,password
debug3: authmethod_is_enabled password
debug1: Next authentication method: password
El registro de autenticación me da:
Apr 2 10:19:13 venus sshd[15693]: User git not allowed because account is locked
Apr 2 10:19:13 venus sshd[15693]: Failed none for illegal user git from ::ffff:127.0.0.1 port 56906 ssh2
Gracias por cualquier ayuda.
Aunque la respuesta aceptada puede funcionar, puede que no sea la manera preferida de hacerlo.
Al menos en Ubuntu 12.04, passwd -u git
dará como resultado esta advertencia:
passwd: unlocking the password would result in a passwordless account.
You should set a password with usermod -p to unlock the password of this account.
Suena bien ... excepto que la página de manual de usermod
advierte contra el uso de la opción -p
.
Note: This option is not recommended because the password (or encrypted password)
will be visible by users listing the processes.
En lugar de todo eso, llamar a passwd -d gitlab
hará el truco al eliminar la contraseña del usuario (establece ese campo de contraseña en una cadena vacía).
Este mismo problema exacto me estaba matando en gitlab 5.2 (bitnami).
Finalmente lo /var/log/auth.log
en /var/log/auth.log
que mostraba:
May 28 11:32:10 ml115 sshd[27779]: User git not allowed because account is locked
May 28 11:32:10 ml115 sshd[27779]: input_userauth_request: invalid user git [preauth]
Después de eso, no tardé en descubrir que la entrada de git
en /etc/shadow
tenía un !
que necesitaba ser reemplazado con un *
.
Con *
y todas mis claves configuradas, pude ssh desde otra máquina (tenga en cuenta que ssh -vvT git@gitserver
también ayuda con el diagnóstico).
git push -u origin master
ahora trabaja.
Mi sistema es Ubuntu 13.04.
Mencionas:
Apr 2 10:19:13 venus shd[15693]: User git not allowed because account is locked
Apr 2 10:19:13 venus sshd[15693]: Failed none for illegal user git from ::ffff:127.0.0.1 port 56906 ssh2
Este artículo menciona:
OpenSSH ahora comprueba las cuentas bloqueadas por defecto.
En los sistemas Linux, las cuentas bloqueadas se definen como aquellas que tienen!!
en el campo de contraseña de/etc/shadow
.
Esta es la entrada predeterminada para las cuentas creadas con el comando useradd .
Incluso si está utilizando la autenticación GSI y no necesita contraseñas locales,sshd
no permitirá que el usuario inicie sesión con este mensaje:
Too many authentication failures for username
En la información de depuración
sshd
indicará que la cuenta está bloqueada:
User username not allowed because account is locked
Aquí hay alguna información adicional del manual sshd:
Independientemente del tipo de autenticación, la cuenta se verifica para garantizar que sea accesible.
No se puede acceder a una cuenta si está bloqueada, listada en DenyUsers o su grupo aparece en DenyGroups.
La definición de una cuenta bloqueada depende del sistema.
Algunas plataformas tienen su propia base de datos de cuenta (por ejemplo, AIX) y algunas modifican el campo de contraseña ("*LK*
" en Solaris y UnixWare, "*
" en HP-UX, que contiene "Nologin
" en Tru64, uno de los principales "*LOCKED*
" en FreeBSD y un líder "!!
" en Linux).
Si hay un requisito para deshabilitar la autenticación de contraseña para la cuenta mientras se permite una clave pública, el campo de contraseña debe configurarse en un valor diferente a estos valores (por ejemplo, "NP
" o "*NP*
").Arreglo: ¡Reemplaza! con (por ejemplo) NP en / etc / shadow.
Como lo mencionaron jszakmeister ( comments ) y Yongcan-Frank-Lv ( comments ):
sudo passwd -u git
Sería suficiente para desbloquear la cuenta .
debe poner ~ gitlab / .ssh / id_rsa.pub en ~ git / .ssh / authorized_keys
-rwx ------ 1 git git 557 27 de marzo 16:46 authorized_keys
-rw-r - r-- 1 gitlab gitlab 406 27 de marzo 16:45 id_rsa.pub
Puedo ver que el tamaño no coincide, ¿agregó alguna opción de clave ssh allí en authorized_keys? También debe verificar el registro de errores de sshd también (por ejemplo: / var / log / auth o / var / log / secure, etc.)