配置Jenkins打包
报错
Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password)
这个错误表示在连接到目标服务器时出现了权限拒绝的问题。可能的原因和解决方法如下:
将 Jenkins 用户的 SSH 公钥添加到目标服务器的 ~/.ssh/authorized_keys 文件。你可以使用
ssh-copy-id 命令来简化此过程:
ssh-copy-id -i /path/to/jenkins/ssh/key user@192.168.2.122
/path/to/jenkins/ssh/key
目录
在 Linux 系统上,SSH 密钥通常存储在用户的家目录下的 ~/.ssh/ 文件夹中。所以,如果 Jenkins 服务是以 jenkins 用户身份运行,你可以使用以下路径:
/home/jenkins/.ssh/id_rsa
如果你知道 Jenkins 服务运行的用户,可以将路径中的 jenkins 替换为实际的用户名。确保选择的密钥是已经添加到目标服务器 ~/.ssh/authorized_keys 文件中的密钥。
Jenkins 用户配置: 确保 Jenkins 服务是以正确的用户身份运行的。在 Jenkins 服务配置中,你可以指定
Jenkins 运行的用户。
SSH 密钥文件路径: 在 Jenkins 中,确保在 “Send files or execute commands over SSH”
步骤中配置了正确的 SSH 密钥文件路径。你可以在 Jenkins 的构建配置中查看 SSH 配置。
SSH 密码登录: 如果无法使用密钥登录,考虑在 Jenkins
配置中启用密码登录,或者在构建脚本中提供密码。这通常不是最安全的方法,但可以作为调试的一种方式。
在 Jenkins 配置中的 “Send files or execute commands over SSH” 步骤中,选择 “Use password authentication, or use a different key” 并提供密码。
目标服务器 SSH 配置: 确保目标服务器的 SSH 服务器配置允许密码登录或使用提供的密钥。检查目标服务器的
/etc/ssh/sshd_config 文件。
在尝试这些解决方法之后,再次运行 Jenkins 作业,应该能够成功连接到目标服务器。