【问题标题】:GitLab cloning via SSH always prompts for passwordGitLab 通过 SSH 克隆总是提示输入密码
【发布时间】:2019-03-07 08:50:48
【问题描述】:

我已经按照指南在我自己的本地机器上设置 ssh 密钥对(我计划从 GitLab 克隆我的源代码)。但是,每次我执行git clone git@mygitlab-ce.locadomain.com 时,总是提示我输入密码。

我希望不输入任何内容并自动克隆我的源代码。因为我将ssh-keygen 命令设置为没有密码。

我在 GitLab 指南中阅读了一些解决方法和调试方法。到目前为止没有任何效果。我想请你们中的任何人看看它。请参阅ssh -Tv git@mygitlab-ce.locadomain.com 上的示例 -v 日志

[root@localhost ~]# ssh -Tvvv git@mygitlab-ce.locadomain.com
OpenSSH_7.4p1, OpenSSL 1.0.2k-fips  26 Jan 2017
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: /etc/ssh/ssh_config line 58: Applying options for *
debug2: resolving "mygitlab-ce.locadomain.com" port 22
debug2: ssh_connect_direct: needpriv 0
debug1: Connecting to mygitlab-ce.locadomain.com [192.168.0.135] port 22.
debug1: Connection established.
debug1: permanently_set_uid: 0/0
debug1: identity file /root/.ssh/id_rsa type 1
debug1: key_load_public: No such file or directory
debug1: identity file /root/.ssh/id_rsa-cert type -1
debug1: key_load_public: No such file or directory
debug1: identity file /root/.ssh/id_dsa type -1
debug1: key_load_public: No such file or directory
debug1: identity file /root/.ssh/id_dsa-cert type -1
debug1: key_load_public: No such file or directory
debug1: identity file /root/.ssh/id_ecdsa type -1
debug1: key_load_public: No such file or directory
debug1: identity file /root/.ssh/id_ecdsa-cert type -1
debug1: key_load_public: No such file or directory
debug1: identity file /root/.ssh/id_ed25519 type -1
debug1: key_load_public: No such file or directory
debug1: identity file /root/.ssh/id_ed25519-cert type -1
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_7.4
debug1: Remote protocol version 2.0, remote software version OpenSSH_7.4
debug1: match: OpenSSH_7.4 pat OpenSSH* compat 0x04000000
debug2: fd 3 setting O_NONBLOCK
debug1: Authenticating to mygitlab-ce.locadomain.com:22 as 'git'
debug3: hostkeys_foreach: reading file "/root/.ssh/known_hosts"
debug3: record_hostkey: found key type ECDSA in file /root/.ssh/known_hosts:1
debug3: load_hostkeys: loaded 1 keys from mygitlab-ce.locadomain.com
debug3: order_hostkeyalgs: prefer hostkeyalgs: ecdsa-sha2-nistp256-cert-v01@openssh.com,ecdsa-sha2-nistp384-cert-v01@openssh.com,ecdsa-sha2-nistp521-cert-v01@openssh.com,ecdsa-sha2-nistp256,ecdsa-sha2-nistp384,ecdsa-sha2-nistp521
debug3: send packet: type 20
debug1: SSH2_MSG_KEXINIT sent
debug3: receive packet: type 20
debug1: SSH2_MSG_KEXINIT received
debug2: local client KEXINIT proposal
debug2: KEX algorithms: curve25519-sha256,curve25519-sha256@libssh.org,ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521,diffie-hellman-group-exchange-sha256,diffie-hellman-group16-sha512,diffie-hellman-group18-sha512,diffie-hellman-group-exchange-sha1,diffie-hellman-group14-sha256,diffie-hellman-group14-sha1,diffie-hellman-group1-sha1,ext-info-c
debug2: host key algorithms: ecdsa-sha2-nistp256-cert-v01@openssh.com,ecdsa-sha2-nistp384-cert-v01@openssh.com,ecdsa-sha2-nistp521-cert-v01@openssh.com,ecdsa-sha2-nistp256,ecdsa-sha2-nistp384,ecdsa-sha2-nistp521,ssh-ed25519-cert-v01@openssh.com,ssh-rsa-cert-v01@openssh.com,ssh-dss-cert-v01@openssh.com,ssh-ed25519,rsa-sha2-512,rsa-sha2-256,ssh-rsa,ssh-dss
debug2: ciphers ctos: chacha20-poly1305@openssh.com,aes128-ctr,aes192-ctr,aes256-ctr,aes128-gcm@openssh.com,aes256-gcm@openssh.com,aes128-cbc,aes192-cbc,aes256-cbc
debug2: ciphers stoc: chacha20-poly1305@openssh.com,aes128-ctr,aes192-ctr,aes256-ctr,aes128-gcm@openssh.com,aes256-gcm@openssh.com,aes128-cbc,aes192-cbc,aes256-cbc
debug2: MACs ctos: umac-64-etm@openssh.com,umac-128-etm@openssh.com,hmac-sha2-256-etm@openssh.com,hmac-sha2-512-etm@openssh.com,hmac-sha1-etm@openssh.com,umac-64@openssh.com,umac-128@openssh.com,hmac-sha2-256,hmac-sha2-512,hmac-sha1
debug2: MACs stoc: umac-64-etm@openssh.com,umac-128-etm@openssh.com,hmac-sha2-256-etm@openssh.com,hmac-sha2-512-etm@openssh.com,hmac-sha1-etm@openssh.com,umac-64@openssh.com,umac-128@openssh.com,hmac-sha2-256,hmac-sha2-512,hmac-sha1
debug2: compression ctos: none,zlib@openssh.com,zlib
debug2: compression stoc: none,zlib@openssh.com,zlib
debug2: languages ctos:
debug2: languages stoc:
debug2: first_kex_follows 0
debug2: reserved 0
debug2: peer server KEXINIT proposal
debug2: KEX algorithms: curve25519-sha256,curve25519-sha256@libssh.org,ecdh-sha2-nistp256,ecdh-sha2-nistp384,ecdh-sha2-nistp521,diffie-hellman-group-exchange-sha256,diffie-hellman-group16-sha512,diffie-hellman-group18-sha512,diffie-hellman-group-exchange-sha1,diffie-hellman-group14-sha256,diffie-hellman-group14-sha1,diffie-hellman-group1-sha1
debug2: host key algorithms: ssh-rsa,rsa-sha2-512,rsa-sha2-256,ecdsa-sha2-nistp256,ssh-ed25519
debug2: ciphers ctos: chacha20-poly1305@openssh.com,aes128-ctr,aes192-ctr,aes256-ctr,aes128-gcm@openssh.com,aes256-gcm@openssh.com,aes128-cbc,aes192-cbc,aes256-cbc,blowfish-cbc,cast128-cbc,3des-cbc
debug2: ciphers stoc: chacha20-poly1305@openssh.com,aes128-ctr,aes192-ctr,aes256-ctr,aes128-gcm@openssh.com,aes256-gcm@openssh.com,aes128-cbc,aes192-cbc,aes256-cbc,blowfish-cbc,cast128-cbc,3des-cbc
debug2: MACs ctos: umac-64-etm@openssh.com,umac-128-etm@openssh.com,hmac-sha2-256-etm@openssh.com,hmac-sha2-512-etm@openssh.com,hmac-sha1-etm@openssh.com,umac-64@openssh.com,umac-128@openssh.com,hmac-sha2-256,hmac-sha2-512,hmac-sha1
debug2: MACs stoc: umac-64-etm@openssh.com,umac-128-etm@openssh.com,hmac-sha2-256-etm@openssh.com,hmac-sha2-512-etm@openssh.com,hmac-sha1-etm@openssh.com,umac-64@openssh.com,umac-128@openssh.com,hmac-sha2-256,hmac-sha2-512,hmac-sha1
debug2: compression ctos: none,zlib@openssh.com
debug2: compression stoc: none,zlib@openssh.com
debug2: languages ctos:
debug2: languages stoc:
debug2: first_kex_follows 0
debug2: reserved 0
debug1: kex: algorithm: curve25519-sha256
debug1: kex: host key algorithm: ecdsa-sha2-nistp256
debug1: kex: server->client cipher: chacha20-poly1305@openssh.com MAC: <implicit> compression: none
debug1: kex: client->server cipher: chacha20-poly1305@openssh.com MAC: <implicit> compression: none
debug1: kex: curve25519-sha256 need=64 dh_need=64
debug1: kex: curve25519-sha256 need=64 dh_need=64
debug3: send packet: type 30
debug1: expecting SSH2_MSG_KEX_ECDH_REPLY
debug3: receive packet: type 31
debug1: Server host key: ecdsa-sha2-nistp256 SHA256:zCtfepU7IAyTrf2GzZjN/MXrHjSC1mFmVhBQqmgQ8B8
debug3: hostkeys_foreach: reading file "/root/.ssh/known_hosts"
debug3: record_hostkey: found key type ECDSA in file /root/.ssh/known_hosts:1
debug3: load_hostkeys: loaded 1 keys from mygitlab-ce.locadomain.com
debug3: hostkeys_foreach: reading file "/root/.ssh/known_hosts"
debug3: record_hostkey: found key type ECDSA in file /root/.ssh/known_hosts:1
debug3: load_hostkeys: loaded 1 keys from 192.168.0.135
debug1: Host 'mygitlab-ce.locadomain.com' is known and matches the ECDSA host key.
debug1: Found key in /root/.ssh/known_hosts:1
debug3: send packet: type 21
debug2: set_newkeys: mode 1
debug1: rekey after 134217728 blocks
debug1: SSH2_MSG_NEWKEYS sent
debug1: expecting SSH2_MSG_NEWKEYS
debug3: receive packet: type 21
debug1: SSH2_MSG_NEWKEYS received
debug2: set_newkeys: mode 0
debug1: rekey after 134217728 blocks
debug2: key: /root/.ssh/id_rsa (0x55f8a93bc520), agent
debug2: key: /root/.ssh/id_dsa ((nil))
debug2: key: /root/.ssh/id_ecdsa ((nil))
debug2: key: /root/.ssh/id_ed25519 ((nil))
debug3: send packet: type 5
debug3: receive packet: type 7
debug1: SSH2_MSG_EXT_INFO received
debug1: kex_input_ext_info: server-sig-algs=<rsa-sha2-256,rsa-sha2-512>
debug3: receive packet: type 6
debug2: service_accept: ssh-userauth
debug1: SSH2_MSG_SERVICE_ACCEPT received
debug3: send packet: type 50
debug3: receive packet: type 51
debug1: Authentications that can continue: publickey,gssapi-keyex,gssapi-with-mic,password
debug3: start over, passed a different list publickey,gssapi-keyex,gssapi-with-mic,password
debug3: preferred gssapi-keyex,gssapi-with-mic,publickey,keyboard-interactive,password
debug3: authmethod_lookup gssapi-keyex
debug3: remaining preferred: gssapi-with-mic,publickey,keyboard-interactive,password
debug3: authmethod_is_enabled gssapi-keyex
debug1: Next authentication method: gssapi-keyex
debug1: No valid Key exchange context
debug2: we did not send a packet, disable method
debug3: authmethod_lookup gssapi-with-mic
debug3: remaining preferred: publickey,keyboard-interactive,password
debug3: authmethod_is_enabled gssapi-with-mic
debug1: Next authentication method: gssapi-with-mic
debug1: Unspecified GSS failure.  Minor code may provide more information
No Kerberos credentials available (default cache: KEYRING:persistent:0)

