亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

使用Jenkins部署React項目的方法步驟

2024-05-06 16:48:55
字體:
來源:轉載
供稿:網友

背景

公司的前端項目部署方式比較簡單,整個過程基本上是手動的;

目標

通過工具實現以下幾個任務:

  • 編譯、部署自動化;
  • 選擇指定版本進行回滾;
  • 區分不同的分支(環境);

技術方案

  • 選用 jenkins 作為部署工具;也便于后續 CI 的接入;
  • 使用 docker 進行編譯,確保每次編譯的環境的穩定;

步驟

步驟一:搭建 Jenkins

搭建 Jenkins 有很多方案,這里選擇使用 docker 搭建。

docker-compose.yml 的內容如下:

version: '3'services: fejenkins:  user: root  image: jenkinsci/blueocean  ports:   - "8080:8080"   - "50000:50000"  volumes:   - /data/jenkins_home:/var/jenkins_home   - /data/nm_cache:/var/nm_cache   - /var/run/docker.sock:/var/run/docker.sock

通過 docker-compose up 命令啟動;啟動后通過初始密碼進行第一個用戶的創建和 Jenkins 初始化的一些列操作,初始密碼會打印在 jenkins docker 啟動命令行的輸出中,注意查看。

當然也可以不使用 docker-compose:

docker run --rm -u root -v /data/jenkins_home:/var/jenkins_home -v /data/nm_cache:/var/nm_cache -v /var/run/docker.sock:/var/run/docker.sock -p 8080:8080 -p 50000:50000 jenkinsci/blueocean

稍做解釋:

  • /data/jenkins_home:/var/jenkins_home /var/jenkins_home 是 jenkinsci image 的默認數據存放路徑,這里將路徑映射到宿主機的指定文件夾;
  • /data/nm_cache:/var/nm_cache nm_cache 涵義是 node_modules cache,顧名思義,這里是想對編譯所需的 node_modules 做緩存,將緩存文件夾也映射到宿主機;
  • /var/run/docker.sock:/var/run/docker.sock 這里是將宿主機運行 docker 后產生的 sock 文件映射到了 jenkins container 中。這樣,jenkins 中使用 docker 進行編譯時,其實是使用宿主機的 docker 來運行的,而不是在 docker container 中又啟動了 docker。這里稍微有點繞,若是暫時看不明白,需要找一些深入介紹 docker 的文章閱讀;

步驟二:配置 Jenkins

添加 Credentials

通過 Jenkins 進行 git 操作需要對應 git repo 的權限,這里需要用到有 git repo 權限的密鑰文件。同樣,通過 Jenkins 將編譯產物 scp 到服務器上的時候,也需要服務器的密鑰文件。

這兩類密鑰文件需要配置在 Jenkins 中,在:Jenkins > Credentials > System > Global credentials (unrestricted) 里進行 Add Credentials 的操作。

添加 Jenkins Item

Jenkins > New Item,然后選擇 Pipeline,在下面的 Pipeline 配置區域的 Definition 中選擇 Pipeline script,Script 如下:

pipeline {  environment {    SERVER_IP_1 = "11.22.33.44"    SERVER_CREDENTIALSID = "abcd1234-abcd-abcd-abcd-abcd1234abcd"    SERVER_DEPLOY_DIR = "/your/www/path/"    CACHE_DIR = "/var/nm_cache/your_project_name/"    GIT_URL = "git@github.com:example/example.git"    GIT_BRANCH = "master"    GIT_CREDENTIALSID = "abcd1234-abcd-abcd-abcd-abcd1234abcd"  }  agent none  stages {    stage('Checkout code') {      agent any      steps {        git (          branch: "${GIT_BRANCH}",          credentialsId: "${GIT_CREDENTIALSID}",          url: "${GIT_URL}",          changelog: true        )        sh '''          ls -al          cache_dir="${CACHE_DIR}"          cache_nm="${CACHE_DIR}node_modules"          cache_lock="${CACHE_DIR}yarn.lock"          if [ ! -d "$cache_dir" ]; then mkdir ${cache_dir}; fi          if [ ! -d "$cache_nm" ]; then mkdir ${cache_nm}; fi          if [ -d "$cache_nm" ]; then ln -sf ${cache_nm} ./; fi          if [ -f "$cache_lock" ]; then mv -n ${cache_lock} .; fi          ls -al        '''      }    }    stage('Build') {      agent {        docker {          image 'node:8-alpine'          args ''        }      }      steps {        sh '''          npm config set registry https://registry.npm.taobao.org          yarn install          yarn build          tar -cvf build.tar build          ls -al          mv ./yarn.lock ${CACHE_DIR}          rm -rf ./node_modules          ls -al        '''        archiveArtifacts artifacts: 'build.tar', fingerprint: true      }    }    stage('Deploy') {      agent any      steps {        unarchive mapping: ['build.tar': 'build.tar']        echo '--- Deploy ---'        sshagent(["${SERVER_CREDENTIALSID}"]) {         sh "scp -o StrictHostKeyChecking=no build.tar root@${SERVER_IP_1}:${SERVER_DEPLOY_DIR}"         sh "ssh -o StrictHostKeyChecking=no root@${SERVER_IP_1} /"rm -rf ${SERVER_DEPLOY_DIR}build; tar -xvf ${SERVER_DEPLOY_DIR}build.tar -C ${SERVER_DEPLOY_DIR}/""        }      }    }  }}

