博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
jenkins系列_使用scp命令进行远程文件复制遇到的坑
阅读量:6376 次
发布时间:2019-06-23

本文共 728 字,大约阅读时间需要 2 分钟。

转自:https://blog.csdn.net/kingboyworld/article/details/78905553

一、场景介绍

项目为微服务项目,使用jenkins进行统一部署。基本思路是 

1. 在jenkins服务器上使用git插件拉取项目代码 
2. 使用gradle进行打包 
3. 将打好的jar包使用scp远程复制到部署服务器上 
4. 执行远程shell脚本启动jar包项目

二、坑

scp命令copy文件时需要输入密码,然而shell脚本中对密码输入的处理还是很麻烦的。有以下两种方式:

1.使用密码插件,自动输入密码 

或 
2.使服务器之间相互信任,这样scp命令就不需要输入密码了

第一种方式,网上搜了下,感觉很麻烦,就没有去尝试了。第二种方式的配置过程如下:

1.复制jenkins服务器用户目录下的.ssh/id_rsa.pub中的内容

(没有这个文件的话可以网上查查怎么生成)。

cat ~/.ssh/id_rsa.pub

2.将上面复制的内容添加到应用服务器(也就是需要远程部署应用的服务器)的.ssh/authorized_keys文件中。

一般这个文件初始都是空的,直接使用vim命令复制进去就好。

#如果文件是空的可以直接使用以下命令复制进去echo 复制的内容 >> ~/.ssh/authorized_keys

这个时候环境配置就准备好了。

3.这个时候使用jenkins构建时,仍然失败,提示权限不够,这就是坑。

原因:虽然我们已经配置了相许信任,但是第一次使用scp命令需要先自己手动在shell中端中执行一次才可以。那么我们使用scp随意复制个文件过去,输入密码。

之后再用jenkins复制文件就免输密码了。

你可能感兴趣的文章
Spring Boot - how to configure port
查看>>
右键添加复制路径选项
查看>>
DocFetcher 本机文件搜索工具
查看>>
ambassador 学习三 限速处理
查看>>
HTTP传输编码增加了传输量,只为解决这一个问题 | 实用 HTTP
查看>>
家里蹲大学数学杂志期刊模式目录
查看>>
数据结构:最小生成树--Kruskal算法
查看>>
Swift_1_基本数据类型
查看>>
POJ 1849 Two(遍历树)
查看>>
Recurrent Neural Network[CTC]
查看>>
VS注释与取消注释快捷键
查看>>
深入解析Vuex实战总结
查看>>
.NET编译项目时出现《此实现不是 Windows 平台 FIPS 验证的加密算法的一部分》处理方法...
查看>>
流水落花春去也
查看>>
从.NET中委托写法的演变谈开去(下):性能相关
查看>>
C# 多人聊天程序
查看>>
【教训】为什么不作备份?!
查看>>
网搜索引擎架构设计
查看>>
iOS笔记:内存管理
查看>>
python开发_python中str.format()
查看>>