debug1: Unspecified GSS failure.  Minor code may provide more information
No Kerberos credentials available (default cache: KEYRING:persistent:0)

debug2: we did not send a packet, disable method
debug3: authmethod_lookup publickey
debug3: remaining preferred: keyboard-interactive,password
debug3: authmethod_is_enabled publickey
debug1: Next authentication method: publickey
debug1: Offering RSA public key: /root/.ssh/id_rsa
debug3: send_pubkey_test
debug3: send packet: type 50
debug2: we sent a publickey packet, wait for reply
debug3: receive packet: type 51
debug1: Authentications that can continue: publickey,gssapi-keyex,gssapi-with-mic,password
debug1: Trying private key: /root/.ssh/id_dsa
debug3: no such identity: /root/.ssh/id_dsa: No such file or directory
debug1: Trying private key: /root/.ssh/id_ecdsa
debug3: no such identity: /root/.ssh/id_ecdsa: No such file or directory
debug1: Trying private key: /root/.ssh/id_ed25519
debug3: no such identity: /root/.ssh/id_ed25519: No such file or directory
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
git@mygitlab-ce.locadomain.com's password:

这部分没看懂

debug1:下一个认证方法:publickey

debug1:提供 RSA 公钥:/root/.ssh/id_rsa

debug1:可以>继续的身份验证:publickey,gssapi-keyex,gssapi-with-mic,password

