持续集成(CI) 持续基础(continuous integration)指的是频繁的将代码集成到主干其好处:
-
快速发现错误。没完成一点更新,就集成到主干,可以快速发现错误,定位错误也比较容易
-
防止分支大幅偏离主干。如果不是经常集成,主干又不在不断更新,会导致以后集成的难度变大,甚至难以集成
持续集成强调开发人员提交了新代码后,理卷进行构建、测试。根据测试结果,可以确定新代码和原有代码是否能正确集成在一起
持续交付(CD) 持续交付(Continuous delivery)指的是频繁地将软件的新版本,交付给质量团队或者用户,以供评审。如果评审通过,代码就进入生产阶段。
持续交付可以看作持续集成的下一步。它强调的是,不管怎么更新,软件都是随时随地可以交付的。
持续交付在持续集成的进程上,将集成后的代码部署到更贴近真实运行环境的类生产环境中,如果没有问题,可以继续手动部署到生产环境中
持续部署(continuous deployment)是持续交付的下一步,指的是代码通过评审以后,自动部署到生产环境中
持续部署的目标是,代码任何时候都是可以部署的,可以进入生产的
持续部署的前提是能自动化完成测试、构建、部署等步骤。
持续集成的操作流程
提交
流程的第一步,是开发者向代码仓库中提交代码,后面的步骤都基于本地代码的第一次提交
测试(第一轮)
代码仓库对commit操作配置了钩子(hook),只要提交代码或者合并进主干,就会跑自动化测试。
-
测试的类型:
-
单元测试:针对函数或模快的测试
-
集成测试: 整体产品的某个功能的测试
-
端对端测试: 从用户界面直达数据库的全链路测试
-
第一轮至少要跑完单元测试。
构建
通过第一轮测试,代码就可以合并进主干,就算可以交付了。
交付后,就先进行构建(build),在进入第二轮测试,也就是将源码转换为可以运行的实际代码,比如安装依赖,配置各种资源等。
常用的构建工具:
-
Jenkins 开源
-
Travis 对开源项目可以免费使用
-
Codeship 对开源项目可以免费使用
-
Strider 开源
测试
构建完成,就要进行第二轮测试。如果第一轮已经涵盖了所以测试内容,第二轮可以省略,当然,构建步骤要在第一轮测试之前
第二轮是全面测试,单元测试和集成测试都会跑,如果可以也需要做端对端测试。所有测试以自动化为主,少数无法自动化完成的测试,就需要人工测试。
每个更新点都必须测试到。如果测试的覆盖率不高,到了部署阶段,可能会出现问题
部署
通过第二轮测试,当前代码就是一个可以直接部署的版本。将这个版本的所有文件打包存档,发到生产服务器。
生产服务器将打包文件,解包成为本地的一个目录,在运行路径指定的符号连接指向这个目录,然后重启新应用。
回滚
环境准备
安装jenkins前确保已经配置好JDK
JDK下载地址:https://www.oracle.com/technetwork/java/javase/downloads/jdk11-downloads-5066655.html
jenkins下载地:https://jenkins.io/
配置jdk环境
[root@localhost ~]# tar -xf jdk-8u281-linux-x64.tar.gz [root@localhost ~]# mv jdk1.8.0_281/ /usr/local/ [root@localhost ~]# vim /etc/profile .................... export JAVA_HOME=/usr/local/jdk1.8.0_291 export JRE_HOME=${JAVA_HOME}/jre export CLASSPATH=.:${JAVA_HOME}/lib/dt.JAVA_HOME/lib/tools.jar:${JRE_HOME}/lib export PATH=${JAVA_HOME}/bin:${PATH} #在/usr/bin目录中创建一个java软链接 [root@localhost ~]# ln -s /usr/local/jdk1.8.0_281/bin/java /usr/bin/java
配置Mavea环境
[root@localhost ~]# wget --no-check-certificate https://dlcdn.apache.org/maven/maven-3/3.8.4/binaries/apache-maven-3.8.4-bin.tar.gz [root@localhost ~]# tar -xf apache-maven-3.8.4-bin.tar.gz [root@localhost ~]# mv apache-maven-3.8.4 /usr/local/apache-maven [root@localhost ~]# vi /etc/profile ......................... export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar export MAVEN_HOME=/usr/local/apache-maven export PATH=$JAVA_HOME/bin:$JAVA_HOME/jre/bin:$MAVEN_HOME/bin:$PATH [root@localhost ~]# source /etc/profile
安装Jenkins
rpm包已经提前下载好了
[root@localhost ~]# yum -y install jenkins-2.277.4-1.1.noarch.rpm #启动服务 [root@localhost ~]# systemctl start jenkins
浏览器访问http://ip:8080
等待安装完插件后
进入全局工具配置配置jdk
配置maven (打包java项目中会使用到)
jenkins的初步配置就已完成