婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 快速掌握使用Docker搭建開發環境

快速掌握使用Docker搭建開發環境

熱門標簽:怎么找到沒有地圖標注的店 河南防封號電銷機器人是什么 400電話辦理介紹信 麗江真人語音電話外呼系統 上海申請高400開頭的電話 10086外包用的什么外呼系統 福州企業電銷機器人排名 打400電話怎么辦理收費 宿城區電話機器人找哪家

隨著平臺的不斷壯大,項目的研發對于開發人員而言,對于外部各類環境的依賴逐漸增加,特別是針對基礎服務的依賴。這些現象導致開發人員常常是為了簡單從而直接使用公有的基礎組件進行協同開發,在出現并行開發的情況特別是針對數據庫的變動或數據的更改常常會導致其他開發人員無辜增加問題的排查時間,導致整體的開發效率降低,同時對于遠程協助也造成了巨大的障礙。為了解決上述存在的問題,將會利用Docker Compose技術輔助開發人員對于開發環境的搭建,最終實現開發人員只要裝有Docker就可以完成整個開發環境的搭建。

知道一個事物和實現這個事物是完全不同的事情。從Docker誕生那天開始,我們就夢想著諸如“15秒部署一個項目”,“版本可控開發環境”,以及時髦的運維用語,如“滾動開發”,“軟件定義架構”。處于浪尖的行業人士都在以前所未有的熱情參與到將很多名詞和工具,例如“編排”,“服務發現”等,定義,重新定義以及商品化大潮中。

我認為這股大潮的催化劑來自于Docker在應用和基礎架構之間帶來的美妙接口和抽象。開發者可以在不必知道底層架構情況下談論基礎架構,操作人員也不必花大量時間研究如何安裝和管理軟件。肯定有什么力量隱藏在看似簡單的外表下使得大家生活簡化,更加高效。

現實世界時殘酷的,不要想當然認為采用一項新技術只會帶來享受。過去幾年經過一些項目的磨練,經歷過奇怪的環境,我認為Docker也不例外。但是某一個經驗一般可以直接應用到項目的下一階段。要想從Docker獲得功力,必須浸淫到實際項目中去磨練。

過去一年中,我全身心投入去教授我的關于Dokcer基礎的書,Docker in Action。

我注意到幾乎所有人開始學習Docker技術時都會糾結于如何創建開發環境,然后才能了解生態系統之內大家的關系。每個人開始都會認為使用Docker會使環境搭建變的簡單,也不是完全不對,有很多“容器化”教程都涵蓋了創建一個image和如何將某個工具打包到容器(Container)內,但是如何將開發環境Docker化是一個完全不同的事情。

作為一個踏坑先驅者,我可以分享一下我的經驗。

我曾經是一個資深Java使用者,但這個分享的經驗不是關于Java的,而是圍繞著我使用Go和Node開發應用發生的。我有一定的Go開發經驗,主動提高在這一領域的能力。進入一個不熟悉領域迅速上手碰到的主要問題就是如何獲得正確的工作流,而且我還比較厭惡在筆記本上不斷安裝軟件,這些都驅使我嘗試用Docker做這些工作,或者有時候采用Vagrant。

我所參與的項目是用Go寫一個標準的REST服務,基于gin,依賴Redis和NSQ的某些庫和服務。也就是說需要import一些本地運行著的Redis和NSQ實例的庫,更有趣的是我還使用了一些服務于NGINX的靜態資源。

對門外漢來說,Go是一種編程語言,實際上還有一種命令行工具也叫“go”。從依賴型管理、編譯、測試用例到其它各種任務都使用它。對Go項目來說,除了Git和一個好用的編輯器,剩下就是跟它打交道了。然而還是有一個問題,我不想在筆記本上安裝Go,筆記本上我只想安裝Git和Docker。這些問題限制了其他環境下的兼容性,并且對新手來說降低了門檻。

這個項目有運行時依賴,意味著此工具集需要為簡單環境定義和編排而包括Docker Compose。 很多人會為此感到不適應,那么我們怎么辦?開始創建一個Dockerfile或者docker-compose.yml?好吧,先讓我告訴大家我是怎么辦的,然后解釋為什么這么做。

