zoukankan      html  css  js  c++  java
  • 1--持续集成,代码管理工具Git

    一、软件开发生命周期

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

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

    • 设计:系统架构和满意状态(就是要做成什么样子,有什么功能)和创建一个项目计划。计划可以使用图表,布局设计挥着文字方式呈现。

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

    • 测试:测试人员进行代码测试 ,包括功能测试、代码测试、压力测试等。

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

    #  软件开发生命周期
    1、设计 ---> 需求分析
    
    2、实现
    	写配置清单,构建容器,部署一个测试环境
    3、测试
    4、优化(迭代)
    

    二、开发模式

    ### 1.敏捷开发  (Agile Development)  
    
    核心是迭代开发与增量开发
    
    ### 2.迭代开发  (Iterative Development)  
    
    对于大型软件项目,传统的开发方式是采用一个大周期(比如一年)进行开发,整个过程就是一次"大 开发";迭代开发的方式则不一样,它将开发过程拆分成多个小周期,即一次"大开发"变成多次"小开 发",每次小开发都是同样的流程,所以看上去就好像重复在做同样的步骤。
    
    ### 3.增量开发  (Incremental Development) 
    软件的每个版本,都会新增一个用户可以感知的完整功能。也就是说,按照新增功能来划分迭代。
    
    

    三、持续集成(CI)持续交付(CD)持续部署(CD)

    1.持续集成( Continuous integration )

    持续集成是软件开发周期的一种实践,把代码仓库(Gitlab或者Github)、构建工具(如Jenkins)和测试工具(SonarQube)集成在一起,频繁的将代码合并到主干然后自动进行构建和测试。持续集成的目的,就是让产品可以快速迭代,同时还能保持高质量。它的核心措施是,代码集成到主干之前,必须通过自动化测试。只要有一个测试用例失败,就不能集成。通过持续集成,团队可以快速的从一个功能到另一个功能。在持续集成的过程当中主要包括以下步骤:提交、测试、构建(容器需要构建, 编译型语言编译)、部署及回滚。

    1)持续集成要素

    # 1、一个自动构建过程,从检出代码、编译构建、运行测试、结果记录、测试统计等都是自动完成的,无需人工干预 
    # 2、 一个代码存储库,即需要版本控制软件来保障代码的可维护性,同时作为构建过程的素材库,一般使用SVN或Git。
    # 3、 一个持续集成服务器, Jenkins 就是一个配置简单和使用方便的持续集成服务。
    

    2)持续集成的好处

    • 1、降低风险,由于持续集成不断去构建,编译和测试,可以很早期发现问题,所以修复的代价就少
    • 2、对系统健康持续检查,减少发布风险带来的问题
    • 3、减少重复性工作
    • 4、持续部署,提供可部署单元包
    • 5、持续交付可供使用的版本
    • 6、增强团队信心

    2.持续交付( Continuous Delivery )

    持续交付,简称CD,是在CI的基础进行了扩展,在CI环节完成了软件构建和测试工作并形成了新的版本,那么接下来就要进行交付,而这里的交付并不是交付到生产环境,而是类生产环境(STAGING),我们可以理解为灰度环境或者预发环境,进而接受部分真实流量的测试。如果没有问题的话则通过手动的方式部署到生产环境

    3.持续部署( Continuous Deployment )

    持续部署,简称CD,它是在持续交付的基础上打通最后一公里的工作,就是把手动部署到生产环境的方式升级为自动部署。看下图和上图在最后部署到生产环境中的区别。

    四、部署代码到服务器的方式

    # 1、早期两者方式
    1、将代码上传到服务器,然后解压
    
    2、将代码上传到服务器中,然后通过软连接的方式部署 ln -s /root/jenkins /usr/share/nginx/html/
    
    无法实现批量部署,无法实现批量回滚,更无法实现批量测试。
    # (ansible只是一个自动化部署工具,无法进行重复利用)
    

    以上两种方式都无法实现批量部署,无法实现批量回滚,更无法实现批量测试。

    • 实现自动集成(java、golang)、自动部署、自动测试: DevOps
    • 实现自动集成、自动部署:Jenkins
    • 代码类型:
    # 1、批量部署,批量测试
    
    1、源代码管理
    2、协同开发
    
    # 2、代码管理工具
    自动集成(java、golang)、自动部署、自动测试: DevOps
    代码:
    	编译型语言:需要编译,后运行
    	脚本型语言:直接运行
    
    • 工具种类:
    # 工具:
    实现自动集成、自动部署:Jenkins
    实现代码管理:git --giterb管理页面-> gitlab、github、gitee
    

    五、代码管理工具Git

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

    1..安装Git

    # 1.安装git
    [root@jenkins ~]# yum install git -y
    [root@jenkins ~]# git  --version  #查看版本
    git version 1.8.3.1
    

    2.仓库

    仓库对应的就是一个目录,这个目录中的所有文件被git管理起来。以后会将一个项目的根目录,作为仓库。仓库中的每个文件的改动 都由git跟踪。

    #1.新建一个data本地仓库
    [root@jenkins ~]# mkdir data
    [root@jenkins ~]# cd data/
    
    #2.初始化代码仓库
    [root@jenkins data]# git init
    Initialized empty Git repository in /root/data/.git/
    初始化空的 Git 版本库于 /root/data/.git/
    [root@jenkins data]# ll -a
    total 0
    drwxr-xr-x  3 root root  18 Aug 11 23:47 .
    dr-xr-x---. 4 root root 207 Aug 11 23:47 ..
    drwxr-xr-x  7 root root 119 Aug 11 23:47 .git
    [root@jenkins data]# cd .git/  #这里存放的都是git的配置文件
    [root@jenkins .git]# ll
    total 12
    drwxr-xr-x 2 root root   6 Aug 11 23:47 branches
    -rw-r--r-- 1 root root  92 Aug 11 23:47 config
    -rw-r--r-- 1 root root  73 Aug 11 23:47 description
    -rw-r--r-- 1 root root  23 Aug 11 23:47 HEAD
    drwxr-xr-x 2 root root 242 Aug 11 23:47 hooks
    drwxr-xr-x 2 root root  21 Aug 11 23:47 info
    drwxr-xr-x 4 root root  30 Aug 11 23:47 objects
    drwxr-xr-x 4 root root  31 Aug 11 23:47 refs
    

    3.远程仓库

    # github   gitee   gitlab
    
    #1.下载远程仓库
    [root@jenkins ~]# git clone https://gitee.com/mming2021/data.git
    正克隆到 'data'...
    warning: 您似乎克隆了一个空版本库。
    
    #2.设置用户名和邮箱
    [root@git ~/data]# git config --global user.name "cdan2021"
    [root@git ~/data]# git config --global user.email "cdaneee@163.com" 
    
    #3.查看信息
    [root@git ~/data]# git config --get user.name
    can99
    [root@git ~/data]# git config --get user.email
    cdaneee@163.com
    
    #4.关联命令
    [root@jenkins data1]# git remote add origin git@gitee.com/cdan99/devops01.git
    
    #5.查看远程连接
    [root@k8s-m-01 data]# git remote -v
    origin	git@https://gitee.com/cdan99/devops01.git (fetch)
    origin	git@https://gitee.com/cdan99/devops01.git (push)
    或者
    [root@k8s-m-01 data]# cat .git/config 
    [core]
    	repositoryformatversion = 0
    	filemode = true
    	bare = false
    	logallrefupdates = true
    [remote "origin"]
    	url = git@https://gitee.com/cdan99/devops01.
    	fetch = +refs/heads/*:refs/remotes/origin/
    
    #6. 删除远程连接
    git remote rm origin 
    

    4.提交代码

    #1.创建源代码文件
    [root@git ~/data]# echo 'hello world' > index.html
    [root@git ~/data]# ll
    总用量 0
    -rw-r--r-- 1 root root 0 3月  24 06:09 index.html
    [root@git ~/data]# git status  #查看状态
    # 位于分支 master
    #
    # 初始提交
    #
    # 未跟踪的文件:
    #   (使用 "git add <file>..." 以包含要提交的内容)
    #
    #	index.html
    提交为空,但是存在尚未跟踪的文件(使用 "git add" 建立跟踪)
    
    #注:此时的源代码还没有交给git管理,如果删除源代码文件,git不会有报错信息,代码会被彻底删除
    
    #2.将代码提交到git缓存区
    [root@git ~/data]# git add index.html #将本地目录中的index.html加入git从库
    [root@git ~/data]# git status
    # 位于分支 master
    #
    # 初始提交
    #
    # 要提交的变更:
    #   (使用 "git rm --cached <file>..." 撤出暂存区)
    #
    #	新文件:    index.html
    
    #注:此时源代码文件已经提交到git,如果此时删除源代码,文件不会被彻底删除,git查看会有报错信息,还可以使用git移回文件
    
    #3.将文件提交由缓冲区提交到暂存区中  
    [root@k8s-m-01 data]# git commit -m '注释'   #-m参数是添加注释,必须加上
    [master (root-commit) 288a856] 注释
     1 file changed, 1 insertion(+)
     create mode 100644 index.html
    
     # 注:添加到缓存区代码是可以修改的,修改后可以将修改的内容重新添加后暂存区。暂存区内容是不可以修改的。
     此时再查看状态是无内容
    [root@k8s-m-01 data]# git status
    # On branch master
    nothing to commit, working directory clean
    [root@k8s-m-01 data]# echo "hello cdan" > index.html  #重新写文件
    [root@k8s-m-01 data]# git status
    # On branch master
    # Changes not staged for commit:
    #   (use "git add <file>..." to update what will be committed)
    #   (use "git checkout -- <file>..." to discard changes in working directory)
    #
    #	modified:   index.html    #状态是修改了,必须再add,再commit
    #
    no changes added to commit (use "git add" and/or "git commit -a")
    
    
    #4.查看修改内容(+代表添加,-代表删除)
    [root@git ~/data]# git diff index.html
    diff --git a/index.html b/index.html
    index 3b18e51..ec6cee9 100644
    --- a/index.html
    +++ b/index.html
    @@ -1 +1,2 @@
     hello world
    +hello mm
    
    

    4.回滚

    #1.查看提交代码历史记录
    [root@jenkins data]# git log
    commit 3a47bf413ea47bba8d47e0f6c5220c768108fafe
    Author: elaina_mm <1715554782@qq.com>
    Date:   Thu Aug 12 00:06:42 2021 +0800
    
        init
    
    commit 0476939d64f6ef497a1a695865bf5a3fe64e0ebe
    Author: elaina_mm <1715554782@qq.com>
    Date:   Thu Aug 12 00:06:20 2021 +0800
    
        init
    commit 6c7e8316a6602fe199e933a2c740b7b15b310a24
    Author: Your Name <you@example.com>
    Date:   Wed Aug 11 23:57:35 2021 +0800
        init    
    #2.回滚 
    [root@jenkins data]# git reset 0476939d64f6ef497a1a695865bf5a3fe64e0ebe
    [root@jenkins data]# git reset --hard 425fb32d50f71f8f4a78e7037f58ff8869b40f7c  # 指定版本
    HEAD 现在位于 425fb32 init
    
    [root@gitlab baim0]# echo 111 > index.html 
    [root@gitlab baim0]# git reset --hard 
    HEAD is now at a08d617 first
    [root@gitlab baim0]# cat index.html 
    hello world
    

    5.将本地代码提交到远程仓库

    [root@git ~/data]# ssh-keygen -t rsa  #生成密钥
    [root@git ~/data]# cat /root/.ssh/id_rsa.pub #查看公钥,复制公钥到gitee上添加公钥(如下图)
    
    #4.将本地代码提交到远程仓库
    [root@k8s-m-02 jenkins]# git remote add origin git@gitee.com:cdan99/jenkins.git
    [root@k8s-m-02 jenkins]# git push origin master
    Counting objects: 3, done.
    Writing objects: 100% (3/3), 218 bytes | 0 bytes/s, done.
    Total 3 (delta 0), reused 0 (delta 0)
    remote: Powered by GITEE.COM [GNK-6.0]
    To git@gitee.com:cdan99/jenkins.git
     * [new branch]      master -> master
    
    
    #5.使用SSH将我们的代码提交到远程仓库
    [root@git ~/data]# vim .git/config   #修改配置文件
    [core]
    	repositoryformatversion = 0
    	filemode = true
    	bare = false
    	logallrefupdates = true
    [remote "origin"]
    	url = git@gitee.com:mming2021/data.git #将http修改成ssh方式
    	fetch = +refs/heads/*:refs/remotes/origin/*
    [branch "master"]
    	remote = origin
    	merge = refs/heads/master
    
    
    [root@git ~/data]# git push -u origin master  #免密提交
    The authenticity of host 'gitee.com (212.64.62.183)' can't be established.
    ECDSA key fingerprint is SHA256:FQGC9Kn/eye1W8icdBgrQp+KkGYoFgbVr17bmjey0Wc.
    ECDSA key fingerprint is MD5:27:e5:d3:f7:2a:9e:eb:6c:93:cd:1f:c1:47:a3:54:b1.
    Are you sure you want to continue connecting (yes/no)? yes  # 输入yes直接上传
    Warning: Permanently added 'gitee.com,212.64.62.183' (ECDSA) to the list of known hosts.
    Counting objects: 5, done.
    Writing objects: 100% (3/3), 264 bytes | 0 bytes/s, done.
    Total 3 (delta 0), reused 0 (delta 0)
    remote: Powered by GITEE.COM [GNK-6.0]
    To git@gitee.com:mming2021/data.git
       338cf8c..ce7496f  master -> master
    Branch master set up to track remote branch master from origin.
    
    

    6.拉取远程仓库代码(获取代码)

    2种方式:
    *如果本地没有就去线上仓库 git clone  *如果本地有仓库代码 git pull
    
    # 1、另外一个人也在登录git账号
    [root@jenkins ~]# mkdir jenkins
    [root@jenkins ~]# cd jenkins/
    [root@jenkins jenkins]# git clone  git@gitee.com:cdan99/jenkins.git
    
    # 2、进入仓库修改内码
    [root@jenkins jenkins]# cd data/
    [root@git ~/data]# vim index.html 
    hello world
    
    # 3、提取到仓库
    [root@git ~/data]# git add index.html
    [root@git ~/data]# git commit -m 'init'
    [master 330e53a] init
     1 file changed, 1 insertion(+), 2 deletions(-)
    [root@git ~/data]# git push -u origin master  #发送到gitee
    
    # 4、在另一个终端查看
    [root@git ~/data]# git pull
    [root@git ~/data]# cat index.html 
    hello world
    
     # git pull 和 git clone 之间有什么不同?
     1、git pull  是更新代码:在现有的仓库里将远程修改过的代码更新到本地仓库
     2、git clone 是下载代码:需要创建仓库,本地仓库与远程仓库连接起来
    

    7.分支(不同分支之间是相对隔离的)

    # 房子 ---> 房间
    # git仓库  ---> 代表是房间
    
    不同的分支之间是相对隔离的。
    
    代码仓库:cdan99
    
    开发环境
    测试环境
    预发布环境
    线上环境
    
    #1.查看本地分支
    [root@git ~/data]# git branch  #必须在存放内码的目录,否则无效
    * master  #默认的master分支
    
    #2.查看所有的分支
    [root@git ~/data]# git branch -a
    * master
      remotes/origin/master  #远程分支
    
    #3.创建分支
    [root@git ~/data]# git checkout -b test
    切换到一个新分支 'test'
    [root@git ~/data]# git branch
      master
    * test
    
    #4.修改内码
    [root@git ~/data]# echo “who is longlong" > index.html 
    [root@git ~/data]# git add index.html
    [root@git ~/data]# git commit -m 'init'
    [root@git ~/data]# git push origin test  #此时test分支的index.html改了
    
    #5.将本地分支同步到远程分支
    [root@git ~/data]# git branch  #前提要保证当前在要同步的分支上
      master
    * test
    [root@git ~/data]# git push -u origin test 
    Total 0 (delta 0), reused 0 (delta 0)
    remote: Powered by GITEE.COM [GNK-6.0]
    remote: Create a pull request for 'test' on Gitee by visiting:
    remote:     https://gitee.com/mming2021/data/pull/new/mming2021:test...mming2021:master
    To git@gitee.com:mming2021/data.git
     * [new branch]      test -> test
    分支 test 设置为跟踪来自 origin 的远程分支 test。
    
    #5.切换分支
    [root@git ~/data]# git checkout master
    切换到分支 'master'
    [root@git ~/data]# git branch  # *在那个分支就代表那个分支
    * master
      test
     
    # 获取指定分支
    [root@k8s-m-02 jenkins]# git clone -b dang git@gitee.com:cdan99/jenkins.git 
    
    #7.查看分支 -- 见下图
    

    8.标签(是一种特殊的分支,只能删除不能修改)

    #代码上传之后打上标签
    # 本地创建标签
    # 1.本地创建
    git tag -a [tag名称] -m "解释"
    [root@git ~/data]# git tag -a v1-stable -m '第一个标签'
    [root@git ~/data]# git tag
    v1-stable
    # 远程创建标签
    # 2.远程仓库创建鼠标点点
    /标签/创建标签
    # 3.另一个终端查看 (标签自动创建)
    [root@git ~/data]# git pull
    [root@git ~/data]# git branch -a
    * master
      remotes/origin/HEAD -> origin/master
      remotes/origin/master
      remotes/origin/test
    [root@git ~/data]# git tag
    v1-stable
    [root@git ~/data]# cat index.html 
    hdello world
    hello mm
    hello mm
    hello mm
    # 4.拉取指定标签内容
    git clone -b [标签名称|分支名称] [仓库地址]
    [root@git ~/data]# git clone git@gitee.com:mming2021/data.git #默认是master
    [root@git ~/data]# git clone -b master git@gitee.com:mming2021/data.git
    [root@git ~/data]# git clone -b master v1-stable  git@gitee.com:mming2021/data.git # 指定标签
    正克隆到 'data'...
    remote: Enumerating objects: 7, done.
    remote: Counting objects: 100% (7/7), done.
    remote: Compressing objects: 100% (4/4), done.
    remote: Total 7 (delta 0), reused 0 (delta 0), pack-reused 0
    接收对象中: 100% (7/7), done.
    
    

    六、练习

    # 1、实现脚本通过标签部署discuz
    1、准备代码
    2、提交的git暂存区
    3、配置用户名和邮箱
    4、提交
    5、推送(认证)
    6、创建标签
    7、编写部署脚本
    

    创建本地仓库,关联上远程仓库,并实现脚本通过标签部署discuz

    #1.创建本地仓库
    [root@jenkins ~]# mkdir data1
    [root@jenkins ~]# cd data1
    [root@jenkins data1 ~]# git init
    初始化空的 Git 版本库于 /root/data1/.git/
    
    #2.将本地仓库关联上远程仓库(前提要有远程仓库)
    [root@jenkins data1]# git remote add origin git@gitee.com:mming2021/data-discuz.git  #关联命令
    [root@jenkins data1]# cat .git/config  #关联远程仓库后的配置文件
    [core]
    	repositoryformatversion = 0
    	filemode = true
    	bare = false
    	logallrefupdates = true
    [remote "origin"]
    	url = git@gitee.com:mming2021/data-discuz.git  #远程仓库的地址
    	fetch = +refs/heads/*:refs/remotes/origin/*
    
    #3.准备discuz包
    [root@jenkins data1]# mkdir discuz
    [root@jenkins data1]# mv Discuz_X3.4_SC_UTF8_20210320.zip discuz/
    [root@jenkins data1]# cd discuz/
    [root@jenkins discuz]# unzip Discuz_X3.4_SC_UTF8_20210320.zip 
    总用量 12172
    -rw-r--r--  1 root root 12330468 4月   7 2021 Discuz_X3.4_SC_UTF8_20210320.zip
    -rw-r--r--  1 root root    17886 3月  20 10:36 LICENSE
    -rw-r--r--  1 root root    31040 1月  19 17:18 qqqun.png
    drwxr-xr-x  2 root root      124 3月  22 19:44 readme
    -rw-r--r--  1 root root    71107 1月  19 17:20 readme.html
    drwxr-xr-x 13 root root     4096 3月  22 19:44 upload
    drwxr-xr-x  4 root root       94 3月  22 19:44 utility
    [root@jenkins discuz]# mv upload/* /root/data1/
    [root@jenkins discuz]# cd ..
    [root@jenkins data1]# rm -rf discuz/
    [root@jenkins data1]# ll
    总用量 68
    -rw-r--r--  1 root root 2834 3月  22 19:44 admin.php
    drwxr-xr-x  9 root root  135 3月  22 19:44 api
    -rw-r--r--  1 root root  727 3月  22 19:44 api.php
    drwxr-xr-x  2 root root   23 3月  22 19:44 archiver
    drwxr-xr-x  2 root root   90 3月  22 19:44 config
    -rw-r--r--  1 root root 1040 3月  22 19:44 connect.php
    -rw-r--r--  1 root root  106 3月  22 19:44 crossdomain.xml
    drwxr-xr-x 12 root root  178 3月  22 19:44 data
    drwxr-xr-x  5 root root  140 4月   6 06:39 discuz
    -rw-r--r--  1 root root 5558 3月  20 10:36 favicon.ico
    -rw-r--r--  1 root root 2245 3月  22 19:44 forum.php
    -rw-r--r--  1 root root  821 3月  22 19:44 group.php
    -rw-r--r--  1 root root 1280 3月  22 19:44 home.php
    -rw-r--r--  1 root root 6472 3月  22 19:44 index.php
    drwxr-xr-x  5 root root   64 3月  22 19:44 install
    drwxr-xr-x  2 root root   23 3月  22 19:44 m
    -rw-r--r--  1 root root 1025 3月  22 19:44 member.php
    -rw-r--r--  1 root root 2371 3月  22 19:44 misc.php
    -rw-r--r--  1 root root 1788 3月  22 19:44 plugin.php
    -rw-r--r--  1 root root  977 3月  22 19:44 portal.php
    -rw-r--r--  1 root root  582 3月  22 19:44 robots.txt
    -rw-r--r--  1 root root 1155 3月  22 19:44 search.php
    drwxr-xr-x 10 root root  168 3月  22 19:44 source
    drwxr-xr-x  7 root root   86 3月  22 19:44 static
    drwxr-xr-x  3 root root   38 3月  22 19:44 template
    drwxr-xr-x  7 root root  106 3月  22 19:44 uc_client
    drwxr-xr-x 13 root root  241 3月  22 19:44 uc_server
    #4.将diacuz所有文件添加到远程仓库
    [root@jenkins data1]# git add . #代表当前目录下的所有文件提交到暂存区
    [root@jenkins data1]# git config --global user.name "mming2021"
    [root@jenkins data1]# git config --global user.email "1715554782@qq.com"
    [root@jenkins data1]# git commit -m 'init' .
    
    #5.将公钥添加到gitee
    [root@jenkins data1]# cat ~/.ssh/id_rsa.pub 
    复制粘贴公钥内容到gitee设置内添加
    #6.推送到远程仓库
    [root@jenkins data1]# git push -u origin master
    #查看gitee仓库就自动更新了
    #7.代码推送成功后可以在gitee上创建一个标签,代码就无法修改了
    /标签/创建标签/
    #8.编写部署脚本
    [root@jenkins ~]# mkdir -pv /usr/share/nginx/html
    
    [root@jenkins ~]# vim discux.sh
    #/bin/bash
    
    REPOASITORY=discuz-`date +%F_%H:%M:%S`
    REPOASITORY_URL="git@gitee.com:mming2021/data-discuz.git"
    REPOASITORY_TAG=$1
    CURRENT_DIR=`pwd`  #当前路径
    echo $1
    git clone -b ${REPOASITORY_TAG} ${REPOASITORY_URL} ${REPOASITORY}
    rm -rf /usr/share/nginx/html
    ln -s ${CURRENT_DIR}/${REPOASITORY} /usr/share/nginx/html
    
    #9.执行脚本
    [root@jenkins ~]# chmod +x discux.sh 
    [root@jenkins ~]# ./discux.sh v1-stable
    #10.查看是否挂载成功
    [root@jenkins ~]#  ll /usr/share/nginx/
    total 0
    lrwxrwxrwx 1 root root 32 Aug 12 12:03 html -> /root/discuz-2021-08-12_12:03:52
    # 11.查看部署文件
    [root@jenkins ~]# ll
    -rwxr-xr-x   1 root root  311 Aug 12 12:03 discux.sh
    drwxr-xr-x  14 root root 4096 Aug 12 12:03 discuz-2021-08-12_12:03:52
    
    

  • 相关阅读:
    0019. Remove Nth Node From End of List (M)
    0018. 4Sum (M)
    0278. First Bad Version (E)
    0273. Integer to English Words (H)
    0017. Letter Combinations of a Phone Number (M)
    0016. 3Sum Closest (M)
    0015. 3Sum (M)
    软件测试常见面试题
    如何快速掌握DDT数据驱动测试?
    selenium--三种等待方式
  • 原文地址:https://www.cnblogs.com/caodan01/p/15144099.html
Copyright © 2011-2022 走看看