- 📢专注于分享软件测试干货内容,欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!
- 📢交流讨论:欢迎加入我们一起学习!
- 📢资源分享:耗时200+小时精选的「软件测试」资料包
- 📢 软件测试学习教程推荐:火遍全网的《软件测试》教程
Jenkins作为目前持续集成中使用较为广泛的工具,在实际生产过程中通过结合众多的插件,从而实现工程的持续构建、持续部署。
而传统构建的应用场景大多数运行在虚拟机或者独立的服务器上,在资源开销和管理维护较为复杂。相比于独立的服务器/虚拟机而言,容器不仅部署方便,且占用资源较少。
Docker作为目前作为业内最火的一个容器解决方案之一,通过将两者结合,从而实现服务的轻量化,并通过Docker管理Jenkins的资源。下面通过Docker部署Jenkins、Jenkins配置以及实例构建,讲述Jenkins的基本使用。
Docker下安装Jenkins
mkdir /home/jenkins # 新建Jenkins工作目录
docker pull jenkins/jenkins:lts # 拉取Jenkins镜像ls -nd /home/Jenkins # 查看目录归属ID
chown -R 1000:1000 /home/jenkins # 赋予权限
注:因为Jenkins容器里的用户是Jenkins,而主机用户不是Jenkins,就算是root也一样会报错:/var/jenkins_home/copy_reference_file.log: Permission denied,这个时候就需要在主机上面给主机地址赋予访问Jenkins容器的权限,Jenkins内部用的是uid 1000的user。
docekr run -dt --name jenkins -p 9090:8080 -p 50000:50000 --privileged=true -v /home/jenkins:/var/jenkins_home jenkins/jenkins:lts # 运行Jenkins容器
-privileged=true让容器具有root权限,便于进入容器
-p 9090:8080指定主机9090端口映射到Jenkins容器的8080端口(Jenkins的web访问端口)
-v /home/jenkins:/var/jenkins_home容器/var/jenkins_home路径挂载到宿主机/home/jenkins路径
启动Jenkins
浏览器输入http://ip:9090访问Jenkins首页:
密码地址
容器内:/var/jenkins_home/secrets/initialAdminPassword
宿主机:/home/jenkins/secrets/initialAdminPassword
进入插件下载页面,下载插件:
Jenkins插件下载
cd /var/jenkins_home/updates #进入容器并切换到updates目录
sed -i 's#https://updates.jenkins.io/download#https://mirrors.huaweicloud.com/jenkins#g' default.json && sed -i 's#http://www.google.com#https://www.baidu.com#g' default.json #替换url
再进入插件下载管理页面http://ip:9090/pluginManager/advanced,使用https://cdn.jsdelivr.net/gh/jenkins-zh/update-center-mirror/tsinghua/current/update-center.json替换原来的json。
配置Jenkins
修改Jenkins时间
查看宿主机系统时间:
date -R
进入Jenkins容器查看时间:
docker exec -it -u root 容器id /bin/bash # 进入容器
date -R # 查看容器内时间
echo Asia/Shanghai >/etc/timezone # 容器内创建Asia时区文件
docker cp /usr/share/zoneinfo/Asia/Shanghai 容器id:/etc/localtime # 退出容器并复制宿主机中localtime到容器内
配置Python3环境
Jenkins容器内并没有Python3环境,需要自己安装:
docker exec -it -u root 容器id /bin/bash #进入容器
cat /etc/issue #查看当前操作系统
注:Debian系统,这里使用apt-get代替yum。
apt-get update #更新apt-get#apt-get安装依赖包
apt-get -y install gcc automake autoconf libtool make
apt-get -y install make*
apt-get -y install zlib*
apt-get -y install openssl libssl-dev
apt-get install sudo# 安装Python3
cd /var/jenkins_home
mkdir python3
cd python3
wget https://www.python.org/ftp/python/3.6.8/Python-3.6.8.tgz # 获取python-3.6.8.tgz包
tar -xvf Pyhthon-3.6.8.tgz #解压
cd Python-3.6.8 # 切换到Python-3.6.8目录#执行make和make install安装
./configure --prefix=/var/jenkins_home/python3 --with-ssl
make
make install# 添加软连接
# 添加Python3软连接
ln -s /var/jenkins_home/python3/bin/python3.6 /usr/bin/python3
# 添加pip3软连接
ln -s /var/jenkins_home/python3/bin/pip3 /usr/bin/pip3# 安装所需Python库
pip3 instal requests pytest-html pytest
配置HTML报告/Allure报告
HTML报告配置
HTML Publisher插件下载,系统设置–>插件管理-可选插件,搜索:HTML Publisher。
Allure报告配置
下载allure:https://github.com/allure-framework/allure2/releases/download/2.14.0/allure-2.14.0.tgz。
docker cp /home/allure-2.14.0.tgz 容器id:/var/jenkins_home # 拷贝到容器内cd /var/jenkins_home
mkdir allure
cd /var/jenkins_home/allure
tar -xvf allure-2.14.0.tgz # 解压allure
安装Allure Jenkins Plugin插件,系统管理插件管理-可选插件,搜索Allure:
安装完成后,全局工具配置>Allure Commandline安装allure命令行工具,选择容器内路径。
简单使用-实例构建
构建job。
参数化构建
系统设置–>插件管理-可选插件,搜索Git Parameter.
安装完成后,job中勾选参数化构建过程。
注:这里是生成allure报告的配置,如果是要生成HTML报告则使用如下命令:
pytest test_demo.py --html=report/result.html --self-contained-html
构建后操作
path地方写Aallure报告的地址,与执行shell地方生成的报告地址保持一致即可。
注:上述是生成allure报告配置,生成HTML配置如下:
注:HTML添加css样式。
安装Startup Trigger和Groovy插件
在Job配置页面构建触发器勾选Build when job nodes start
增加构建步骤Execute system Groovy script
配置成功
配置成功后,参数化构建:
控制台输出
Allure报告查看
HTML报告查看
最后如果你想学习提升找不到资料,没人答疑解惑时,请及时加入群,里面有各种测试开发资料和技术可以一起交流哦:
感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:
这些资料,对于从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。希望对大家有所帮助……