Jenkins打包问题
配置Jenkins打包
报错
Permission denied (publickey,gssapi-keyex,gssapi-with-mic,password)
这个错误表示在连接到目标服务器时出现了权限拒绝的问题。可能的原因和解决方法如下:
- -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 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 作业,应该能够成功连接到目标服务器。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!