稍做解釋:

這個部署腳本分為三個步驟:

  • Checkout code(在指定 git 倉庫通過指定證書文件獲取代碼)
  • Build(通過指定命令進行編譯,將編譯后的產物存檔)
  • Deploy(通過指定命令部署)

在 Build 階段前后,我們各做了一些工作,以求每次部署可以復用 node_modules,因為下載 node_modules 的時間可能很長,而并不是每次都會修改 package.json,所以其實 node_modules 大概率可以復用;

編譯前:

  • 看指定 node_modules 緩存文件夾是否存在,不存在則新建該文件夾;
  • 看緩存文件夾中是否有 node_modules 文件夾,如果沒有則新建該文件夾;并且將該文件夾軟連接到當前目錄;
  • 看緩存文件夾中是否有 yarn.lock 文件,如果有則移動到當前文件夾;

編譯后:

  • 移除 node_modules 文件夾的軟連接;
  • 將 yarn.lock 文件移動到緩存文件夾中;

這里使用了 yarn install 的某些特性:

  • 沒有 node_modules 或者 yarn.lock 時會安裝全量依賴;
  • 有 node_modules 和 yarn.lock 但是 yarn.lock 和 package.json 不匹配時,會安裝所需依賴;
  • 有 node_modules 和 yarn.lock,且 yarn.lock 和 packge.json 配置時,跳過安裝依賴;

使用

編譯和部署

編譯和部署直接點擊 Build Now 即可;

回滾

回滾的本質其實是:重新部署某個歷史版本。在 Build History 找到想要重新部署的版本,點擊 Restart from Stage,在新頁面中選擇 Stage Name 為 Deploy。

其他

若是想要進入 docker container 交互,可以通過以下命令

