JenKins

官网 jenkins.io Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开 放易用的软件平台,使软件的持续集成变成可能。

1.安装部署

关闭selinux和防火墙
内存2G 50G+硬盘

#官方下载或上传安装包
[root@db02 ~]# rpm -ivh jdk-8u181-linux-x64.rpm 
[root@db02 ~]# rpm -ivh jenkins-2.176.1-1.1.noarch.rpm
[root@db02 ~]# systemctl start jenkins
[root@db02 /var/lib/jenkins]# vim /etc/sysconfig/jenkins
JENKINS_USER="root"

jenkins主要的目录
/usr/lib/jenkins/:jenkins安装目录,WAR包会放在这里 /etc/sysconfig/jenkins:jenkins配置文件,“端口”,“JENKINS_HOME”等都可以在这里配置
/var/lib/jenkins/:默认的JENKINS_HOME
/var/log/jenkins/jenkins.log:Jenkins日志文件

2.web页面配置

image.png

image.png

image.png
  • 更改登录密码


    image.png
  • 更改插件更新源


    image.png

    image.png
  • 上传插件包(包中包括中文)
#删除插件目录
[root@db02 /var/lib/jenkins]# rm -rf plugins/
#上传已经下载好的插件压缩包解压
[root@db02 /var/lib/jenkins]# tar xf jenkins_plugins.tar.gz 
[root@db02 /var/lib/jenkins]# systemctl restart jenkins

3.项目测试


image.png

image.png

image.png

观察现象:
1、jenkins 默认工作目录/var/lib/jenkins/workspace/
2、当前有新项目时发现会在/var/lib/jenkins/workspace/生成一个项目名的文件夹

[root@db02 /var/lib/jenkins/workspace/freestyle-job]# pwd
/var/lib/jenkins/workspace/freestyle-job
[root@db02 /var/lib/jenkins/workspace/freestyle-job]# ll
total 0
-rw-r--r-- 1 root root 0 Mar 25 19:55 test.txt

3.结合gitlab手动上线代码V1.0

image.png
  • 采用导入项目的方式(测试项目可以去码云找)


    image.png

    image.png

    image.png
