国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

gitlab-ci坑后感與指北

jerry / 3112人閱讀

摘要:本文的目的最主要是備忘其次是分享療效并不能讓你一下子掌握這只是一個(gè)比較完整的解決方案其他基礎(chǔ)知識(shí)自行補(bǔ)充基調(diào)首先這不是屠龍刀不要奢望一篇文章可以走遍天下這里只是提供一個(gè)具體的落地方案一個(gè)具體的技術(shù)選型階段代碼倉(cāng)庫(kù)關(guān)于代碼倉(cāng)庫(kù)本文選取的方案是

本文的目的:

最主要是備忘, 其次是分享

療效:

并不能讓你一下子掌握CI/CD, 這只是一個(gè)比較完整的解決方案,其他基礎(chǔ)知識(shí),自行補(bǔ)充.


基調(diào)
首先,這不是屠龍刀,不要奢望一篇文章可以走遍天下.這里只是提供一個(gè)具體的落地方案, 一個(gè)具體的技術(shù)選型.

階段1: 代碼倉(cāng)庫(kù)

關(guān)于 代碼倉(cāng)庫(kù), 本文選取的方案是 gitlab

gitlab的搭建:

以目前的情況來(lái)說(shuō), 推薦使用docker來(lái)搭建你的系統(tǒng), 不然你會(huì)陷入各種膜明其妙的問(wèn)題.

docker的知識(shí), 請(qǐng)自行補(bǔ)充一下,篇幅有限不能展開細(xì)說(shuō).

在這里我推薦一個(gè):

https://hub.docker.com/r/sameersbn/gitlab/

打開以后直接搜索Quick Start, 按照docker-compose的方式啟動(dòng)你的gitlab.

不要對(duì)英文心存恐懼 ---- 孔子

下載好 docker-compose.yml之后不要急著啟動(dòng), 需要修改幾個(gè)參數(shù):

需要學(xué)習(xí)一點(diǎn)點(diǎn)yml的知識(shí), 大約5分鐘, 自行g(shù)oogle

GITLAB_SECRETS_DB_KEY_BASE,

GITLAB_SECRETS_SECRET_KEY_BASE,

GITLAB_SECRETS_OTP_KEY_BASE

上面三個(gè)是gitlab用于加密時(shí)用的key, 隨便給個(gè)長(zhǎng)度64的字符串, 這塊不做 深究.

GITLAB_ROOT_EMAIL

GITLAB_ROOT_PASSWORD

上面兩個(gè)就是初始化時(shí)管理員賬號(hào)的賬號(hào)密碼, 按自己的需要填寫

GITLAB_HOST

這是 gitlab 內(nèi)部使用的地址, 這關(guān)系到你gitlab頁(yè)面上的項(xiàng)目地址,沒設(shè)置的話, 到時(shí)候顯示的是127.0.0.1, 這個(gè)鬼才能clone下來(lái).

這個(gè) host 一旦設(shè)置, 初始化完就改不了了, 所以一定要在第一次啟動(dòng)之前 就設(shè)置好.
啟動(dòng)

docker-compose up

一系列的初始化信息以后, 你就能訪問(wèn)你的gitlab了.

默認(rèn)是 http://{你的IP}:10080

其他關(guān)于gitlab的使用技巧, 就不深入了.
能關(guān)注這篇文章的都不是萌新了,這些內(nèi)容自己補(bǔ)充吧.

階段2: 提交觸發(fā)

接上文.

gitlab-ci在最新版的gitlab已經(jīng)是內(nèi)置的了, 只要項(xiàng)目里有.gitlab-ci.yml,同時(shí)有對(duì)應(yīng)的gitlab-runner, 就能實(shí)現(xiàn)CI, 相比之下不需要太多的配置.

名詞解釋:

.gitlab-ci.yml:

這是gitlab-ci使用的任務(wù)描述文件, 里面主要是定義CI的過(guò)程需要執(zhí)行哪些行為, 簡(jiǎn)單說(shuō)就是, 要進(jìn)行哪幾個(gè)步驟, 每個(gè)步驟是哪些命令.

gitlab-runner:

另一個(gè)程序, 也可以用docker啟動(dòng), 就是負(fù)責(zé)執(zhí)行 CI 任務(wù)的機(jī)器人, runner這塊后面會(huì)展開講.


啟動(dòng)并注冊(cè)gitlab-runner

我們還是使用docker來(lái)啟動(dòng),這是一個(gè)大方向

docker run -d --name gitlab-runner --restart always 

-v /srv/gitlab-runner/config:/etc/gitlab-runner 

-v /var/run/docker.sock:/var/run/docker.sock 

gitlab/gitlab-runner:latest


想深入了解的話, 請(qǐng)看 

https://docs.gitlab.com/runne...

敲黑板!!

在這里, 我們將宿主機(jī)的docker.sock映射進(jìn)去,讓runner可以跟宿主用同一個(gè)daemon, (意味著你進(jìn)去runner內(nèi)部執(zhí)行docker images是可以看到外面的鏡像列表的), 這樣做是埋下一個(gè)伏筆, 以便后面階段使用dind(docker in docker)時(shí), 獲得更好的體驗(yàn).


