@Jenkins持续集成及gitlab仓库管理

一、Jenkins持续集成

软件开发生命周期又叫做SDLC(Software Development Life Cycle),它是集合了计划、开发、测试 和部署过程的集合

1、软件开发生命周期

1)#需求分析
这是生命周期的第一阶段,根据项目需求,团队执行一个可行性计划的分析。项目需求可能是公司内部或者客户提出的。这阶段主要是对信息的收集,也有可能是对现有项目的改善和重新做一个新的项目。还要分析项目的预算多长,可以从哪方面受益及布局,这也是项目创建的目标。



2)#设计
第二阶段就是设计阶段,系统架构和满意状态(就是要做成什么样子,有什么功能),和创建一个项目计划。计划可以使用图表,布局设计或者文者的方式呈现。



3)#实现
第三阶段就是实现阶段,项目经理创建和分配工作给开者,开发者根据任务和在设计阶段定义的目标进行开发代码。依据项目的大小和复杂程度,可以需要数月或更长时间才能完成。



4)#测试
测试人员进行代码测试 ,包括功能测试、代码测试、压力测试等。



5)#进化
最后进阶段就是对产品不断的进化改进和维护阶段,根据用户的使用情况,可能需要对某功能进行修改,bug修复,功能增加等

2、敏捷开发

敏捷开发(Agile Development) 的核心是迭代开发(Iterative Development) 与 增量开发 (Incremental Development)

#迭代开发
   对于大型软件项目,传统的开发方式是采用一个大周期(比如一年)进行开发,整个过程就是一次"大 开发";迭代开发的方式则不一样,它将开发过程拆分成多个小周期,即一次"大开发"变成多次"小开 发",每次小开发都是同样的流程,所以看上去就好像重复在做同样的步骤
    
   示列:举例来说,SpaceX 公司想造一个大推力火箭,将人类送到火星。但是,它不是一开始就造大火箭,而
是先造一个最简陋的小火箭 Falcon 1。结果,第一次发射就爆炸了,直到第四次发射,才成功进入轨
道。然后,开发了中型火箭 Falcon 9,九年中发射了70次。最后,才开发 Falcon 重型火箭。如果
SpaceX 不采用迭代开发,它可能直到现在还无法上天。
   
   
   
   
   
   
#增量开发
软件的每个版本,都会新增一个用户可以感知的完整功能。也就是说,按照新增功能来划分迭代  
   
   列如:举例来说,房产公司开发一个10栋楼的小区。如果采用增量开发的模式,该公司第一个迭代就是交付一
号楼,第二个迭代交付二号楼......每个迭代都是完成一栋完整的楼。而不是第一个迭代挖好10栋楼的地
基,第二个迭代建好每栋楼的骨架,第三个迭代架设屋顶......
 
#敏捷开发如何迭代:
  虽然敏捷开发将软件开发分成多个迭代,但是也要求,每次迭代都是一个完整的软件开发周期,必须按照软件工程的方法论,进行正规的流程管理
  
  
  
  
  
  
#敏捷开发有什么好处:

1)早期交付
   
   示列:
      敏捷开发的第一个好处,就是早期交付,从而大大降低成本。 还是以上一节的房产公司为例,如果按照
传统的"瀑布开发模式",先挖10栋楼的地基、再盖骨架、然后架设屋顶,每个阶段都等到前一个阶段完
成后开始,可能需要两年才能一次性交付10栋楼。也就是说,如果不考虑预售,该项目必须等到两年后
才能回款。 敏捷开发是六个月后交付一号楼,后面每两个月交付一栋楼。因此,半年就能回款10%,后
面每个月都会有现金流,资金压力就大大减轻了



2)降低风险
    
    示列:
       敏捷开发的第二个好处是,及时了解市场需求,降低产品不适用的风险。 请想一想,哪一种情况损失比
较小:10栋楼都造好以后,才发现卖不出去,还是造好第一栋楼,就发现卖不出去,从而改进或停建后
面9栋楼
  

3、持续集成

持续集成( Continuous integration , 简称 CI )指的是,频繁地(一天多次)将代码集成到主干