# 新开台虚拟机安装nginx
yum install nginx -y
systemctl start nginx
cd /usr/share/nginx/html 
mv * /tmp
git clone http://10.0.0.51/test/monitor.git
#用户和密码为gitlab仓库
mv monitor/* .
image.png

4.jenkins手动构建代码上线V1.0

image.png

image.png

image.png

image.png

image.png

image.png

image.png
  • jenkins服务编写脚本
#!/bin/sh
COOE_DIR=$WORKSPACE
WEB_DIR=/usr/share/nginx
echo $BUILD_ID
TAR(){
    cd $COOE_DIR && tar zcf /opt/${BUILD_ID}-web.tar.gz ./*
}

SCP(){
    scp /opt/${BUILD_ID}-web.tar.gz 10.0.0.7:${WEB_DIR} 
}

XF(){
    ssh 10.0.0.7 "mkdir ${WEB_DIR}/${BUILD_ID}-web"
    ssh 10.0.0.7 "cd ${WEB_DIR} && tar xf ${BUILD_ID}-web.tar.gz -C ${BUILD_ID}-web"
}

LN(){
    ssh 10.0.0.7 "cd ${WEB_DIR} && rm -rf html && ln -s ${BUILD_ID}-web html && rm -f ${BUILD_ID}-web.tar.gz"
}

main(){
    TAR
    SCP
    XF
    LN
}
main
image.png
  • 检查web服务器


    image.png
  • 检查web页面是否访问正常


    image.png

5.jenkins钩子的使用。(推送代码自动触发脚本)V2.0

image.png
  • 在Gitlab页面配置自动触发的秘钥


    image.png
  • 成功后测试下


    image.png
  • 发现jenkins配置成功自动执行了


    image.png

6.代码质量检测SonarQube

1、SonarQube基础java开发,需安装openJDK8版本
2、SonarQube需要MySQL数据库,至少5.6版本以上
3.SonarQube的小型实例至少4G内存,如果大型实例需要16G内存

  • 安装软件
[root@sonarqube ~]# yum -y install git java unzip wget
  • 安装数据库

下载mysqlyum源 https://dev.mysql.com/downloads/repo/yum/

image.png

image.png

wget https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm
[root@sonarqube ~]# rpm -ivh mysql80-community-release-el7-3.noarch.rpm
[root@sonarqube ~]# vim /etc/yum.repos.d/mysql-community.repo
# 调整各版本对应的enabled=1,根据想安装版本更改【0、1】0:关闭、1:打开
# 更改默认安装版本为5.6 enabled=1
#下一步安装MySQL5.6
yum -y install mysql-community-server
service mysqld start
# 检查3306端口
mysqladmin -uroot password 123456
mysql -uroot -p123456
[root@sonarqube ~]# mysql -uroot -p123456 -e "create database sonar default character set utf8"
[root@sonarqube ~]# mysql -uroot -p123456 -e "show databases"
  • sonarqube安装

下载sonar 并使用sonar用户启动 https://www.sonarqube.org/downloads/

# 上传下载好的sonarqube包
unzip sonarqube-8.2.0.32929.zip -d /usr/local/
cd /usr/local/
ln -s sonarqube-8.2.0.32929 sonarqube
useradd sonar
chown -R sonar.sonar /usr/local/sonarqube*
# 修改配置文件(连接mysql数据库)
vim /usr/local/sonarqube/conf/sonar.properties
sonar.jdbc.username=root
sonar.jdbc.password=123456
sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance&useSSL=false
# 启动sonarqube
[root@sonarqube /usr/local/sonarqube]# su - sonar -c "/usr/local/sonarqube/bin/linux-x86-64/sonar.sh" 
Usage: /usr/local/sonarqube/bin/linux-x86-64/sonar.sh { console | start | stop | restart | status | dump }
[root@sonarqube /usr/local/sonarqube]# su - sonar -c "/usr/local/sonarqube/bin/linux-x86-64/sonar.sh start" 
# 检查9000端口
  • sonarqube web 页面设置


    image.png

    image.png

    image.png

    image.png

    image.png

    image.png
  • 插件下载方法


    image.png
  • 上传的本地插件包
[root@sonarqube /usr/local/sonarqube-7.0/extensions]# mv plugins plugins_back
tar xf sonar_plugins.tar.gz
su - sonar -c "/usr/local/sonarqube/bin/linux-x86-64/sonar.sh restart"
  • 手动上传一段测试代码(在jenkins服务器操作)
# 上传测试代码并解压
unzip sonar-scanner-cli-4.0.0.1744-linux.zip -d /usr/local/
cd /usr/local/
ln -s sonar-scanner-4.0.0.1744-linux sonar-scanner
vim /etc/profile
export PATH="/usr/local/sonar-scanner/bin:$PATH"
source /etc/profile
cd /var/lib/jenkins/workspace/freestyle-job
# 输入之前记录sonarqube教学html代码
sonar-scanner \
  -Dsonar.projectKey=html \
  -Dsonar.sources=. \
  -Dsonar.host.url=http://10.0.0.8:9000 \
  -Dsonar.login=cfc117e212cd4a4985d11880b584eecc1474dce6
image.png

7 jenkins上配置Sonarqube服务端

系统管理->系统设置->sonarQube 告诉jenkins SonarQubeServer服务端地址


image.png

image.png

image.png

image.png

image.png
  • jenkins 添加sonarqube执行命令

系统管理→全局工具配置→SonarQube Scanner→取消Install automatically


image.png

image.png

image.png

修改一端代码并上传到,远程Gitlab仓库。观察sonarqube上是否有新代码上线


image.png
  • jenkins 集成微信通知
  1. 注册微信企业公众号 搜索微信公众平台->注册->选择企业微信
image.png

选择完成后把下面信息进行完善->使用自己微信扫描二维码进行管理后-点注册


image.png

注册成功登陆后点击应用管理->创建应用


image.png

上次一张图片->填写应用名称-可见范围->创建应用-保存好agentld和secret写入py脚本
image.png

更改py脚本内对应的内容-touser为账号名称
Corpid为企业ID 这里只把corpid写入对应的位置
上传脚本jenkins_notify.py并修改配置


image.png

image.png
  • web部署触发微信插件
#jenkins进入到项目中->构建环境多了Add Changelog Information to #Environment->点击选择 
#Entry Format中添加 
%3$s(at %4$s via %1$s),参数分别为ChangeLog内容,时间,提交人。
#Date Format中添加 
yyyy‐MM‐dd HH:mm:ss 就是时间格式。
image.png

image.png
echo ${SCM_CHANGELOG} > /tmp/${JOB_NAME}_change.log
python /server/scripts/jenkins_notify.py ${BUILD_URL} /tmp/${JOB_NAME}_change.log ${JOB_NAME} 
rm ‐fv /tmp/${JOB_NAME}_change.log
  • 安装pip模块
yum -y install python2-pip
pip install requests
  • 此时上一段修改后的代码到远程仓库gitlab


    image.png

8.测试环境流程图

image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
禁止转载,如需转载请通过简信或评论联系作者。

推荐阅读更多精彩内容