请选择 进入手机版 | 继续访问电脑版

ITIL,DevOps,ITSS,ITSM,IT运维管理-ITIL先锋论坛

 找回密码
 立即注册

扫描二维码登录本站

QQ登录

只需一步,快速开始

查看: 673|回复: 0

使用开源工具构建 DevOps 管道的初学者指南

[复制链接]
发表于 2021-12-24 23:39:19 | 显示全部楼层 |阅读模式
本帖最后由 FYIRH 于 2021-12-24 23:44 编辑 / i: q% I! R; G: c
0 ~) b' Y* j. b- [. |# j
DevOps已成为修复缓慢、孤立或不正常运行的软件开发流程的默认答案。但是,当您不熟悉DevOps并且不确定从哪里开始时,这并不意味着什么。本文探讨了什么是 DevOps 管道,并提供了五步创建过程。虽然本教程并不全面,但它应该为您提供基础,以供以后入门和扩展。但是首先,是一个故事。
3 b# r  K5 h9 Y! ?7 Y6 ~
我的 DevOps 旅程
我曾经在云团队工作,开发了基础架构即服务(IaaS)Web应用程序来管理云基础架构,但是我一直对找出使开发流程更高效并带来更多收益的方法感兴趣。给开发团队带来积极的文化变革。我在云架构和基础架构工程首席技术官格雷格·拉文德(Greg Lavender)推荐的一本书《凤凰计划》中找到了答案。该书在解释DevOps原理时读起来像小说。
! T( h. ]& c  T3 s! O
本书背面的表格显示了不同公司部署到发布环境的频率:6 G* p1 ]8 u9 {0 w

) `$ I6 o9 b. Q7 _! h/ z
! ^' s$ q: C# i# [
粘贴上传202112242333136034..png

0 u" a  C$ T' Q# \+ W$ m/ ]  r
, x# X/ u" c, P; H

$ [" T6 d/ h: E: p9 c5 |6 ]亚马逊,谷歌和Netflix的频率速率怎么可能?这是因为这些公司已经找到了如何制作接近完美的DevOps管道的方法。0 t- B5 B+ P6 S% g* g
* ]4 o/ t# X* J' D% w( J

2 ]! C% ]8 P; l( u! X$ D( U9 M* m我们在实施 DevOps 之前,情况肯定不是这样。那时,我的团队拥有不同的临时环境,但是到开发服务器的部署是手动的。所有开发人员都只能访问一台基于IBM WebSphere Application Server Community Edition的开发服务器。问题是,每当多个用户同时尝试进行部署时,服务器就会关闭,因此开发人员必须在要进行部署的时候互相告知对方,这是很痛苦的。此外,还存在代码测试覆盖率低,手动部署过程繁琐以及无法通过定义的任务或用户故事来跟踪代码部署的问题。
# }! P5 c, S9 ]# N, N- Y0 Q, C
* S" t0 K4 ~3 R# r

; x- I5 f) v) i我意识到必须做些事情,然后我找到了一个有同样想法的同事。我们决定合作建立一个初始的DevOps管道-当我在Jenkins工作时,他建立了虚拟机和Tomcat应用程序服务器,并与Atlassian Jira和BitBucket集成在一起,并进行了代码测试。这个辅助项目非常成功:我们几乎完全自动化了开发流程,在开发服务器上实现了近100%的正常运行时间,我们可以跟踪和改善代码测试的覆盖范围,并且Git分支可以与部署和Jira任务相关联。而且,我们用来构建DevOps管道的大多数工具都是开源的。
4 V9 v5 z) [  ^- [% h) }" x
  H" |% ~9 {  A& y( |. n
$ Y7 y  ?3 z- n% n
我现在意识到我们的DevOps管道非常初级,因为我们没有利用JenkinsFile或Ansible等高级配置管理工具。但是,这个简单的过程效果很好,可能是由于Pareto原则(也称为80/20规则)。3 x( l! }: F5 q9 M( U  t3 [
2 z2 m$ c$ y/ e5 n, a- b. N6 p
DevOps 和 CI/CD 管道的简要介绍
( U1 s* p! r8 U6 `4 C* ^
' j0 p: B9 u# x2 l# M

