日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

docker二进制代码编译

發布時間:2024/4/17 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 docker二进制代码编译 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Contents

  • docker二進制代碼編譯流程
  • 其他編譯方法
  • Makefile

docker二進制代碼編譯流程

docker如何編譯,在?官網?進行了介紹。

其實很簡單,就是在docker源碼中有一個makefile文件,執行make,就可以進行編譯了。

我們從源碼來看一下make的過程。

首先看一下Makefile。

... DOCKER_MOUNT := $(if $(BINDDIR),-v "$(CURDIR)/$(BINDDIR):/go/src/github.com/docker/docker/$(BINDDIR)") DOCKER_RUN_DOCKER := docker run --rm -it --privileged -e TIMEOUT -e BUILDFLAGS -e TESTFLAGS -e TESTDIRS -e DOCKER_GRAPHDRIVER -e DOCKER_EXECDRIVER $(DOCKER_MOUNT) "$(DOCKER_IMAGE)" ... binary: build$(DOCKER_RUN_DOCKER) hack/make.sh binary ... build: bundles docker build -t "$(DOCKER_IMAGE)" . ... bundles:mkdir bundles

執行make binary。會首先創建bundles文件夾,然后執行docker build,通過dockerfile創建鏡像(這一步其實可以直接從官網pull鏡像而不用自己build,下面詳細講)。然后將容器run起來,通過-v參數,將容器中的bundles同物理機的該路徑下的bundles文件夾綁定起來,然后啟動容器。容器執行了hack/dind命令,編譯docker,將編譯好的文件放在了bundles中。從而在物理機上也可見。

對于docker的二進制代碼編譯采取了一種極為dockerful的方式。因為搭建docker的編譯環境可能會較為繁瑣,docker直接提供給了一個?docker-dev?的鏡像給用戶。獲得這個鏡像有兩種方式,一種是直接下載。用戶只需要下載這個鏡像,就可以在這個鏡像中進行docker的二進制代碼的編譯了。另一種,就是使用Dockerfile進行進行build,來獲取鏡像。Dockerfile文件就在docker源碼的根目錄下。這種方式比較耗時,不推薦。

有了docker-dev鏡像,其實不必每次都要docker build鏡像,而只需要利用原有鏡像就可以了。那么我修改了Makefile文件,從而可以支持能夠使用docker-dev鏡像進行編譯。更新后的Makefile在末尾附帶。

在我的里面支持了多種方式來靈活使用本地環境:

通過build方式 make DOCKER_COMMAND=build通過pull方式(默認,pull與本版本相同的docker-dev鏡像) make通過pull方式,指定本地鏡像(不再pull鏡像) make DOCKER_IMAGE=docker-dev:v1.2

其他編譯方法

另外一種方法,就是把你的代碼上傳到github上。

然后在?https://registry.hub.docker.com?上面,注冊,選擇自己的github項目,進行自動編譯。

這種方式真心慢,沒個半小時弄不出來(實測是20min),雖然是官方推薦。但是我感覺這更像是給他們自己做的一種硬廣告。。。

Makefile

