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

相关推荐
yhole1 天前
Java进阶(ElasticSearch的安装与使用)
java·elasticsearch·jenkins
学习使我快乐——玉祥2 天前
ElasticSearch离线安装
大数据·elasticsearch·jenkins
H_老邪2 天前
Docker 学习之路-从入门到放弃-Jenkins:4
容器·jenkins
sjmaysee2 天前
Springboot中使用Elasticsearch(部署+使用+讲解 最完整)
spring boot·elasticsearch·jenkins
蜜獾云4 天前
Elastic Stack基础概念
运维·jenkins
北风toto4 天前
Jenkins的安装与启动
运维·servlet·jenkins
任我坤5 天前
搭建Jenkins服务-2025更新
运维·servlet·jenkins
bearpping6 天前
Java进阶(ElasticSearch的安装与使用)
java·elasticsearch·jenkins
代码星辰6 天前
Jenkins——安装与使用
运维·ci/cd·jenkins