摘要:环境介绍角色系统版本版本准备工作在被远程主机上准备好脚本文件。禁止在目标机上执行命令,勾选后将会忽略在配置中选项中设置的命令。服务使用的用户名,使用进行连接时为指定的用户名。在这里填写在远程主机上执行的命令。
IP | 角色 | 系统版本 | Docker版本 |
---|---|---|---|
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/bashecho 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插件
安装完插件需要重启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-masterThe 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”来配置该插件信息。
注意:私钥指的是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中设置的命令都将补忽略。
Name:SSH节点配置的名称,在构建中使用Publish over SSH插件时,此名称将出现在“SSH Server”中“Name”的下拉列表中,如下图:
Hostname:通过SSH连接到的机器的主机名或IP。
Username:SSH服务使用的用户名,使用key进行连接时为key指定的用户名。
Remote Derictory:运程机器上真实存在的目录,并且“Username”指定的用户要有访问此目录的权限,插件将把文件传送到此目录下。
Name:“系统管理>系统配置”设置的SSH Sverver的名字Name。
Source files:允许为空,复制到远程主机上的文件。
Remove prefix:允许为空,文件复制时要过滤的目录。
Remote directory:允许为空,文件得到到远程机上的目录,此目录是相对于“SSH Server”中的“Remote directory”的,如果不存在将会自动创建。
Exec command:在这里填写在远程主机上执行的命令。
最近刚申请了个微信公众号,上面也会分享一些运维知识,大家点点发财手关注一波,感谢大家。 【原创公众号】:非著名运维 【福利】:公众号回复 “资料” 送运维自学资料大礼包哦!
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/123944.html
摘要:测试环境和产品环境应该使用不同的任务,因为服务会部署到不同的机器。使用部署设置时区加入程序并安装包发布其他资料持续集成执行读不到环境变量问题文档 showImg(https://segmentfault.com/img/remote/1460000010233188); docker run -u root -itd --name jenkins -p 8080:8080 -p 500...
摘要:使用自动构建部署环境阿里云,宿主机服务器安装,在安全规则中确认端口开启。完毕后,根据提示设置登陆账户。至此,完成自动化的构建和部署。当你推送代码后就会实现自动构建,部署。容器出错的是镜像构建和镜像运行,以及容器间通信的问题。 使用Docker+Jenkins自动构建部署 环境 阿里云ESC,宿主机服务器安装Docker,在安全规则中确认8080端口开启。 客户端mac 运行jenk...
实践性尝试,这里只在一台虚拟机下操作。 1.vmware 下centos 安装 设置centos 桥接模式 参考:https://www.cnblogs.com/loven... 2.centos 软件安装 1) docker 安装 yum install -y docker 2)JDK 安装 参考:https://blog.csdn.net/evan_chen_1/article/de...
阅读 3950·2021-11-24 09:38
阅读 1421·2021-11-19 09:40
阅读 2777·2021-11-18 10:02
阅读 3690·2021-11-09 09:46
阅读 1763·2021-09-22 15:27
阅读 3109·2019-08-29 15:24
阅读 996·2019-08-29 12:40
阅读 1681·2019-08-28 18:24