Jenkins打包问题

配置Jenkins打包

报错

bash 复制代码
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 命令来简化此过程:

bash 复制代码
ssh-copy-id -i /path/to/jenkins/ssh/key user@192.168.2.122

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

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

bash 复制代码
/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 作业,应该能够成功连接到目标服务器。

相关推荐
tianyuanwo4 小时前
Jenkins × Gerrit 集成:自动触发构建的全流程解析
运维·servlet·jenkins
勿芮介7 小时前
【研发工具】Jenkins镜像源配置问题及解决方案
运维·servlet·jenkins
Cat_Rocky10 小时前
Jenkins通过kubernetes连接K8s集群
运维·kubernetes·jenkins
齐潇宇1 天前
Jenkins 自动化部署 Tomcat + PHP
linux·运维·容器·tomcat·jenkins
Cat_Rocky1 天前
Linux-基于Jenkins自动打包并部署Tomcat环境
linux·tomcat·jenkins
tang7451639621 天前
Huawei Cloud EulerOS 2.0(x8664)安装 Jenkins
java·servlet·jenkins
2601_948810601 天前
Jenkins
运维·jenkins
D4c-lovetrain1 天前
Jenkins 实战:Java 项目全自动打包、镜像构建、K8s 集群部署(完整CI/CD方案)
java·kubernetes·jenkins
东北甜妹1 天前
Jenkins自动化部署tomcat环境 PHP环境
tomcat·自动化·jenkins
眷蓝天2 天前
Jenkins部署与配置
运维·jenkins