例如在此案中www.sangpi.com中我希望我的本地包是完全自動的。我不喜歡手動逐條執行步驟,而且我的vim配置文件也很簡單。我只想從“是否運行”層次控制運行環境。本地化開發環境目標被快速復制,不僅用于提高生產效率,而且用于共享Docker images。 我最終完成了Dockerfile,用來產生包含Go,Node,和我最經常使用的打包工具Gulp的images。 此Dockerfile沒有嵌入代碼,image也沒有嵌入Gulpfile。相反的,在一個建立了的GOPATH(Go workspace的根路徑)上定義了一個卷。

最終,我為此images設置了給gulp提供服務的entrypoint,設置默認命令來監控。輸出images肯定不是我稱為build artifact的東西,從這個意義上來講,此環境唯一做的就是提供了一個運行實例,幫助我們判斷是否代碼運行。對我的場景來說,運行的非常棒。而我將“artifacts”用于稱呼另外一個build。

下一步我用Compose定義本地開發環境。首先定義了在images中用到的所有Docker Hub 中定義的依賴服務,將他們連接到某一個“目標”服務。此服務引用了新Dockerfile從哪里生成,將本地源目錄綁定到新image期望輸出的掛載點,暴露一些可以測試的端口。然后,添加了一個服務,可以不斷地向目標服務循環發起一系列集成測試。最終,我添加了NGINX服務,掛載了有很多配置文件和靜態assets的卷。使用卷的好處在于重復使用配置文件和assets而不用重建image。

所有代碼最終會在電腦上生成本地開發環境,當使用:

docker-compose up –d

時,會啟動git clone,然后循環運行;不需要重建image或者重啟容器。每當.go文件發生變化,Gulp就會重建,并且在運行的容器中重啟我的服務。就這么簡單。

創建此環境很簡單嗎?不盡然,但是確實實現了。難道不用容器,而在本地直接安裝Go,Node,Gulp不是更簡單嗎?也許在這個場景是,但也只限于用Docker運行此依賴服務。我不喜歡這樣。

我曾經要管理這些工具的不同版本,而產生了復雜的環境變量,到處生成artifacts。我不得不提醒同事們注意這些容易發生沖突的環境變量,他們太缺乏集中版本控制了。

也許你并不喜歡上面描述的環境,或者對項目有不同的需求。很好,確實是這樣,本文并不是讓所有工具都運行在Docker中,如果這樣就說明并沒考慮過要解決什么問題。

當我設計這個環境時,考慮過下面幾個問題,顧慮,以及某些潛在答案。當開始Docker工作環境時,就會發現實際情況可能比自己的回答更糟糕。

當你考慮打包和環境時,最先考慮的因素是什么?

這個確實是最重要的問題。在此場景中,有幾個選項。我可以使用go直接在容器內編程,看起來如下:

其實這個示例中大部分bolierplate可以通過shell別名或者函數隱藏,感覺Go是安裝在自己的設備中似的,還可以跟Go工作流聯系,創建artifacts。這些特性對非服務項目有益處,但是對庫和軟件項目就不一定了。

假設你已經在使用Gulp、make、ant或者其他腳本,那么可以繼續,并且使用Dokcer作為這些工具的目標。

另外一種方法,我可以通過使用Dockerbuild來定義和控制我的build,獲得更多面向Docker的經驗。代碼如下:

使用Dokcer來控制build有若干好處。可以使用以前編譯好的image,Dockerfilebuilds使用緩存方法,使得編譯工作只重復最小的步驟(假設有一個很棒的Dockerfile)。最后,這些builds生成的images也可以跟其他開發者共享。

這個案例中,我使用golang資源庫中的onbuildimage作為基礎。其中包括一些很棒的下載依賴包邏輯。這個方法會生成可以方便用于其他非生產環境的Dockerimage。這個方法對于生產級別的image的問題在于,必須有步驟避免大image并且包括某些初始化腳本,用于啟動和監控服務前驗證狀態。

有意思的是,Docker使用一系列腳本,Makefiles和Dockerfiles。build系統相對很健壯了,負責各種游戲測試,linting等,以及各種操作系統和架構的artifacts。本場景中,容器是用來產生二進制的工具,然而是從一個本地build image中實現的。

