Jenkins学习笔记5

Jenkins学习笔记5_第1张图片

[root@localhost ~]# cd  /var/lib/jenkins/workspace/nginx_root_sync
[root@localhost nginx_root_sync]# ll
total 16
-rw-r--r-- 1 jenkins jenkins  6 Sep 20 20:57 1.php
-rw-r--r-- 1 jenkins jenkins  5 Sep 20 20:57 2.php
-rw-r--r-- 1 jenkins jenkins  5 Sep 20 21:17 3.php
-rw-r--r-- 1 jenkins jenkins 35 Sep 20 20:57 README.md

 这个目录其实就是一个workspace。

自动发布系统:

Jenkins学习笔记5_第2张图片

Jenkins学习笔记5_第3张图片

SSH免密:

开发者要产生ssh空密码密钥对,把公钥添加到gitlab(过程省略)

Jenkins学习笔记5_第4张图片

在开发者进行git clone创建好的项目,进行开发

[root@git-developer ~]# git clone [email protected]:root/auto_build_web.git
Cloning into 'auto_build_web'...
The authenticity of host '192.168.17.118 (192.168.17.118)' can't be established.
ECDSA key fingerprint is SHA256:4dogA08L5gdfaA69BGekE13kzSuIP2vcRp9rsqYnpn0.
ECDSA key fingerprint is MD5:93:34:b9:61:03:cd:00:92:b9:91:3d:b6:6c:7a:84:95.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '192.168.17.118' (ECDSA) to the list of known hosts.
remote: Enumerating objects: 3, done.
remote: Counting objects: 100% (3/3), done.
remote: Compressing objects: 100% (2/2), done.
remote: Total 3 (delta 0), reused 0 (delta 0), pack-reused 0
Receiving objects: 100% (3/3), done.
[root@git-developer ~]# ll
total 4
-rw-------. 1 root root 1518 Sep  2 02:39 anaconda-ks.cfg
drwxr-xr-x  3 root root   35 Sep 20 21:41 auto_build_web
drwxr-xr-x  3 root root   74 Sep 20 21:16 jenkins

 写好代码并上传:

[root@git-developer auto_build_web]# echo 1111 > 1.php
[root@git-developer auto_build_web]# git add *
[root@git-developer auto_build_web]# git commit -m "Added 1.php"
[main e5d9341] Added 1.php
 1 file changed, 1 insertion(+)
 create mode 100644 1.php


[root@git-developer auto_build_web]# git push -u origin main
Counting objects: 4, done.
Delta compression using up to 2 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 275 bytes | 0 bytes/s, done.
Total 3 (delta 0), reused 0 (delta 0)
To [email protected]:root/auto_build_web.git
   e223804..e5d9341  main -> main
Branch main set up to track remote branch main from origin.

Jenkins学习笔记5_第5张图片

Jenkins安装对应的插件:

jenkins安装gitlab和gitlab hook插件:

Jenkins学习笔记5_第6张图片

安装好之后,要重启下jenkins。 

Jenkins学习笔记5_第7张图片

Available:可获得的。

Installed:已安装的。

添加Jenkins服务器公钥到gitlab:

第1步: jenkins产生root用户的ssh空密码密钥对(步骤省略)

添加公钥到gitlab:

Jenkins学习笔记5_第8张图片

测试下连通性:

在jenkins-server服务器上,通过git clone方法测试。

在jenkins服务器上克隆仓库,确认连接OK

[root@jenkins-server ~]# git clone [email protected]:root/auto_build_web.git
Cloning into 'auto_build_web'...
The authenticity of host '192.168.17.118 (192.168.17.118)' can't be established.
ECDSA key fingerprint is SHA256:4dogA08L5gdfaA69BGekE13kzSuIP2vcRp9rsqYnpn0.
ECDSA key fingerprint is MD5:93:34:b9:61:03:cd:00:92:b9:91:3d:b6:6c:7a:84:95.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '192.168.17.118' (ECDSA) to the list of known hosts.
remote: Enumerating objects: 6, done.
remote: Counting objects: 100% (6/6), done.
remote: Compressing objects: 100% (4/4), done.
remote: Total 6 (delta 0), reused 0 (delta 0), pack-reused 0
Receiving objects: 100% (6/6), done.


