gitlab与jenkins的自动化部署(通过webhook与ansilble)

时间:2022-05-30 20:05:32

gitlab与jenkins的自动化部署(通过webhook与ansilble)


1、部署介绍

gitlab服务器:192.168.1.49:80
jenkins服务器:192.168.1.49:8180
ps:由于两个服务运行在同一台服务器上面,因此,为了保证jenkins服务器能拉取到 gitlab的代码,把root的用户的公钥分别上传到gitlab admin用户跟jenkins admin用户当中去。jenkins我没有使用默认的端口8080,主要是我公司的gerrit架构会用到这个8080端口,所以为了防止冲突,改为8180端口


2、gitlab安装

a) 第一步:安装相应的在依赖包(postfix或者sendmail),其中选择internet site这种网络smtp邮件服务器这种方式来发送邮件,其他一些依赖包:curl \openssh-server\ ca-certificates\ postfix

If you install Postfix to send email please select 'Internet Site' during setup. Instead of using Postfix you can also use Sendmail or configure a custom SMTP server . If you wish to use Exim, please configure it as an SMTP server.
On Centos 6 and 7, the commands below will also open HTTP and SSH access in the system firewall.

操作命令:
sudo apt-get install curl openssh-server ca-certificates postfix

b) 第二步:Add the GitLab package server and install the package. 下载gitlab安装包,并且安装
方法1、增加yum源链接,使用sduo apt-get install gitlab-ee
Apt-get安装Curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.deb.sh|sudo bash
操作命令:
sudo apt-get install gitlab-ce

If you are not comfortable installing the repository through a piped script, you can find the entire script here .
Alternatively you can select and download the package manually and install using
方法2、deb包安装下载deb包,然后安装

下载: sudo wget https://packages.gitlab.com/gitlab/gitlab-ee
安装: sudo dpkg -i gitlab-ce_8.1.2-ee.0_amd64.deb

建议一般下载后再装

c)第三步,启用配置,并且启动 GitLab
操作命令:
sudo gitlab-ctl reconfigure

d) 第四步:打开网页,进行注册,使用默认密码
http://192.168.0.177:80
Username: rootPassword: 5iveL!fe

e) 第五步:2.1.6. Upload your license(EE版本需要认证,CE) 这步我操作的时候是没有的
Go toAdmin > Licenseand upload your.gitlab-licensefile.
Don't have a license yet? Get a subscription.

其实只要下载到gitlab ce包(ce是社区版,不用验证的),直接安装就行了,启动命令为gitlab-ctl reconfigure


3、jenkins安装

a) Install Jenkins
wget -q -O - https://jenkins-ci.org/debian/jenkins-ci.org.key | sudo apt-key add -
sudo sh -c 'echo deb http://pkg.jenkins-ci.org/debian binary/ > /etc/apt/sources.list.d/jenkins.list'
sudo apt-get update
sudo apt-get install jenkins

b) Starting Jenkins

nohup java -Dorg.jenkinsci.plugins.gitclient.Git.timeOut=60 -Dfile.encoding=UTF-8 -Dhudson.DNSMultiCast.disabled=true -jar /usr/share/jenkins/jenkins.war --httpPort=8180 > /var/log/jenkins_log 2>&1 &

(注意--httpPort=8180放在后面)

c) 开启 jenkins页面为:192.168.0.179:8180
http://xxxxx:8180/

d) 插件安装
Git Plugin
SSH Plugin
URL Trigger Plugin
Gerrit Trigger Plugin
Gitlab Hook
Gitlab Merge Request Builder
GitLab Plugin

e) 注册用户
先开启用户注册按钮,用户注册完毕以后,关闭用户注册


4、配置jenkins拉取gitlab项目的账号的sshkey

由于两个服务运行在同一台服务器上面,因此,为了保证jenkins服务器能拉取到 gitlab的代码,把root的用户的公钥分别上传到gitlab admin用户跟jenkins admin用户当中去。步骤我就不写了!


5、配置jenkins项目

1、登录192.168.1.49:8180
点击新建:

gitlab与jenkins的自动化部署(通过webhook与ansilble)

依次填写相关信息:(注意,项目安全这块是在日常管理中才会用到,如果简单测试可以忽略)

gitlab与jenkins的自动化部署(通过webhook与ansilble)

源码管理:
gitlab与jenkins的自动化部署(通过webhook与ansilble)

触发器:

我这里选择得比较多,有push触发,也有merge触发
gitlab与jenkins的自动化部署(通过webhook与ansilble)

构建:(通过shell来构建)
gitlab与jenkins的自动化部署(通过webhook与ansilble)

我这里是通过简单的ansible来控制web服务器的压缩包scp,tar解压,还有指定软联接
#变量WORKSPACE、GIT_URL是jenkins默认内置的变量

#!/bin/bash 

#变量WORKSPACE,GIT_URL是jenkins默认提供的变量
cd $WORKSPACE #截取giturl中的产品
product=`echo $GIT_URL| awk -F"/" '{print $NF}'|sed 's/\.git//g'` #截取代码当前的前七位sha值
sha=`cat .git/HEAD|cut -b -` #指定日期
d=`date +"%Y%m%d"` #指定压缩包的路径与包全称,包名(不带后缀)
p_pathname=/tmp/"$product"_"$d"_"$sha".tar.gz
p_name="$product"_"$d"_"$sha".tar.gz
p_productname="$product"_"$d"_"$sha" #本地压缩
tar -cf $p_pathname $WORKSPACE/* #指定web服务器的包的存放位置
p_store=/var/prod/"$product"/"$d" #指定web服务器的包解压位置
p_target=$p_store/$p_productname #指定nginx网页代码位置
www=/mnt/www/launcher.szprize.cn #dev代表web服务器,确保包解压路径存在
ansible dev -m shell -a "mkdir -p $p_target "
#dev代表web服务器,ansible copy模块远程复制
ansible dev -m copy -a "src=$p_pathname dest=$p_store/"
#ansible 远程解压
ansible dev -m shell -a "tar -xf $p_store/$p_name -C $p_target"
#ansible 软联接
ansible dev -m file -a "src=$p_target dest=$www state=link"#!/bin/bash

jenkins这边就配置完了

但是注意:jenkins跟gitlab怎么通信触发呢?

大家请留意触发器那块有一句话:
Build when a change is pushed to GitLab. GitLab CI Service URL: http://192.168.1.49:8180/project/launcher
它的意思的,gitlab ci接口可以通过http://192.168.1.49:8180/project/launcher来连接两者的有关系。



6、gitlab设置webhook

在对应的gitlab项目设置当中,设置webhooks
gitlab与jenkins的自动化部署(通过webhook与ansilble)

当然,这里也可以设置triger事件:
gitlab与jenkins的自动化部署(通过webhook与ansilble)

保存后会在底部,生成webhook,点击test,看jenkins界面是否触发了!

gitlab与jenkins的自动化部署(通过webhook与ansilble)

登录jenkins界面:192.168.1.49:8180
gitlab与jenkins的自动化部署(通过webhook与ansilble)

然后大功告成!