#持续集成的目的:
   让产品可以快速迭代,同时还能保持高质量。它的核心措施是,代码集成到主干之前,必须通过自动化测试。只要有一个测试用例失败,就不能集成。


#特点:
   通过持续集成, 团队可以快速的从一个功能到另一个功能,简而言之,敏捷软件开发很大一部分都要归功于持续集成

【持续集成的流程】

在这里插入图片描述

#根据持续集成的设计,代码从提交到生产,整个过程有以下几步:

1)提交
  流程的第一步,是开发者向代码仓库提交代码。所有后面的步骤都始于本地代码的一次提交(commit)
  
  
  
2)测试(第一轮)
  代码仓库对commit操作配置了钩子(hook),只要提交代码或者合并进主干,就会跑自动化测试





3)构建
  通过第一轮测试,代码就可以合并进主干,就算可以交付了
  交付后,就先进行构建(build),再进入第二轮测试。
  所谓构建,指的是将源码转换为可以运行的实际代码,比如安装依赖,配置各种资源(样式表、JS脚本、图片)等
  
  
  
4)测试(第二轮)
  构建完成,就要进行第二轮测试。如果第一轮已经涵盖了所有测试内容,第二轮可以省略,当然,这时构建步骤也要移到第一轮测试前面
  
  
  
  
5)部署
  过了第二轮测试,当前代码就是一个可以直接部署的版本(artifact)。将这个版本的所有文件打包(tar filename.tar * )存档,发到生产服务器
  
  
  
6)回滚
  一旦当前版本发生问题,就要回滚到上一个版本的构建结果。最简单的做法就是修改一下符号链接,指向上一个版本的目录

【持续集成的组成要素】

1)一个自动构建过程, 从检出代码、 编译构建、 运行测试、 结果记录、 测试统计等都是自动完成
的, 无需人工干预。


2)一个代码存储库,即需要版本控制软件来保障代码的可维护性,同时作为构建过程的素材库,一般
使用SVN或Git


3)一个持续集成服务器, Jenkins 就是一个配置简单和使用方便的持续集成服务器

在这里插入图片描述

【持续集成的好处】

1)降低风险,由于持续集成不断去构建,编译和测试,可以很早期发现问题,所以修复的代价就少;

2)对系统健康持续检查,减少发布风险带来的问题;

3)减少重复性工作;

4)持续部署,提供可部署单元包;

5)持续交付可供使用的版本;

6)增强团队信心;

二、GitLab私有代码仓库

在这里插入图片描述

【官网】

1)GitLab 是一个用于仓库管理系统的开源项目,使用Git作为代码管理工具,并在此基础上搭建起来的

web服务。

2)GitLab和GitHub一样属于第三方基于Git开发的作品,免费且开源(基于MIT协议),与Github类似,

可以注册用户,任意提交你的代码,添加SSHKey等等。不同的是,GitLab****是可以部署到自己的服务器 上,数据库等一切信息都掌握在自己手上,适合团队内部协作开发,你总不可能把团队内部的智慧总放

在别人的服务器上吧?简单来说可把GitLab看作个人版的GitHub

1、Git

Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而是一个开放源码的版本控制软件。Git 与常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版本库的方式,不必有服务器端软件支持

【git的优点】

1)git是分布式的,svn不是


2)git分布式本地就可以用,可以随便保存各种历史痕迹,不用担心污染服务器,连不上服务器也能提交代码、查看log。


3)GIT分支和SVN的分支不同,分支在SVN中实际上是版本库中的一份copy,而git一个仓库是一个快照,所以git 切换、合并分支等操作更快速。


4)git有一个强大的代码仓库管理系统 , gitlab可以很方便的管理权限、代码review,创建、管理projec

【git安装】

################################# 安装步骤   ######################################

#git的安装
[root@jenkins-gitlab ~]# yum install git -y




#git安装测试
[root@jenkins-gitlab ~]# git version
git version 1.8.3.1




#git用户配置
[root@jenkins-gitlab ~]# git config --global user.name "hzl" 
[root@jenkins-gitlab ~]# git config --global user.email "hzl@123.com"