繼續(xù)

好了, 這個(gè)時(shí)候你啟動(dòng)了一個(gè)runner, 你要告訴它應(yīng)該到哪里去"服役",

這一步叫做: 注冊(cè)

注冊(cè)runner的方式請(qǐng)看 

https://docs.gitlab.com/runne...

不過(guò), 還是請(qǐng)你使用以下命令來(lái)注冊(cè):

docker exec -it gitlab-runner gitlab-runner register 

--docker-volumes /var/run/docker.sock:/var/run/docker.sock 

--docker-privileged

這里使用了兩個(gè)參數(shù), 都是為了 docker in docker 能得到更好的體驗(yàn)而服務(wù)的.

輸入以上命令后, 根據(jù)提示填寫信息, 其中:

host,token 這些, 請(qǐng)打開你剛裝好的gitlab, 進(jìn)入 Admin area-Runners ,然后照著填寫就是了

特別注意期間會(huì)讓你選一個(gè)executor 類型, 個(gè)人推薦最好的方式是docker , 至于shell這種方式, 玩玩可以,實(shí)際使用時(shí)副作用太多.

更多參數(shù)的細(xì)節(jié), 自行研究.

完成以上步驟之后, 你在gitlab - Admin area-Runners 頁(yè)面就能看到注冊(cè)好的runner了, 當(dāng)然你現(xiàn)在還是感覺不到它的作用.

這個(gè)環(huán)節(jié)內(nèi)容比較多, 操作比較多, 走到這里建議休息一下喝杯茶.



階段3: Runner Job

這個(gè)階段, 是指代碼提交以后, gitlab-runner會(huì)自動(dòng)讀取項(xiàng)目的.gitlab-ci.yml, 運(yùn)行里面定義的每個(gè)Job.

這里給出一個(gè)極簡(jiǎn)的.gitlab-ci.yml例子,

它做的就是, 在提交代碼以后, 自動(dòng)的測(cè)試, 自動(dòng)的構(gòu)建, 自動(dòng)的發(fā)布 :

stages:
  - test
  - build
  - deploy

job_01:
  stage: test
  image: dev_tool/node_builder:1.0.0
  script: 
   - npm install --registry=https://registry.npm.taobao.org
   - node server.js &
   - node test_api.js

job_02:
  stage: build
  image: gitlab/dind
  script:
  - docker build -t ci-demo:latest .
   
job_03:
  stage: deploy
  image: dev_tool/rancher-cli:latest
  script:
  - rancher-tool init
  - rancher up -d  --pull --force-upgrade --confirm-upgrade

一目了然, 上面的第一個(gè)定義: stages 數(shù)組,

意思是這個(gè)項(xiàng)目的CI/CD過(guò)程要執(zhí)行三個(gè)步驟(stage),

分別是test測(cè)試-build編譯-deploy發(fā)布

然后下面的三個(gè)job_*,名字是隨意的, 重點(diǎn)是里面的stage屬性,

告訴gitlab-ci這個(gè)任務(wù)是在哪個(gè)stage執(zhí)行的,

一個(gè)stage你可以寫很多個(gè)job

敲黑板!!!

需要注意的是, 我們之前選擇了docker executor, job里面就要聲明image屬性,指定這個(gè)Jobscripts要在哪個(gè)image里面運(yùn)行.

重點(diǎn)說(shuō)明!! 再次大力敲黑板!!

這里第二步使用了gitlab/dind , 仔細(xì)看script, 這是在一個(gè)容器里面去構(gòu)建一個(gè)鏡像, 為了整體體驗(yàn)構(gòu)建效率著想, 我們之前注冊(cè)runner的時(shí)候,將宿主機(jī)的docker.sock映射進(jìn)去是十分必要的!!
(重新翻上去看吧)

看到這里, 聰明的朋友已經(jīng)發(fā)現(xiàn)了,

我們需要自己打造一批用于運(yùn)行Job的基礎(chǔ)鏡像, 這些鏡像里要預(yù)先安裝好我們需要的依賴環(huán)境.

舉個(gè)栗子:

你要在build這一步做webpack打包的話, 你要準(zhǔn)備好一個(gè)內(nèi)部安裝好webpack的鏡像(相關(guān)的node,npm之類就更不用說(shuō)了)

聽起來(lái)好麻煩?

也不是, 這是個(gè) 功在當(dāng)代,利在千秋 的行為, 前期打造好基礎(chǔ)鏡像, 后面的項(xiàng)目就可以很容易寫CI Job了.

更多 gitlab-ci.yml 的高級(jí)寫法,還是建議看官方文檔
https://docs.gitlab.com/ee/ci...

階段4: 坐享其成 && 總結(jié)

如果按照上面的步驟把這個(gè)系統(tǒng)搭建起來(lái)以后, 你應(yīng)該已經(jīng)能夠感受到gitlab-ci帶來(lái)的好處了.