docker exec -i -t [dockername] /bin/bash

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久久久久久网站| 成人a视频在线观看| 在线视频国产日韩| 精品国偷自产在线| 日本午夜精品理论片a级appf发布| 97人人做人人爱| 国产日韩亚洲欧美| 国产精品免费一区二区三区都可以| 亚洲成人激情小说| 亚洲欧洲免费视频| 成人国产精品免费视频| 欧美另类在线观看| 国产ts人妖一区二区三区| 欧洲美女免费图片一区| 亚洲福利视频二区| 亚洲精品小视频| 日韩中文字幕视频| 国外成人免费在线播放| 亚洲美女中文字幕| 日韩视频在线免费观看| 大胆欧美人体视频| 97超级碰在线看视频免费在线看| 在线观看久久久久久| 欧美黑人巨大xxx极品| 久久97精品久久久久久久不卡| 久久久久久久久中文字幕| 日韩av影片在线观看| 欧美大片va欧美在线播放| 国产精品欧美一区二区三区奶水| 国产精品中文字幕在线观看| 国产精品久久一区主播| 国产在线98福利播放视频| 国产精品日韩欧美| 欧美激情精品久久久久久黑人| 欧美国产视频一区二区| 亚洲第一精品夜夜躁人人躁| 91牛牛免费视频| 91久久久久久国产精品| 欧美成人一区二区三区电影| 亚洲天堂成人在线视频| 久久亚洲精品成人| 九九久久久久99精品| 亚洲欧洲一区二区三区久久| 久久久久在线观看| 久久亚洲精品视频| 最近的2019中文字幕免费一页| 国产一区二区三区在线观看视频| 尤物精品国产第一福利三区| 免费97视频在线精品国自产拍| 国产免费观看久久黄| 久久亚洲国产精品成人av秋霞| 91精品视频免费| 亚洲色图综合久久| 欧美日韩中文字幕在线视频| 欧日韩在线观看| 国产精品久久久久999| 日韩在线观看成人| 久久精品91久久久久久再现| 亚洲免费av电影| 国产欧美日韩最新| 91久久在线视频| 亚洲加勒比久久88色综合| 亚洲国产欧美一区二区丝袜黑人| 欧美激情视频一区二区三区不卡| 亚洲欧美成人一区二区在线电影| 久久精品亚洲国产| 91在线视频九色| 亚洲va久久久噜噜噜| 在线精品91av| 国产精品国产三级国产aⅴ浪潮| 少妇激情综合网| 欧美精品videosex牲欧美| 亚洲欧美综合v| 久久精品电影网| 成人黄色免费片| 日韩有码视频在线| 91亚洲va在线va天堂va国| 欧美老女人在线视频| 亚洲一区二区三区乱码aⅴ蜜桃女| 中文字幕亚洲激情| 久久97久久97精品免视看| 尤物yw午夜国产精品视频明星| 91精品国产综合久久香蕉| 成人在线小视频| 国产做受高潮69| 日本亚洲欧洲色α| 久久福利视频导航| 欧美性猛交xxxx乱大交| 久操成人在线视频| 美乳少妇欧美精品| 国产精品永久免费| 国产精品免费久久久久影院| 国产精品视频导航| 欧美www在线| 日韩精品视频在线播放| 5566日本婷婷色中文字幕97| 欧美性xxxxx极品娇小| 欧美日韩国产精品一区二区不卡中文| 日韩美女在线看| 国内伊人久久久久久网站视频| 91色琪琪电影亚洲精品久久| 亚洲区免费影片| 久久精彩免费视频| 欧美激情奇米色| 日韩欧美国产成人| 粗暴蹂躏中文一区二区三区| 久久久久久久国产精品视频| 国内精品久久久久久中文字幕| 亚洲人线精品午夜| 色悠悠国产精品| 欧美日韩一区二区在线| 91国产精品视频在线| 国产精品普通话| 91精品国产高清久久久久久| 97视频在线观看播放| 国产精品第100页| 亚洲欧美综合精品久久成人| 国产成人在线视频| 亚洲白虎美女被爆操| 欧美日韩亚洲一区二| 亚洲精品一区二区在线| 国产精品久久电影观看| 日产精品久久久一区二区福利| 精品无码久久久久久国产| 国产精品久久久久高潮| 欧美一区二区三区免费视| 成人免费淫片aa视频免费| 日韩在线欧美在线| 日韩欧美在线视频观看| 成人性教育视频在线观看| 国产精品自产拍在线观看| 欧美自拍视频在线观看| 久久久久国产精品免费网站| 欧美猛交ⅹxxx乱大交视频| 国产精品三级美女白浆呻吟| 成人亚洲欧美一区二区三区| 久久久免费电影| 亚洲视频777| 成人av在线网址| 亚洲最大在线视频| 欧美激情综合色综合啪啪五月| 亚洲欧美精品suv| 国内精品久久久| 国产精品白嫩美女在线观看| 日韩有码视频在线| 亚洲白虎美女被爆操| 亚洲男人的天堂网站| 91在线|亚洲| 2019亚洲日韩新视频| 亚洲男人的天堂网站| xvideos亚洲人网站| 亚洲视频第一页| 久久久久久久久久久成人| 亚洲精品美女久久久| 亚洲视频一区二区三区| 国产日韩欧美视频在线| 欧美日韩国产成人在线观看| 国产www精品| 2019亚洲男人天堂| 国产成人拍精品视频午夜网站| 亚洲精品国产精品国自产观看浪潮| 日韩欧美有码在线| 国产精品99久久久久久白浆小说| 国产精品视频久久久久|