[root@jenkins-server ~]# ll
total 4
-rw-------. 1 root root 1518 Sep  2 02:39 anaconda-ks.cfg
drwxr-xr-x  3 root root   48 Sep 20 22:10 auto_build_web
drwxr-xr-x  2 root root   42 Sep 20 11:28 soft


[root@jenkins-server ~]# cd auto_build_web/
[root@jenkins-server auto_build_web]# ll
total 12
-rw-r--r-- 1 root root    5 Sep 20 22:10 1.php
-rw-r--r-- 1 root root 6183 Sep 20 22:10 README.md

Jenkins

这是一个构建任务名称:

Jenkins学习笔记5_第9张图片

 然后点击OK。

Jenkins学习笔记5_第10张图片

Jenkins学习笔记5_第11张图片

这个root凭据需要进行下确认。

Jenkins学习笔记5_第12张图片

更改下主分支名称,不是master,是main。

Jenkins学习笔记5_第13张图片

Gitlab知道自己的projects或者仓库发生了变化,通过WebHook告诉jenkins,触发。

Jenkins学习笔记5_第14张图片

生成token令牌。

Jenkins学习笔记5_第15张图片

 构建:这次我们不使用Publish over SSH了。我们使用执行Shell。

使用Shell,那说明我们可以使用Shell来发挥了。

#!/bin/bash
SOURCE_DIR=/var/lib/jenkins/workspace/$JOB_NAME/
DEST_DIR=/usr/share/nginx/html

/usr/bin/rsync -av --delete $SOURCE_DIR [email protected]:$DEST_DIR

rsync这个工具还是很强大的,需要学习下。

Jenkins学习笔记5_第16张图片

$JOB_NAME Name of the project of this build。

Jenkins学习笔记5_第17张图片

 另外,执行此脚本不再是使用publish over ssh插件,而是使用jenkins服务器上的jenkins用户来执行的。

[root@jenkins-server ~]# grep jenkins /etc/passwd
jenkins:x:998:996:Jenkins Automation Server:/var/lib/jenkins:/bin/false


[root@jenkins-server ~]# usermod -s /bin/bash jenkins


[root@jenkins-server ~]# grep jenkins /etc/passwd
jenkins:x:998:996:Jenkins Automation Server:/var/lib/jenkins:/bin/bash

让jenkins具有登录权限。能够使用su jenkins命令进行切换。

问题: 既然是使用jenkins服务器上的jenkins用户来执行,为什么rsync不传给10.1.1.14的jenkins用户,而是传给它的root用户?

Jenkins学习笔记5_第18张图片

Jenkins学习笔记5_第19张图片

答: 因为10.1.1.14上没有jenkins用户,就算有jenkins用户,对/usr/share/nginx/html也没有写权限

我们再看下/usr/share/nginx/html目录的权限:

Jenkins学习笔记5_第20张图片

html的目录的拥有者是root,具有可读可写可执行的权限。

然后再执行命令:

Jenkins学习笔记5_第21张图片

Jenkins学习笔记5_第22张图片

再确认下rsync这个工具有没有安装:
Jenkins学习笔记5_第23张图片

小结:

使用jenkins用户执行rsync脚本同步到nginx的root用户。

再配置Jenkins跟gitlab的对接:

Jenkins学习笔记5_第24张图片

配置gitlab允许本地网络使用webhook:

gitlab默认在本地网络不能使用webhook,所以我们配置允许。(使用管理员配置,普通用户看不到下面的扳手图标。)

Jenkins学习笔记5_第25张图片

Jenkins学习笔记5_第26张图片

 这个SSL verification的选项要去掉。

安全带来的问题对运维来说是麻烦。

Urlis blocked: Requests to the local network are not allowed

在配置的过程中遇到这个问题。

Jenkins学习笔记5_第27张图片

Jenkins学习笔记5_第28张图片

那一切就准备就绪。

然后我这边也将几个系统的时间重新进行了同步,保证每台服务器的时间都是相同的。

ntpdate time1.aliyun.com

systemctl restart ntpd

没有出现构建的自动运行,检查发现这个地方没有被勾选。Push events。

Jenkins学习笔记5_第29张图片

看到jenkins的这个地方开始进行构建。

Jenkins学习笔记5_第30张图片

Jenkins学习笔记5_第31张图片

可以看到文件已经同步到了nginx-server服务器上了。

然后我们再看下构建的日志:

Jenkins学习笔记5_第32张图片

你可能感兴趣的:(Jenkins,jenkins)