Jenkins打包问题

配置Jenkins打包
报错

Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password)

这个错误表示在连接到目标服务器时出现了权限拒绝的问题。可能的原因和解决方法如下:

  1. -SSH 密钥问题: 确保 Jenkins 服务器上运行 Jenkins 服务的用户(通常是 jenkins 用户)的 SSH 密钥已经添加到目标服务器的 ~/.ssh/authorized_keys 文件中。
  • 将 Jenkins 用户的 SSH 公钥添加到目标服务器的 ~/.ssh/authorized_keys 文件。你可以使用

    ssh-copy-id 命令来简化此过程:


ssh-copy-id -i /path/to/jenkins/ssh/key [email protected]

/path/to/jenkins/ssh/key 目录

在 Linux 系统上,SSH 密钥通常存储在用户的家目录下的 ~/.ssh/ 文件夹中。所以,如果 Jenkins 服务是以 jenkins 用户身份运行,你可以使用以下路径:

/home/jenkins/.ssh/id_rsa

如果你知道 Jenkins 服务运行的用户,可以将路径中的 jenkins 替换为实际的用户名。确保选择的密钥是已经添加到目标服务器 ~/.ssh/authorized_keys 文件中的密钥。

  1. Jenkins 用户配置: 确保 Jenkins 服务是以正确的用户身份运行的。在 Jenkins 服务配置中,你可以指定
    Jenkins 运行的用户。

  2. SSH 密钥文件路径: 在 Jenkins 中,确保在 “Send files or execute commands over SSH”
    步骤中配置了正确的 SSH 密钥文件路径。你可以在 Jenkins 的构建配置中查看 SSH 配置。

  3. SSH 密码登录: 如果无法使用密钥登录,考虑在 Jenkins
    配置中启用密码登录,或者在构建脚本中提供密码。这通常不是最安全的方法,但可以作为调试的一种方式。

    在 Jenkins 配置中的 “Send files or execute commands over SSH” 步骤中,选择 “Use password authentication, or use a different key” 并提供密码。

  4. 目标服务器 SSH 配置: 确保目标服务器的 SSH 服务器配置允许密码登录或使用提供的密钥。检查目标服务器的
    /etc/ssh/sshd_config 文件。

在尝试这些解决方法之后,再次运行 Jenkins 作业,应该能够成功连接到目标服务器。

你可能感兴趣的:(jenkins)