一、 持续集成简介
1.介绍
1、将代码上传到服务器,然后解压
2、将代码上传到服务器中,然后通过软连接的方式部署
无法实现批量部署,无法实现批量回滚,更无法实现批量测试。
cd /opt/
mkdir deploy
rz index.zip
unzip index.zip
rm -rf index.zip
yum install lrzsz -y
mv index.html /usr/share/nginx/html/
访问
10.0.0.8
# 批量部署,批量测试
源代码管理
协同开发
代码管理工具
自动集成(java、golang)、自动部署、自动测试: DevOps
代码:
编译型语言:需要编译,后运行
脚本型语言:直接运行
工具:
实现自动集成、自动部署:Jenkins
代码管理:git ---> gitlab、github、gitee
2. 什么是软件开发生命周期?
软件开发生命周期又叫做SDLC(Software Development Life Cycle),它是集合了计划、开发、测试 和部署过程的集合。
1. 需求分析
这是生命周期的第一阶段,根据项目需求,团队执行一个可行性计划的分析。项目需求可能是公司内部或者客户提出的。这阶段主要是对信息的收集,也有可能是对现有项目的改善和重新做一个新的项目。还要分析项目的预算多长,可以从哪方面受益及布局,这也是项目创建的目标。
2. 设计
第二阶段就是设计阶段,系统架构和满意状态(就是要做成什么样子,有什么功能),和创建一个项目计划。计划可以使用图表,布局设计或者文者的方式呈现。
3. 实现 ---> 写配置清单,构建容器,部署一个测试环境
第三阶段就是实现阶段,项目经理创建和分配工作给开者,开发者根据任务和在设计阶段定义的目标进行开发代码。依据项目的大小和复杂程度,可以需要数月或更长时间才能完成。
4. 测试
测试人员进行代码测试 ,包括功能测试、代码测试、压力测试等。
5. 进化
最后进阶段就是对产品不断的进化改进和维护阶段,根据用户的使用情况,可能需要对某功能进行修改,bug修复,功能增加等。
3.敏捷开发
敏捷开发(Agile Development) 的核心是迭代开发(Iterative Development) 与 增量开发 (Incremental Development)
3.1迭代开发
对于大型软件项目,传统的开发方式是采用一个大周期(比如一年)进行开发,整个过程就是一次"大 开发";迭代开发的方式则不一样,它将开发过程拆分成多个小周期,即一次"大开发"变成多次"小开 发",每次小开发都是同样的流程,所以看上去就好像重复在做同样的步骤。
3.2增量开发
软件的每个版本,都会新增一个用户可以感知的完整功能。也就是说,按照新增功能来划分迭代。
3.3敏捷开发如何迭代
虽然敏捷开发将软件开发分成多个迭代,但是也要求,每次迭代都是一个完整的软件开发周期,必须按
照软件工程的方法论,进行正规的流程管理。
4.持续集成
持续集成( Continuous integration , 简称 CI )指的是,频繁地(一天多次)将代码集成到主干。 持续集成的目的,就是让产品可以快速迭代,同时还能保持高质量。它的核心措施是,代码集成到主干之前,必须通过自动化测试。只要有一个测试用例失败,就不能集成。通过持续集成,团队可以快速的从一个功能到另一个功能,简而言之,敏捷软件开发很大一部分都要归功于持续集成。在持续集成的过程当中主要包括以下步骤:提交、测试、构建(容器需要构建, 编译型语言编译)、部署及回滚。
4.1持续集成要素
1.一个自动构建过程,从检出代码、编译构建、运行测试、结果记录、测试统计等都是自动完成的,无需人工干预。
2. 一个代码存储库,即需要版本控制软件来保障代码的可维护性,同时作为构建过程的素材库,一般使用SVN或Git。
3. 一个持续集成服务器, Jenkins 就是一个配置简单和使用方便的持续集成服务器。
4.2持续集成有什么优点?
1、降低风险,由于持续集成不断去构建,编译和测试,可以很早期发现问题,所以修复的代价就少
2、对系统健康持续检查,减少发布风险带来的问题
3、减少重复性工作
4、持续部署,提供可部署单元包
5、持续交付可供使用的版本
6、增强团队信心
二、git —> 代码管理工具
代码管理工具:git
Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而是一个开放源码的版本控制软件。Git 与常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版本库的方式,不必有服务器端软件支持。
git架构图
1.安装Git
[root@web02 ~]# yum install git -y
[root@web02 ~]