#查看git的用户配置
[root@jenkins-gitlab ~]# git config -l
user.name=hzl
user.email=hzl@123.com

2、仓库

创建新目录,这个目录中的所有文件被git管理起来,作为本地git仓库。仓库中的每个文件的改动都由git跟踪

创建本地仓库

[root@jenkins-gitlab ~]# mkdir /hzl
[root@jenkins-gitlab ~]# cd /hzl/
[root@jenkins-gitlab /hzl]# 
[root@jenkins-gitlab /hzl]# git init   #初始化新的仓库作为本地git管理仓库
初始化空的 Git 版本库于 /hzl/.git/
[root@jenkins-gitlab /hzl]# ll -a
总用量 0
drwxr-xr-x.  3 root root  18 813 22:18 .
dr-xr-xr-x. 19 root root 270 813 17:49 ..
drwxr-xr-x   7 root root 119 813 22:18 .git   #git管理仓库文件

链接远程仓库

#指定远程链接地址
[root@jenkins-gitlab /hzl]# git remote add origin https://github.com/hzl888/jenkins.git            



#查看远程连接
[root@jenkins-gitlab /hzl]# git remote -v         
origin	https://github.com/hzl888/jenkins.git (fetch)     
origin	https://github.com/hzl888/jenkins.git (push)



#删除远程连接          
[root@jenkins-gitlab /hzl]# git remote rm origin   

从远程仓库获取CODE

#远程仓库获取
[root@jenkins-gitlab /hzl]# git clone https://github.com/hzl888/jenkins.git
正克隆到 'jenkins'...
error: RPC failed; result=35, HTTP code = 0
fatal: The remote end hung up unexpectedly
[root@jenkins-gitlab /hzl]# ll
总用量 4
-rw-r--r-- 1 root root 10 8月  13 22:34 README.md





#当本地已经有了代码仓库,现在需要同步远程仓库内容
git pull origin master

将本地文件推送到op远程

#查看工作目录的状态
[root@jenkins-gitlab /hzl]# git status
# 位于分支 main
无文件要提交,干净的工作区



#将文件添加到暂存区
git add <file>
[root@jenkins-gitlab /hzl]# git add README.md 



#提交更改,添加备注信息(此时将暂存区的信息提交到本地仓库)
[root@jenkins-gitlab /hzl]# git commit -m "commnet"
# 位于分支 main
无文件要提交,干净的工作区





#将本地仓库的文件push到远程仓库(若 push 不成功,可加 -f 进行强推操作)
[root@jenkins-gitlab /hzl]# git push origin main -f
Username for 'https://github.com': hzl888
Password for 'https://hzl888@github.com': 
Counting objects: 3, done.
Writing objects: 100% (3/3), 203 bytes | 0 bytes/s, done.
Total 3 (delta 0), reused 0 (delta 0)
  

提交与修改

#添加文件到仓库
git add


#查看状态
git status	

查看文件差异变化

#查看当前全部
git diff

#查看某一个文件
git diff <file>

分支

# 查看分支
[root@jenkins-gitlab /hzl]# git branch 
* main




# 查看远程分支
[root@jenkins-gitlab /hzl]# git branch  -a
* main




# 创建分支
[root@jenkins-gitlab /hzl]# git branch test
[root@jenkins-gitlab /hzl]# git branch
* main
  test





# 切换分支
[root@jenkins-gitlab /hzl]# git checkout test
A	hzl.yaml
切换到分支 'test'
[root@jenkins-gitlab /hzl]# git branch 
  main
* test






# 打标签
[root@instance-gvpb80ao test]# git tag -a v1.1.5-stable -m "做了很多事" 
[root@instance-gvpb80ao test]# git tag
v1.1.5-stable



# 查看标签内容
[root@instance-gvpb80ao test]# git show v1.1.5-stable
tag v1.1.5-stable
Tagger: Your Name <you@example.com>
Date:   Mon Dec 21 16:41:12 2020 +0800

做了很多事