擴充Docker build的選項,可以使用Compose來定義一整套開發環境。

Compose負責環境管理。如果覺得系統非常干凈并不奇怪,Compose把所有事情都聯系起來,優化卷管理,當images缺失時自動build,匯總日志輸出。我之所以選這些開關是為了簡化服務依賴,也因為它能生成我需要的artifacts。

這個示例是一個運行時容器,Compose或者Docker都有合適的工具做到這點。此場景中,也可能更需要一個分布式image,或者可能希望build可以為本機產生一個二進制文件。

如果期望獲得想要的image,必須確保源碼或者預編譯庫在build時候嵌入image中。build時候沒有掛載卷,也即需要每次重復時都要重建image。

如果希望在容器內部產生某些artifacts,則需要引入掛載卷。使用Docker命令行或者Compose環境可以很容易實現。但是要注意,除非容器在運行,否則build并不工作,也就意味著不能只用dockerbuild。

匯總

目前沒有Docker方式創建開發環境。Docker是一個可編排工具,不只是圣書。與其使用別人已有的dockerbuild系統,不如花一定時間學習此工具,明確自己的需求,然后創建適合自己的Docker環境。

到此這篇關于快速掌握使用Docker搭建開發環境的文章就介紹到這了,更多相關Docker搭建開發環境內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

標簽:朝陽 荊門 面試通知 連云港 隴南 雞西 運城 遵義