- d8 e2 P2 E+ R' ?如果您问几个人:“什么是 DevOps?您可能会得到几个不同的答案。像敏捷一样,DevOps 已经演变为涵盖许多不同的学科,但是大多数人会在以下几件事上达成共识:DevOps 是一种软件开发实践或软件开发生命周期(SDLC)。中心宗旨是文化变革,开发人员和非开发人员都在这样的环境中工作:以前的人工操作是自动化的;每个人都尽其所能;每个时期的部署数量增加;吞吐量增加;灵活性提高。虽然拥有正确的软件工具并不是实现DevOps环境的唯一条件,但某些工具是必需的。关键之一是持续集成和持续部署(CI/CD)。该管道是环境具有不同阶段(例如DEV,INT,TST,QA,UAT,STG,PROD)的地方,手动操作是自动化的,并且开发人员可以实现高质量的代码,灵活性和大量部署。: h7 X. T, N; A+ E

% T+ P$ z: B0 O9 P1 ^

* A/ }+ {2 }: F) a* F本文介绍了使用开源工具创建 DevOps 管道的五步方法,如下图所示。3 S( d% z# {! K/ j# j
" @7 E" e; J) b7 ?- V
3 \7 |4 U' A& {  a
粘贴上传202112242333465069..png

* G8 [4 o7 f! z8 V3 k! [: T0 |
* o4 p2 ~! j" q5 J
事不宜迟,让我们开始吧。

3 A3 _1 L! f. J步骤1:搭建CI/CD框架

+ Z! z% n0 c3 c; _$ r' d" Y# k4 |: _9 N1 y& \: Z
# q2 S: y/ E. e
您需要的第一件事是CI/CD工具。Jenkins是基于MIT许可证的基于Java的开放源代码CI/CD工具,它是使DevOps运动普及并已成为事实上的标准的工具。
0 m0 p' j3 `$ B2 C6 E
4 ?) K% v0 V4 B5 _( y

  X' g' C! s$ E' ]3 d) Q那么,Jenkins 是什么?可以将其想象为一种神奇的通用控制器,它可以与许多不同的服务和工具进行通信并进行编排。仅靠Jenkins这样的CI/CD工具是没有用的,但是随着它集成不同的工具和服务,它变得更加强大。7 Y4 n9 r2 m' i: X, f; I) {: g& |
; J0 H' R5 P) ~1 z/ s( T/ e5 ^

/ l6 Y, I  x* p; ]2 B8 F  _
粘贴上传202112242334168405..png
% G" I8 R6 K' D8 V

  d1 p; B' ^. \8 p0 ?
% r" `' {- r7 _+ t+ {. j
使用 CI/CD 工具的 DevOps 流程如下所示。5 W' Y2 j% [3 \! C: Z3 }; T, s

4 x4 B8 L6 W2 m: ?5 C% m

) Z; K7 c! P, o2 g! A, I  F$ j4 d8 ?. L
粘贴上传202112242334437695..png

% B; z2 Y% o" ]/ L+ A
, i5 c7 k5 \$ u9 Y% V- M
您的本地主机中运行着CI/CD工具,但是目前您无能为力。让我们继续进行DevOps旅程的下一步。
  o  ?# |  v8 H4 Y. R