commit 3fb292cfade47c2c6f58ceb23d0dfd3cb14217d1
Author: Your Name <you@example.com>
Date:   Mon Dec 21 16:30:46 2020 +0800

    init

diff --git a/demo.php b/demo.php
new file mode 100644
index 0000000..b3d9bbc
--- /dev/null
+++ b/demo.php
@@ -0,0 +1 @@
+<?php
diff --git a/index.php b/index.php
index e69de29..12dbfc1 100644
--- a/index.php
+++ b/index.php
@@ -0,0 +1,3 @@
+<?php
+
+echo "Oldboy"




# 按照分支拉取代码
git clone -b [分支名称] [git链接]




# 按照标签拉取代码
git clone [git链接]
git tag [tag_name]

3、远程仓库

在这里插入图片描述

三、gitlab远程仓库

1、远程仓库安装

#gitlab安装依赖包
[root@jenkins-gitlab /hzl]# yum -y install policycoreutils openssh-server openssh-clients postfix   

2、启动ssh服务&设置为开机启动

[root@jenkins-gitlab /hzl]#systemctl enable sshd && sudo systemctl start sshd

3、关闭防火墙

[root@jenkins-gitlab ~]#systemctl disable firewalld
# 关闭selinux
[root@jenkins-gitlab ~]#sed -i 's#enforcing#disabled#g' /etc/sysconfig/selinux
# 临时关闭
[root@jenkins-gitlab ~]#setenforce 0

4、下载gitlab包,并且安装

#下载
[root@jenkins-gitlab ~]# wget https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el7/gitlab-ce-13.0.3-ce.0.el7.x86_64.rpm




#安装:
rpm -i gitlab-ce-13.0.3-ce.0.el7.x86_64.rpm
yum install gitlab-ce-13.0.3-ce.0.el7.x86_64.rpm -y

5、 修改gitlab配置

vi /etc/gitlab/gitlab.rb

#修改gitlab访问地址和端口,默认为80,我们改为82 

external_url:'http://192.168.66.100:82'
nginx['listen_port'] = 82 

6、重载配置及启动gitlab

gitlab-ctl reconfifigure :刷新配置

gitlab-ctl restart:重启github

安装完成如下所示:

在这里插入图片描述

在这里插入图片描述

四、github使用(添加组、创建用户、创建项目)

1、创建组

使用管理员 root 创建组,一个组里面可以有多个项目分支,可以将开发添加到组里面进行设置权限,

不同的组就是公司不同的开发项目或者服务模块,不同的组添加不同的开发即可实现对开发设置权限的 管理

在这里插入图片描述

![在这里插入图片描述](https://img-blog.csdnimg.cn/ad787e2bd02f418880cb618f52298cbb.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl81NTk3Mjc4MQ==,size_16,color_FFFFFF,t_70#pic_center)

2、创建用户

创建用户的时候,可以选择Regular或Admin类型

创建完用户后,立即修改密码

在这里插入图片描述

在这里插入图片描述

3、将用户添加到组中

选择某个用户组,进行Members管理组的成员

在这里插入图片描述

在这里插入图片描述

#添加用户有5种角色
1)Guest:可以创建issue、发表评论,不能读写版本库

2)Reporter:可以克隆代码,不能提交,QA、PM 可以赋予这个权限 

3)Developer:可以克隆代码、开发、提交、push,普通开发可以赋予这个权限 

4)Maintainer:可以创建项目、添加tag、保护分支、添加项目成员、编辑项目,核心开发可以赋予这个 权限 

5)Owner:可以设置项目访问权限 - Visibility Level、删除项目、迁移项目、管理组成员,开发组组 长可以赋予这个权限

4、在用户组中创建项目

以刚才创建的新用户身份登录到Gitlab,然后在用户组中创建新的项目

在这里插入图片描述

5、测试gitlab

略 🐱‍🏍🐱‍🏍🐱‍🏍

六、jenkins使用😎

【jenkins安装xiangjie】

posted @ 2021-08-14 00:43  ଲ一笑奈&何  阅读(123)  评论(0编辑  收藏  举报