[root@localhost ~]# ls -alh ~/.ssh/
total 16K
drwx------.  2 root root   57 Oct  2 04:26 .
dr-xr-x---. 23 root root 4.0K Oct  2 04:26 ..
-rw-------.  1 root root 3.4K Oct  2 04:17 id_rsa
-rw-r--r--.  1 root root  750 Oct  2 04:17 id_rsa.pub

为什么检测不到我的私钥?

【问题讨论】:

  • 您正在尝试以用户 git 的身份通过 SSH 连接到服务器 mygitlab-ce.locadomain.com。提供了一个密钥,但可能是错误的。您在 mygitlab-ce.locadomain.com 上有一个名为“git”的用户吗?该用户在 ~/.ssh/authorized_keys 中是否有您本地 id_rsa.pub 的条目?这不会解决您的 git 问题,但可能会解决您的 SSH。尝试调试 git 问题时,尝试运行 GIT_SSH_COMMAND="ssh -vvv" git clone git@mygitlab-ce.locadomain.com 以查看 SSH 是否是问题所在。
  • @Mr.Christer 我已经更新了 sss -vvv,关于是否有 git 用户的问题。有,它配备了 gitlab 配置。至于不在授权密钥中的 SSH 密钥,我假设 GitLab 已经处理了这个问题,因为当我尝试在实际的 gitlab 服务器上 su git 时,有一个不同的 shell 仅用于 gitlab。
  • 我明白了。 Gitlab 使用 git 用户和系统 SSH 守护进程。是否在 gitlab 服务器上启用了 RSAAuthentication?您能否尝试创建一个 ECDSA 密钥对并将公钥添加到您的 gitlab 安装中,然后重试。使用命令ssh-keygen -t ecdsa -C comment 创建密钥。如果可行,我会假设您没有启用 RSAAuth。
  • @Mr.Christer 我在哪里查看RSAAuthentication?在客户端?还是 GitLab 服务器端?我在/etc/ssh/sshd_config 中检查了双方,RSAAuthentication yes 没有条目。尝试了您发送的内容,它是相同的,它在ssh -vvv 我看到它检测到/root/.ssh/id_ecdsa 但是debug3: receive packet: type 51 是回复
  • 可能不允许 RSAAuth。尝试使用命令ssh-keygen -t ecdsa -C comment 创建一个 ECDSA 密钥对,然后像使用 id_rsa.pub 一样将公钥添加到服务器。您的服务器似乎更喜欢 ECDSA。