現(xiàn)在你只管提交代碼, 就能快速看到新功能集成到相應(yīng)的環(huán)境了.

此后, 你只要寫好每一步的Job 就可以了.

尤其是測(cè)試這個(gè)環(huán)節(jié).

尤其是測(cè)試這個(gè)環(huán)節(jié).

尤其是測(cè)試這個(gè)環(huán)節(jié).


后記

gitlab 真的很吃資源, 虛擬機(jī)玩夠嗆, 團(tuán)隊(duì)用的話, 建議裝一臺(tái)PC來(lái)搭建.

基礎(chǔ)鏡像別偷懶, 多打磨,讓你的scripts可以更簡(jiǎn)潔

更進(jìn)一步的話, 自己開發(fā)一系列的命令行工具, 讓你的scripts更強(qiáng)大.

有事找我, 包教會(huì).

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/28033.html

相關(guān)文章

  • 持續(xù)集成之.gitlab-ci.yml篇

    摘要:因?yàn)榭梢园惭b到不同的機(jī)器上,所以在構(gòu)建任務(wù)運(yùn)行期間并不會(huì)影響到的性能。注冊(cè)打開中的項(xiàng)目頁(yè)面,在項(xiàng)目設(shè)置中找到在運(yùn)行的機(jī)器上,用命令行注冊(cè),比如按照提示一步一步安裝就可以了。任務(wù)將按此順序執(zhí)行。當(dāng)然,這是不符合語(yǔ)義的。 在介紹.gitlab-ci.yml之前,我們先看幾個(gè)概念: GitLab Runner 一般來(lái)說(shuō),構(gòu)建任務(wù)都會(huì)占用很多的系統(tǒng)資源 (譬如編譯代碼),而 GitLab CI...

    Ajian 評(píng)論0 收藏0
  • React Native項(xiàng)目自動(dòng)化打包發(fā)布

    摘要:所以在此給大家分享一下不使用構(gòu)建工具實(shí)現(xiàn)項(xiàng)目自動(dòng)化打包發(fā)布的思路。對(duì)于一個(gè)前端項(xiàng)目來(lái)說(shuō),自動(dòng)化的構(gòu)建是很有必要的,同時(shí)我們也可以通過(guò)實(shí)現(xiàn)更多的功能比如代碼檢測(cè),單元測(cè)試等等。另外這種思路同樣適用于其他項(xiàng)目等前端項(xiàng)目,等移動(dòng)端項(xiàng)目。 今天這篇文章的目的是在rn項(xiàng)目的構(gòu)建,并不會(huì)涉及到rn框架或者使用的講解,說(shuō)起構(gòu)建,特別是前端構(gòu)建大家應(yīng)該很快會(huì)想到webpack、Grunt、 Gulp等...

    desdik 評(píng)論0 收藏0
  • 基于 GitLab CI 搭建前端自動(dòng)構(gòu)建環(huán)境

    摘要:什么是持續(xù)集成持續(xù)集成,簡(jiǎn)稱指的是,頻繁地一天多次將代碼集成到主干。如圖什么是一次其實(shí)相當(dāng)于一次構(gòu)建任務(wù),里面可以包含多個(gè)流程,如安裝依賴運(yùn)行測(cè)試編譯部署測(cè)試服務(wù)器部署生產(chǎn)服務(wù)器等流程。參考鏈接用進(jìn)行持續(xù)集成 什么是持續(xù)集成 ? 持續(xù)集成(Continuous integration,簡(jiǎn)稱CI)指的是,頻繁地(一天多次)將代碼集成到主干。 GitLab CI 什么是 GitLab CI...

    Warren 評(píng)論0 收藏0
  • webkit內(nèi)核瀏覽器自定義滾動(dòng)條樣式

    摘要:滾動(dòng)條兩端的按鈕。內(nèi)層軌道,滾動(dòng)條中間部分除去。有如下功能若是水平滾動(dòng)條,則屬性不起作用,屬性用來(lái)控制滾動(dòng)條相應(yīng)部分豎直方向高度若是豎直滾動(dòng)條,則屬性不起作用,屬性用來(lái)控制相應(yīng)部分的寬度。 CSS ::-webkit-scrollbar { /* 1 */ } ::-webkit-scrollbar-button { /* 2 */ } :...

    testbird 評(píng)論0 收藏0
  • webkit內(nèi)核瀏覽器自定義滾動(dòng)條樣式

    摘要:滾動(dòng)條兩端的按鈕。內(nèi)層軌道,滾動(dòng)條中間部分除去。有如下功能若是水平滾動(dòng)條,則屬性不起作用,屬性用來(lái)控制滾動(dòng)條相應(yīng)部分豎直方向高度若是豎直滾動(dòng)條,則屬性不起作用,屬性用來(lái)控制相應(yīng)部分的寬度。 CSS ::-webkit-scrollbar { /* 1 */ } ::-webkit-scrollbar-button { /* 2 */ } :...

    Achilles 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<