步骤2:源代码管理
( Z2 ^& C# S! x% Y7 ~

- i6 h+ e, S$ h5 P

! Z- m: m9 Z% V+ W0 x& w验证您的CI/CD工具是否可以执行某些操作的最佳方法(可能是最简单的方法)是与源代码管理管理(SCM)工具集成。为什么需要源代码控制?假设您正在开发应用程序。每当您构建应用程序时,您都在进行编程-无论您使用的是Java,Python,C ++,Go,Ruby,JavaScript还是任何种类繁多的编程语言。您编写的编程代码称为源代码。首先,尤其是当您独自工作时,可以将所有内容都放在本地目录中。但是,当项目规模扩大并且您邀请其他人进行协作时,您需要一种在有效共享代码修改的同时避免合并冲突的方法。您还需要一种方法来恢复以前的版本,并且使备份以及复制粘贴的过程变得陈旧。您(和您的队友)想要更好的东西。
1 e. B! _- q8 g4 }. K# x2 u. {
2 v6 ]: H% ?# v2 S# W

" U7 G: m2 s/ W. e8 J  y这就是SCM几乎成为必需品的地方。SCM工具通过将代码存储在存储库中,对代码进行版本控制以及在项目成员之间进行协调来提供帮助。
+ w  g9 B4 V9 n: ?# Z尽管有很多SCM工具,但Git是标准的,这是正确的。我强烈建议使用Git,但如果您愿意,还有其他开源选项。
* i* s5 ]4 ?& k& w# q

3 ^4 ?5 ^! o  C) Y# t( C6 B! p
! ?& Y! e0 K1 E; ?* L
粘贴上传202112242335074104..png

# `8 H8 a* m" w- F% K* Z* P0 F' C: F' }; n3 v) a  L2 J+ a

/ b# Y- G. F7 t* P- J' u: d" ?! C这是添加SCM后的DevOps管道的样子。
# C; U6 s- `% D9 [  U
3 z* j/ w, ^) \! L# {2 x
% `: t2 z/ B0 v8 }% N: c- F
粘贴上传202112242335328652..png

  V0 c( v, ~1 o( e0 ~9 h+ z+ Y; {' Q- S5 A$ R

) B$ K; I  U* V/ U8 J2 {8 b& H, P2 I: F

3 a! I/ Z& g9 sCI/CD工具可以自动执行签入和签出源代码以及跨成员协作的任务。不错?但是,您如何才能使其成为可以正常工作的应用程序,以便数十亿人可以使用和欣赏它?
+ |* e- p) ~! C( }
# T0 L8 v) x8 F步骤3:自动化构建工具  j$ B' O; Z' h  h# e  b8 ^
% m3 ~" E5 V0 a; H

! v5 [) `& d* S1 N优秀的!您可以签出代码并将更改提交给版本控制系统,还可以邀请您的朋友在源代码控制系统中开发进行协作。但是您尚未构建应用程序。要使其成为Web应用程序,必须对其进行编译并将其设置为可部署的包格式或以可执行文件的形式运行。(请注意,不需要编译诸如JavaScript或PHP之类的解释型编程语言。)$ b. c- d4 f& ^) A
. e2 e2 P; |* z5 R% f. c

* c7 k% E' Q3 I  Z- @8 l) d输入构建自动化工具。无论您决定使用哪种构建工具,所有构建自动化工具都有一个共同的目标:将源代码构建为某种所需的格式,并使清理,编译,测试和部署到特定位置的任务自动化。根据您的编程语言,构建工具会有所不同,但是这里有一些常见的开源选项可供考虑。. a" y% |  w$ g- B. q  E& g
6 a' w) ?# T! n6 d" A