标签: git ssh gitlab


【解决方案1】:

经过@Mr.Christer 的一些挖掘和一些投入。我已经解决了这个问题。该修复有点冗长,因为 GitLab 本身存在问题单问题。所以我不妨将信息链接到 GitLab 问题,因为那里有几个有助于解决问题的 cmets。

Cloning via SSH always prompts password when SSH Key passphrase is set to None

基本上,我想说的是不要在符号链接上执行semanage fcontext,而是在实际物理位置上执行。

-------- 旧 -----------

在与@Mr.Christer 合作后,我们发现 SELinux 阻止了 ssh 公钥身份验证。在 GitLab 服务器上执行 setenforce 0 时,这将允许通过 ssh 成功克隆 git。

我仍在寻找有关如何使用 SELinux 配置 GitLab 的指南。但只是为了给你答案,为 GitLab 配置 SELinux 并通过 ssh 克隆将起作用。

【讨论】:

    【解决方案2】:

    由于服务器使用 SELinux 运行 CentOS,因此可能需要调整策略。

    首先通过在服务器上运行以下命令来测试 SELinux 是否可能是问题

    sudo setenforce 0
    

    如果您能够通过 setenforce 0 使用公钥/私钥对,则使用

    重新启用 SELinux
    sudo setenforce 1
    

    SELinux 停止使用公钥/私钥对克隆的解决方案

    假设 /var/opt/gitlab/ 是你的 gitlab 安装 git 用户的主文件夹,运行如下

    sudo semanage fcontext -a -t  ssh_home_t /data/gitlab/.ssh/
    sudo semanage fcontext -a -t  ssh_home_t /data/gitlab/.ssh/authorized_keys
    sudo restorecon -Rv /data/gitlab/
    

    文件/var/opt/gitlab/gitlab-shell/config.yml 也将被访问,因此需要编辑其上下文

    sudo semanage fcontext -a -t ssh_home_t /data/gitlab/gitlab-shell/config.yml
    sudo restorecon -Rv /data/gitlab/gitlab-shell/
    

    还有/data/gitlab/gitlab-rails/etc/gitlab_shell_secret

    sudo semanage fcontext -a -t ssh_home_t /data/gitlab/gitlab-rails/etc/gitlab_shell_secret
    sudo restorecon -Rv /data/gitlab/gitlab-rails
    

    通过运行确认上下文更改已应用

    sudo semanage fcontext --list
    

    你应该看到

    /data/gitlab/.ssh/authorized_keys                  all files          system_u:object_r:ssh_home_t:s0
    /data/gitlab/.ssh/                                 all files          system_u:object_r:ssh_home_t:s0
    /data/gitlab/gitlab-shell/config.yml               all files          system_u:object_r:ssh_home_t:s0
    /data/gitlab/gitlab-rails/etc/gitlab_shell_secret  all files          system_u:object_r:ssh_home_t:s0
    

    如果是这种情况,请尝试从您的存储库中克隆。详情请参考lemoncodes support thread on gitlab.com

    【讨论】:

    • 我在我们的车队中添加了一些。请看他们。
    • 只是一个更正,在执行semanage 时,不要将其应用于符号链接路径。将其应用于 symlnk 引用的实际物理文件夹
    • 我明白了。我不知道路径是符号链接。我将编辑答案以反映您为使其正常工作所做的工作。请确认这是正确的程序。
    猜你喜欢
    • 2017-09-30
    • 1970-01-01
    • 2021-11-23
    • 1970-01-01
    • 2016-03-08
    • 1970-01-01
    • 2021-09-09
    • 2020-06-03
    • 2023-03-20
    相关资源
    最近更新 更多