巨人網絡通訊聲明:本文標題《快速掌握使用Docker搭建開發環境》,本文關鍵詞  快速,掌握,使用,Docker,搭建,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《快速掌握使用Docker搭建開發環境》相關的同類信息!
  • 本頁收集關于快速掌握使用Docker搭建開發環境的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产精品色噜噜| 中文字幕一区二区不卡| 久久精品人人做| 国产在线麻豆精品观看| 欧美r级在线观看| 国产精品一二三四区| 国产精品久久久久久久浪潮网站| 日韩中文字幕区一区有砖一区 | 91免费视频观看| 亚洲精品国产精华液| 欧美性猛交一区二区三区精品| 亚洲一区自拍偷拍| 91精品欧美综合在线观看最新| 激情久久五月天| 国产精品第四页| 欧美精品久久久久久久多人混战 | 欧美怡红院视频| 六月丁香综合在线视频| 国产亚洲欧美激情| 欧美自拍偷拍午夜视频| 日本午夜精品一区二区三区电影| 欧美变态口味重另类| 91亚洲精品久久久蜜桃| 日本中文字幕不卡| 亚洲色欲色欲www| 日韩一区二区视频在线观看| 成人性视频免费网站| 天天综合色天天| 国产精品美女久久久久久久| 91麻豆精品国产91久久久久| 国产精品主播直播| 三级成人在线视频| **性色生活片久久毛片| 欧美精品一区二区三区久久久 | 欧美日韩美女一区二区| 黄网站免费久久| 午夜精品成人在线| 亚洲欧美日韩在线| 久久免费午夜影院| 日韩欧美你懂的| 欧美久久久一区| 色噜噜狠狠成人中文综合| 国产高清成人在线| 久久精品国产亚洲a| 亚洲午夜国产一区99re久久| 国产精品久久久99| 久久久国产精华| 久久亚洲精品小早川怜子| 91精品免费在线观看| 欧美性大战xxxxx久久久| 99国内精品久久| www.久久精品| 成人黄色在线视频| 免费精品视频最新在线| 亚洲国产精品一区二区久久恐怖片| 国产精品久久久久影院老司| 久久久精品国产免大香伊| 91精品国产乱码久久蜜臀| 欧美日韩黄视频| 欧美精品亚洲二区| 在线观看免费视频综合| 在线一区二区视频| 色婷婷综合久色| 色噜噜狠狠成人网p站| 欧美在线影院一区二区| 欧美日韩一级大片网址| 欧美日韩日本视频| 日韩欧美一区在线| 亚洲精品一区二区三区福利| 久久这里只有精品6| 国产日产精品一区| 亚洲欧洲av一区二区三区久久| 国产精品久久久久久亚洲伦 | 亚洲欧洲日产国产综合网| 欧美激情一区在线观看| 国产精品蜜臀在线观看| 国产精品国产自产拍高清av王其| 国产农村妇女精品| 伊人一区二区三区| 亚洲无人区一区| 久久国产精品99精品国产| 国产激情偷乱视频一区二区三区 | 色综合中文字幕| 欧美午夜视频网站| 日韩免费一区二区| 中文在线一区二区| 中文字幕一区二区三区视频| 亚洲成av人片| 欧美人与禽zozo性伦| 欧美日韩精品是欧美日韩精品| 91精品国产一区二区三区香蕉| 欧美情侣在线播放| 久久久精品免费免费| 国产精品久久久久久久久动漫| 亚洲成人7777| 国模少妇一区二区三区| 色婷婷av一区二区三区大白胸| 99精品久久99久久久久| 欧美女孩性生活视频| 国产精品久久久久9999吃药| 一区二区三区在线观看视频| 久久精品国产澳门| 91视频.com| 日韩精品专区在线影院重磅| 久久九九久久九九| 亚洲综合男人的天堂| 国产一区二区精品久久91| 色八戒一区二区三区| 精品区一区二区| 中文字幕一区二区三区在线观看 | 亚洲精品久久久久久国产精华液| 日本色综合中文字幕| 黄色资源网久久资源365| 在线观看av一区二区| 久久日一线二线三线suv| 亚洲欧美区自拍先锋| 国产精品资源网站| 精品久久国产97色综合| 亚洲美女一区二区三区| 国产一区二区精品久久99| 欧美性感一类影片在线播放| 中文字幕亚洲一区二区va在线| 久久爱www久久做| 欧美一区二区女人| 亚洲国产日韩一区二区| 91蜜桃在线观看| 中文字幕在线不卡一区| 国产成人午夜视频| 久久精品欧美一区二区三区不卡| 久99久精品视频免费观看| 欧美体内she精高潮| 亚洲精品伦理在线| 在线视频欧美精品| 亚洲一区在线看| 欧美日韩一区二区不卡| 视频一区在线播放| 欧美一级理论片| 麻豆精品一二三| 欧美成人精精品一区二区频| 五月激情丁香一区二区三区| 欧美日本乱大交xxxxx| 无码av免费一区二区三区试看| 欧洲在线/亚洲| 日韩黄色免费网站| 日韩欧美一级片| 精东粉嫩av免费一区二区三区| 欧美videos中文字幕| 狠狠狠色丁香婷婷综合激情| www亚洲一区| av网站免费线看精品| 亚洲精品视频在线| 欧美日韩一区二区三区在线看| 日韩不卡一二三区| 久久久亚洲国产美女国产盗摄| 久久9热精品视频| 国产亲近乱来精品视频| 91在线观看高清| 午夜久久久久久电影| 欧美精品v日韩精品v韩国精品v| 美女视频黄久久| 欧美精品一区二区三区在线播放| 国产999精品久久| 亚洲va在线va天堂| 久久精品欧美日韩| 欧美在线|欧美| 精品一区二区三区在线播放| 国产精品久久看| 欧美日韩三级一区二区| 国产高清精品网站| 亚洲国产综合色| 久久久国产午夜精品| 91视频在线观看| 国产美女视频一区| 亚洲自拍另类综合| 欧美电视剧在线观看完整版| aaa欧美色吧激情视频| 午夜免费久久看| 中文字幕在线不卡一区| 精品少妇一区二区三区在线播放| 97精品久久久午夜一区二区三区 | 天天av天天翘天天综合网| 日韩三级视频中文字幕| av电影在线观看完整版一区二区| 日本在线不卡一区| 亚洲日本va在线观看| 久久婷婷国产综合精品青草| 欧美日韩国产中文| 色哦色哦哦色天天综合| 国产成人免费高清| 麻豆成人免费电影| 亚洲一区二区av在线| 亚洲女子a中天字幕| 国产精品久99| 国产精品私人影院| 欧美激情中文字幕一区二区| 日韩午夜av一区| 日韩西西人体444www| 欧美日韩夫妻久久| 欧美天堂亚洲电影院在线播放 | 色网综合在线观看|