/ R( c3 p/ B0 t2 ~# e6 R太棒了!您可以将构建自动化工具配置文件放入源代码管理管理中,并让您的CI/CD工具对其进行构建。+ x8 }9 O) j' w& r! a) A
2 w. i6 U* e) f8 L9 n5 v! i5 `8 ^
: [5 f1 w7 M. U1 o! w% W
粘贴上传202112242336009058..png
) o) m, A+ }/ K

* S2 w8 G' }/ |" \  ?
一切都很好,对吗?但是,您可以在哪里部署它呢?

0 w  g+ e* d0 @" b1 ?* q' N! s; E步骤4:Web应用程序服务器

. c% J( g! _# X: t- d- y5 r3 z8 V5 ~% K& G
: e5 u6 w* W# z( }1 a6 J
到目前为止,您具有一个可执行或可部署的打包文件。为了使任何应用程序真正有用,它必须提供某种服务或接口,但是您需要一个容器来托管您的应用程序。* [6 l- {7 m" o& P! t3 c- H' e& R

% R% _. M) Y6 M  C2 u# t
5 v0 s* m# L* `  f" J* j7 h& g
对于Web应用程序,Web应用程序服务器就是那个容器。应用服务器提供了一个环境,在该环境中,可检测可部署程序包内的编程逻辑,呈现接口并通过打开外部套接字来提供Web服务。您需要HTTP服务器以及其他环境(例如虚拟机)来安装应用程序服务器。现在,让我们假设您将沿途学习(尽管我将在下面讨论容器)。
2 }) w+ O* z1 X. A8 I; ?" N) _7 J) {. x" o2 f# C1 `, m9 _7 M! u

" n& `. X3 r6 H9 {. J有许多可用的开源Web应用程序服务器。
) }& T4 }+ R: d& c& P- ^( ]6 b* q" Y/ Y0 _9 D! F

- {6 @2 V% e" S1 T现在,DevOps管道几乎可用。做得好!0 Z- U/ A9 }  X

: I& [8 \- \2 R1 X: m7 h0 l
% l& p: {9 ]0 H8 e1 G( z3 [1 G
粘贴上传202112242336264541..png

2 D/ k/ S0 h/ B+ i( y* c8 c2 F# S
0 U& z7 k3 j" ~1 n$ s, ^* m

5 S. D4 e  N+ l& G尽管可以在这里停下来自己进一步集成,但是代码质量对于应用程序开发人员来说是重要的。
) a* P: S# a. p9 t$ r( c1 L7 |" X2 ^
步骤5:代码测试范围; _  I6 }; t  B' p1 K) a5 ]. c

4 c# r: T! f+ U* |% \
! b2 Q8 U5 C) a4 u' G3 B6 G3 y! z
实施代码测试块可能是另一个繁琐的要求,但是开发人员需要尽早发现应用程序中的任何错误并提高代码质量,以确保最终用户满意。幸运的是,有许多开源工具可用于测试您的代码并提出提高其质量的建议。更好的是,大多数CI/CD工具都可以插入这些工具中并使过程自动化。: E' A5 r5 T& z+ V' t: r9 P. I
1 }9 z1 Z, L9 W0 Y; o7 g
2 t7 ~) o+ {4 i/ N
代码测试包含两个部分:帮助编写和运行测试的代码测试框架,以及有助于提高代码质量的代码质量建议工具。
* A1 v! u" a8 f3 x; j0 ~. T' L. w, P( i. X1 W8 _7 N  K5 e

" {2 R' ~. e8 r& a9 Q3 T$ `# X代码测试框架
  o* \' X: H+ o2 s& j
  s- f7 F: c( z" a  p: q6 j
$ I+ _7 {. }& q) u
粘贴上传202112242337307274..png
" I! O; X$ a" a

' `, ?' C- q, I$ O. s0 z  I" c

/ g3 y# Y  N( a1 r代码质量建议工具0 X" [9 p9 V, `/ A; }5 C

% m; v+ t8 @( }) F8 U' m+ R% J
9 R. \) n5 \" _! W0 P' a
粘贴上传202112242337573747..png