.PHONY: all binary build cross default docs docs-build docs-shell shell test test-unit test-integration test-integration-cli test-docker-py validate# env vars passed through directly to Docker's build scripts # to allow things like `make DOCKER_CLIENTONLY=1 binary` easily # `docs/sources/contributing/devenvironment.md ` and `project/PACKAGERS.md` have some limited documentation of some of these DOCKER_ENVS := \-e BUILDFLAGS \-e DOCKER_CLIENTONLY \-e DOCKER_EXECDRIVER \-e DOCKER_GRAPHDRIVER \-e TESTDIRS \-e TESTFLAGS \-e TIMEOUT # note: we _cannot_ add "-e DOCKER_BUILDTAGS" here because even if it's unset in the shell, that would shadow the "ENV DOCKER_BUILDTAGS" set in our Dockerfile, which is very important for our official builds# to allow pull docker-dev image from registry.hub.docker.com and avoid building every time # allow `make DOCKER_COMMAND=build` to build image from Dockerfile DOCKER_COMMAND := pullDOCKER_VERSION := $(shell cat VERSION)# to allow `make BIND_DIR=. shell` or `make BIND_DIR= test` # (default to no bind mount if DOCKER_HOST is set) # note: BINDDIR is supported for backwards-compatibility here BIND_DIR := $(if $(BINDDIR),$(BINDDIR),$(if $(DOCKER_HOST),,bundles))DOCKER_BUILD_MOUNT := $(if $(BIND_DIR),-v "$(CURDIR)/$(BIND_DIR):/go/src/github.com/docker/docker/$(BIND_DIR)") DOCKER_PULL_MOUNT := -v "$(CURDIR):/go/src/github.com/docker/docker"# to allow `make DOCSDIR=docs docs-shell` (to create a bind mount in docs) DOCS_MOUNT := $(if $(DOCSDIR),-v $(CURDIR)/$(DOCSDIR):/$(DOCSDIR))# to allow `make DOCSPORT=9000 docs` DOCSPORT := 8000GIT_BRANCH := $(shell git rev-parse --abbrev-ref HEAD 2>/dev/null)# to allow you miss .git directory DOCKER_ENVS += $(if $(GIT_BRANCH),,-e DOCKER_GITCOMMIT=$(DOCKER_VERSION))DOCKER_BUILD_IMAGE := docker$(if $(GIT_BRANCH),:$(GIT_BRANCH)) DOCKER_PULL_IMAGE := docker-dev:$(if $(DOCKER_VERSION),$(DOCKER_VERSION))# to allow `make DOCKER_IMAGE=docker-dev:v1.2`(to use some other image if needed) ifeq ($(DOCKER_COMMAND),pull)DOCKER_IMAGE := $(DOCKER_PULL_IMAGE)DOCKER_MOUNT := $(DOCKER_PULL_MOUNT) elseDOCKER_IMAGE := $(DOCKER_BUILD_IMAGE)DOCKER_MOUNT := $(DOCKER_BUILD_MOUNT) endifDOCKER_DOCS_IMAGE := docker-docs$(if $(GIT_BRANCH),:$(GIT_BRANCH))DOCKER_RUN_DOCKER := docker run --rm -it --privileged $(DOCKER_ENVS) $(DOCKER_MOUNT) "$(DOCKER_IMAGE)"DOCKER_RUN_DOCS := docker run --rm -it $(DOCS_MOUNT) -e AWS_S3_BUCKET -e NOCACHE# for some docs workarounds (see below in "docs-build" target) GITCOMMIT := $(shell git rev-parse --short HEAD 2>/dev/null)default: binaryall: $(DOCKER_COMMAND)$(DOCKER_RUN_DOCKER) hack/make.shbinary: $(DOCKER_COMMAND)$(DOCKER_RUN_DOCKER) hack/make.sh binarycross: $(DOCKER_COMMAND)$(DOCKER_RUN_DOCKER) hack/make.sh binary crossdocs: docs-build$(DOCKER_RUN_DOCS) -p $(if $(DOCSPORT),$(DOCSPORT):)8000 "$(DOCKER_DOCS_IMAGE)" mkdocs servedocs-shell: docs-build$(DOCKER_RUN_DOCS) -p $(if $(DOCSPORT),$(DOCSPORT):)8000 "$(DOCKER_DOCS_IMAGE)" bashdocs-release: docs-build$(DOCKER_RUN_DOCS) -e OPTIONS -e BUILD_ROOT -e DISTRIBUTION_ID \-v $(CURDIR)/docs/awsconfig:/docs/awsconfig \"$(DOCKER_DOCS_IMAGE)" ./release.shdocs-test: docs-build$(DOCKER_RUN_DOCS) "$(DOCKER_DOCS_IMAGE)" ./test.shtest: $(DOCKER_COMMAND)$(DOCKER_RUN_DOCKER) hack/make.sh binary cross test-unit test-integration test-integration-cli test-docker-pytest-unit: $(DOCKER_COMMAND)$(DOCKER_RUN_DOCKER) hack/make.sh test-unittest-integration: $(DOCKER_COMMAND)$(DOCKER_RUN_DOCKER) hack/make.sh test-integrationtest-integration-cli: $(DOCKER_COMMAND)$(DOCKER_RUN_DOCKER) hack/make.sh binary test-integration-clitest-docker-py: $(DOCKER_COMMAND)$(DOCKER_RUN_DOCKER) hack/make.sh binary test-docker-pyvalidate: $(DOCKER_COMMAND)$(DOCKER_RUN_DOCKER) hack/make.sh validate-gofmt validate-dco validate-tomlshell: $(DOCKER_COMMAND)$(DOCKER_RUN_DOCKER) bashpull:docker pull "$(DOCKER_IMAGE)"build: bundlesdocker build -t "$(DOCKER_IMAGE)" .docs-build:git fetch https://github.com/docker/docker.git docs && git diff --name-status FETCH_HEAD...HEAD -- docs > docs/changed-filescp ./VERSION docs/VERSIONecho "$(GIT_BRANCH)" > docs/GIT_BRANCH # echo "$(AWS_S3_BUCKET)" > docs/AWS_S3_BUCKETecho "$(GITCOMMIT)" > docs/GITCOMMITdocker build -t "$(DOCKER_DOCS_IMAGE)" docsbundles:mkdir bundles

將Makefile拷貝到自己的docker工程中即可。



來自為知筆記(Wiz)



轉載于:https://www.cnblogs.com/ToBeSmart/p/4311297.html

總結

以上是生活随笔為你收集整理的docker二进制代码编译的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。