Fork me on GitHub

Jenkins解决Host key verification failed

1.在没有做任何操作时,是这样报错的

a.在任务中配置远程执行命令

rsync -raz --delete --progress  target/testweb-v1.1.jar  root@10.0.0.41:/data/

ssh root@10.0.0.41 "java -jar /data/testweb-v1.1.jar"

要远程到10.0.0.41这台服务器上执行java命令,所以这台服务器上得有java环境,简单点用yum装就行:

yum -y install java-1.8.0-openjdk java-1.8.0-openjdk-devel

b.构建后报错信息

 

2.报错原因

a.jenkins普通用户无法执行某些系统命令;

b.我们并没有为jenkins生成过密钥对,也没有将他的公钥拷到目标服务器上.

  在安装jenkins后,系统生成了jenkins这个普通用户,但是在/etc/passwd中,他的shell是/bin/false,所以他不能登录系统,也没有家目录;

  首先我们修改他的登录权限,将/bin/false改为/bin/bash,切换到jenkins用户,su - jenkins,他的终端显示为-bash-4.2$,修改终端显示.

终端修改完之后长这个样子

生成密钥对

具体步骤

vim ~/.bash_profile
export PS1='[\u@\h \W]\$'
source ~/.bash_profile
# 给jenkins生成密钥对
ssh-keygen -t rsa
ssh-copy-id -i ~/.ssh/id_rsa.pub root@10.0.0.41
# 验证
ssh 'root@10.0.0.41'

3.使用sudo提升普通用户权限

  此时是完成了第二步,但还没有操作第一步,在文件末尾添加一行,就这么一行就有很多要注意的地方,首先修改文件权限为600,然后用viduso去修改文件,中间的空隙不是空格,而是tab,命令和命令之间要用逗号,保存退出后,将权限改为440,而不是400,最后用visudo -c检查语法是否出错.

jenkins        ALL=(ALL)    NOPASSWD: /usr/bin/ssh, /usr/bin/rsync

jenkins        ALL=(ALL)    NOPASSWD: ALL

这两行内容任意选一个都行.

重启服务,构建任务

参考博客:https://blog.csdn.net/cdnight/article/details/81078191

posted @ 2019-01-24 19:25  法外狂徒  阅读(12473)  评论(0编辑  收藏  举报