Docker搭建Jenkins持续集成

注意

我用的是centos7 arm版的

前提条件

Docker要求Centos系统内核的版本高于3.10,通过以下命令验证

uname -r

图片

安装Docker

检查并清楚系统残余项,并安装Docker环境

yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine

图片

安装下载Docker依赖的工具

sudo yum install -y yum-utils device-mapper-persistent-data lvm2

图片

添加清华软件源

后面每个软件都会先从阿里云下载,如果仓库没有,则回去docker.hub下载。

# 清华
sudo yum-config-manager --add-repo https://mirrors.tuna.tsinghua.edu.cn/docker-ce/linux/centos/docker-ce.repo

图片

更新yum缓存

为了保证能更新和下载需要的服务

sudo yum makecache

图片

安装Docker(CE-社区版)

会较慢,耐心等待

sudo yum -y install docker-ce

图片

启动Docker

systemctl start docker

Docker设置开机自启

systemctl enable docker

下载Jenkins镜像

docker pull jenkins/jenkins:2.346.3

该版本为jdk11

挂载目录

mkdir -p /home/dajun/jenkins_node

# 授权
chmod -R 777 /home/dajun/jenkins_node

启动镜像

docker run -u root -d -p 8080:8080 --name jenkins1 -e LANG=C.UTF-8 -v /home/dajun/jenkins_node:/var/jenkins_home  jenkins/jenkins:2.346.3

访问Jenkins

注意写你的ip地址

ip:8080

图片

进入容器

docker exec -it -u root jenkins1 bash

容器内安装Python3环境

我在容器内查看系统是debian的,所以使用apt命令。centos用的是yum命令

# 安装wget。如果是centos的,使用yum install wget安装
apt-get install wget

# 进入jenkins_home目录
cd /var/jenkins_home/

# 创建python存放路径
mkdir python3
cd python3/


# 下载python3
wget  http://npm.taobao.org/mirrors/python/3.9.10/Python-3.9.10.tgz

# 解压文件目录
tar -zxvf Python-3.9.10.tgz

# 查看解压后的文件
ls

# 更改解压后文件包名(可选项)
mv Python-3.9.10 py3.9.10

make编译安装

时间比较长

# 分别执行以下4条命令

cd py3.9.10

./configure --prefix=/var/jenkins_home/python3 --with-ssl

make


make install

添加软连接

添加python3软链接
ln -s /var/jenkins_home/python3/bin/python3.9 /usr/bin/python3

添加pip3软链接
ln -s /var/jenkins_home/python3/bin/pip3 /usr/bin/pip3

python3命令就可以进入python了

图片

安装allure

# 下载
wget https://github.com/allure-framework/allure2/releases/download/2.22.1/allure-2.22.1.zip

# 解压
unzip allure-2.22.1.zip

# 授权
mv allure-2.22.1 allure
chmod -R 777 allure

配置allure和Python环境变量

# 配置环境变量
cat >> /root/.bashrc << "EOF" 
export PATH=/var/jenkins_home/allure/bin:$PATH 
export PATH=/var/jenkins_home/python3/bin:$PATH 
EOF
# 配置文件生效
source /root/.bashrc
allure --version
python3 --version

图片

配置JDK环境变量

cat >> /root/.bashrc<< "EOF" 
export PATH=$JAVA_HOME/bin:$PATH 
EOF
source /root/.bashrc
java --version

图片

配置Jenkins

配置镜像加速

将url地址改为下面的,不然后面安装jenkins插件很慢 https://mirrors.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json

cd /var/jenkins_home

vi hudson.model.UpdateCenter.xml

图片

查看登录密码,登录Jenkins

cat /var/jenkins_home/secrets/initialAdminPassword

图片

图片

选择推荐插件安装

耐心等待,有安装失败的不用管,直接继续

图片

图片

图片

安装Gitee、Allure插件

我的代码在gitee存放

图片

图片

安装完插件需要使用docker restart命令重启jenkins容器

Gitee配置

图片

找到Gitee相关配置

图片

下面的令牌去gitee生成,然后再重新填写。

图片

浏览器访问该地址,生成新令牌:https://gitee.com/profile/personal_access_tokens

图片

图片

图片

图片

图片

新建项目,构建项目

图片

图片

图片

图片

图片

配置gitee webhook,上图中的URL是配置webhook的地址

图片

图片

点击生成密码,复制

图片

进入gitee的WebHooks界面,添加WebHook

图片

图片

点击添加后,这个报错是因为我是局域网,百度搜索IP查询,将上面的IP重新换为百度查询的公网IP,再次点击添加就好了。但是要注意换地方后这个IP会变的,可能需要重新在这里配置。

图片

点击保存

图片

构建一次,查看项目路径

图片

图片

图片

图片

docker进入到这个路径,然后安装依赖包

cd /var/jenkins_home/workspace/api-auto-httprunner

pip3 install  -r requirements.txt -i https://mirrors.aliyun.com/pypi/simple/

# 如果找不到pip命令,安装下
apt -y install python3-pip

图片

# 注意如果你想手动在服务器运行代码,需要指定你的Python环境地址安装库
pip3 install --target=/var/jenkins_home/python3/lib/python3.9/site-packages -r requirements.txt -i https://mirrors.aliyun.com/pypi/simple/

注意:--target指定的是之前创建Python环境的目录,我们需要将库安装在此目录下。因为我们的Python环境使用的是该路径,如果只是执行pip3 install的话,会将库装在全局环境,但我们的Python环境又使用的不是全局环境,执行Python代码时会报错,找不到库。

jenkins配置shell,执行程序

图片

图片

项目中配置Allure

图片

report/tmp是allure生成的json文件路径

图片

report/html是allure生成的html报告路径

图片

注意上面的两个path路径要和项目中的保持一致

图片

全局配置Allure Commandline

  • 在系统管理--全局工具配置中配置

  • 点击应用、点击保存

图片

再次构建项目,查看Allure报告

图片

图片

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

missterzy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值