使用Jenkins通过Publish Over SSH插件远程控制主机执行脚本

简介: 使用Jenkins通过Publish Over SSH插件远程控制主机执行脚本

环境介绍:


192.168.1.18 :Jenkins、CentOS 7.5.1804、Docker 19.03.13


192.168.1.20:K8s_Node2/Gitlab、CentOS 7.5.1804、Docker 19.03.13


准备工作:


 在被远程主机192.168.1.20上准备好test.sh脚本文件。

[root@k8s-node2 ~]# cat >> cat shell/test.sh << EOF
> #!/bin/bash
> echo I am 192.168.1.20
> EOF
[root@k8s-node2 ~]# cat shell/test.sh
#!/bin/bash
echo I am 192.168.1.20
[root@k8s-node2 ~]# chmod +x shell/test.sh     //添加脚本执行权限

插件安装


 在主机192.168.1.18的Jenkins中【系统管理】—【管理插件】中,过滤出“Publish over SSH插件”,然后直接安装插件,如图安装即可,或者去官网下载插件的.hpi文件通过高级选项中手动安装也可以。


Publish Over SSH插件

12.png

安装完插件需要重启Jenkins生效。


配置免密登录


 在Jenkins主机上生成一对密钥,公钥发送给需要被远程的主机,私钥配置到Jenkins中即可。

[root@k8s-master ~]# ssh-keygen -t rsa -P ''
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa):
Your identification has been saved in /root/.ssh/id_rsa.
Your public key has been saved in /root/.ssh/id_rsa.pub.
The key fingerprint is:
SHA256:OfjoeZpsg4PijcdTjIPJ4WIXWHkOQeC6wFztgryyvWE root@k8s-master
The key's randomart image is:
+---[RSA 2048]----+
| .ooo            |
|.  +..           |
| .o.+.           |
|=oo... . .       |
|==+.+.. S        |
|oB.+.o o .       |
|=.E.o.. .        |
|o++=oooo.        |
|o++o.o*+         |
+----[SHA256]-----+
[root@k8s-master ~]# ls .ssh/
id_rsa(私钥)       id_rsa.pub(公钥)   known_hosts
[root@k8s-master ~]# ssh-copy-id -i .ssh/id_rsa.pub 192.168.1.20
[root@k8s-node2 ~]# cat .ssh/authorized_keys     //可以看到公钥已经拷贝到被远程主机上了
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDSV7n2kfuan5cfGaSgRtfxLJdxn52ZzKGtLUduq1+dZWhKpqIytCKOUgO/rpsUOD1WdsVQqJetxvML7BWHzO67LhmX07K9QQ4L9hIfBoG+ozA+qDCeKkJGg02rcxAwGvtPqvtJYDQII/Yg8KX6rRb8ccjktGTwVPusYf+F25/BifysnEwHuOe0FcwpknMhBEzJWRnS+UCVr/b+3fd1BVEso0Xz/8bfAQpAvXIYyCYJe0CP+ucz3pPioirgOmQQtQVHnaqXlKNIVncwtDlZ7LHzWV4sgkfmKQno3qkdAw0FG1bxXDp3KnOGiCNdvq0aVyNPHGWi3pu7OhPsxlEz2NZP root@k8s-master
[root@k8s-master ~]# ssh root@192.168.1.20      //测试免密登录成功
Last login: Wed Nov 17 12:59:12 2021 from k8s-master
[root@k8s-node2 ~]# 登出
Connection to 192.168.1.20 closed.

插件配置


 在Jenkins中【系统管理】—【系统配置】,划到“Publish over SSH”来配置该插件信息。

13.png

注意:私钥指的是Jenkins主机上生成的私钥,公钥在上面已经发送给被远程主机了。


 Passphrase:SSH的密码,使用用户名/密码登录时为用户名的密码,使用私钥登录时为私钥的密码。


 Path to key:SSH私钥的文件路径,私钥文件的路径,可以是绝对路径,也可以是相对$JENKINS_HOME的相对路径。


 Key:私钥,即私钥的具体密钥内容。如果“Key”和“Path to key”都设置,则“Key”的优先级较高,私钥的密码是“Passphrase”中设置的内容。


 Disable exec:禁止在目标机上执行命令,勾选后将会忽略在Job配置中“Exec command”选项中设置的命令。Jenkins的说明文档中的“The Disable exec in the advanced settings for individual configurations will be ignored.”没有完全理解,从实际效果来看,只要“Disable exec”被勾选后,不管SSH Server中是否勾选“Disable exec”,Job中设置的命令都将补忽略。

14.png

 Name:SSH节点配置的名称,在构建中使用Publish over SSH插件时,此名称将出现在“SSH Server”中“Name”的下拉列表中,如下图:

15.png


 Hostname:通过SSH连接到的机器的主机名或IP。


 Username:SSH服务使用的用户名,使用key进行连接时为key指定的用户名。


 Remote Derictory:运程机器上真实存在的目录,并且“Username”指定的用户要有访问此目录的权限,插件将把文件传送到此目录下。


创建项目

16.png

17.png

Name:“系统管理>系统配置”设置的SSH Sverver的名字Name。


 Source files:允许为空,复制到远程主机上的文件。


 Remove prefix:允许为空,文件复制时要过滤的目录。


 Remote directory:允许为空,文件得到到远程机上的目录,此目录是相对于“SSH Server”中的“Remote directory”的,如果不存在将会自动创建。


 Exec command:在这里填写在远程主机上执行的命令。


构建项目

18.png19.png

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
打赏
0
0
0
0
12
分享
相关文章
Jenkins自动化部署脚本
Jenkins自动化部署脚本
74 0
告别繁琐配置:Alibaba Cloud Toolkit插件打破Jenkins自动化部署的局限
告别繁琐配置:Alibaba Cloud Toolkit插件打破Jenkins自动化部署的局限
463 0
|
9月前
|
【Shell 命令集合 文件管理】Linux ssh 远程主机之间复制文件 scp 命令使用教程
【Shell 命令集合 文件管理】Linux ssh 远程主机之间复制文件 scp 命令使用教程
328 0
如何在 Ubuntu 上创建一个 SSH CA 以验证主机和客户端
如何在 Ubuntu 上创建一个 SSH CA 以验证主机和客户端
116 0
Java项目jar包启动脚本,适用jenkins或定时任务或手动执行
Java项目jar包启动脚本,适用jenkins或定时任务或手动执行
396 3
Jenkins 插件生态:提升自动化能力
【8月更文第31天】Jenkins 是一个开源的持续集成/持续交付(CI/CD)平台,广泛应用于软件开发的各个阶段。Jenkins 的一大特色就是其丰富的插件生态系统,这些插件极大地扩展了 Jenkins 的功能,使其能够适应各种各样的应用场景。本文将深入探讨 Jenkins 的插件生态系统,并指导如何选择和配置插件以满足特定需求。
319 1
jenkins学习笔记之十七:使用插件及maven上传制品到nexus
jenkins学习笔记之十七:使用插件及maven上传制品到nexus
Jenkins Pipeline 流水线 - 完整构建 Pipeline Script 脚本
Jenkins Pipeline 流水线 - 完整构建 Pipeline Script 脚本
117 0
Jenkins Pipeline 流水线 - 上传文件 Publish over SSH + Docker 编译 + 上传到阿里仓库
Jenkins Pipeline 流水线 - 上传文件 Publish over SSH + Docker 编译 + 上传到阿里仓库
181 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等