8 }5 ]( s( Z$ e$ _
3 m3 B; o( X5 b0 Q! ^" |
, N* A+ h, {% i( ^  n6 i: i; b
请注意,由于 C++ 和 C#是专有的编程语言(尽管GCC是开源的),因此上述大多数工具和框架都是为Java,Python和JavaScript编写的。
; s. o& k% i0 X# f! P. w5 u7 a$ Z9 k5 p9 D, ?
& o. f1 S' i/ s/ e  `. L9 `
现在,您已经实现了代码测试覆盖率工具,您的DevOps管道应类似于本教程开头所示的DevOps管道图。
# T2 K! S5 }/ J9 O) U6 B4 A) T' a
' r' ^3 G  A  I& k, Y; e9 N" j# T  B可选步骤9 H: z; }6 a8 c1 R
( {/ C( p$ K0 R/ G
容器* t# Y/ k9 e' F4 |

/ ]: P2 E7 U* a+ C  X) b
- c' n6 F) m1 `
如前所述,您可以将应用程序服务器托管在虚拟机或服务器上,但是容器是一种流行的解决方案。
- ^: X: p* s; E& \% g9 U& A( \" [0 y5 b9 N. P; i

  }( T8 u2 Y( @+ B7 F9 s( i% @什么是容器?简短的解释是,VM需要操作系统的巨大资源,这不但占用了应用程序的大小,而容器只需要一些库和配置即可运行应用程序。显然,VM仍然有重要的用途,但是容器是用于托管应用程序(包括应用程序服务器)的轻量级解决方案。" H9 p" E+ I/ Y

& @* c' h0 j: u

0 @  U' _" h% D6 ?% t+ Q% }尽管容器还有其他选择,但是Docker和Kubernetes是最受欢迎的。: ^3 O( @/ u0 d0 f
, p& J0 |# R2 @& W) M3 P* d, k/ {

- E0 b; s6 K$ k9 {4 ]" W6 y
粘贴上传202112242338189584..png
! C3 Q+ Y+ G- E( M. M1 `5 t
( M( [3 Q/ o. u$ K, I8 g9 Y
中间件自动化工具! ~5 q/ P$ o8 k* ?$ s6 d8 c

3 U8 ~! O3 |+ `; M; S6 s1 `
5 D$ k. M2 h) ]; E
我们的DevOps管道主要集中于协作构建和部署应用程序,但是您可以使用DevOps工具执行许多其他操作。其中之一是利用基础结构即代码(IaC)工具,也称为中间件自动化工具。这些工具有助于自动化中间件软件的安装,管理和其他任务。例如,自动化工具可以使用正确的配置提取应用程序(如Web应用程序服务器,数据库和监视工具),并将其部署到应用程序服务器。9 }9 u* a1 @# r
' R5 S$ ^8 x1 }, J4 }. N
$ U; S7 n6 g2 h; t
以下是要考虑的几种开源中间件自动化工具:
7 X, k& X' e6 z# V6 o
/ ]) N  t6 U+ F, j# t9 x

$ q2 K) _$ I7 B/ T8 H7 R/ I6 g: v
粘贴上传202112242338421602..png

9 G# H" M3 |& t" g6 \4 }' W0 t( ^' s5 R- i
总结/ x: R5 R& e# b5 d3 m+ t
6 \+ T  V8 B) _% x: }; A3 @

6 O! L! K9 f1 }% \这只是完整的DevOps管道外观的冰山一角。首先从CI/CD工具开始,然后探索其他可以自动化的方法,以简化团队的工作。另外,请研究可帮助您的团队更好地合作的开源工具。(转自泽阳)
) a* _) u/ }0 n+ c8 u1 p6 j$ k* j5 A  N4 n" z- P5 ?
5 i% F/ _. m2 w, x) b  ]

0 \3 e9 Z4 g0 d2 ~9 F

4 k4 Q# h0 p" ?0 {' k, G6 W! F* E$ h6 k' |% b




上一篇:你也被 DevOps 的流水线坑过吗?
下一篇:5 大 DevOps 工具,看看你用过几个?
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

参加 ITIL 4 基础和专家认证、长河ITIL实战沙盘、DevOps基础级认证、ITSS服务经理认证报名
ITIL(R) is a registered trademark of AXELOS Limited, used under permission of AXELOS Limited. The Swirl logo is a trademark of AXELOS Limited, used under permission of AXELOS Limited. All rights reserved.

QQ|ITIL ( 粤ICP备11099876号 )|appname

GMT+8, 2023-1-28 01:12 , Processed in 0.106326 second(s), 32 queries .

Powered by Discuz! X3.4 Licensed

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表