Ubuntu使用Docker搭建編譯環境完整教程

前言

因爲只有一臺編譯服務器,但是我們需要在服務器上搭建不同的編譯環境,不同的編譯環境區別巨大,甚至可能需要是不同的Ubuntu版本,所以我們可以使用Docker,搭建不同的編譯環境而不對宿主機環境造成修改,且搭建好的環境可以導出爲鏡像,可以導出到其他機器中使用。

下面是詳細的搭建流程,從安裝到鏡像製作再到最終容器導出,預計閱讀時間10min。

一、安裝Docker

Docker Engine-Community 支持以下的 Ubuntu 版本:

  • Xenial 16.04 (LTS)
  • Bionic 18.04 (LTS)
  • Cosmic 18.10
  • Disco 19.04
  • 其他更新的版本……

Docker Engine - Community 支持上 x86_64(或 amd64)armhf,arm64,s390x (IBM Z),和 ppc64le(IBM的Power)架構。

(一)卸載舊版本

Docker 的舊版本被稱爲dockerdocker.iodocker-engine。如果已安裝,請卸載它們:

sudo apt-get remove docker docker-engine docker.io containerd runc

(二)安裝 Docker Engine-Community

當前稱爲 Docker Engine-Community 軟件包 docker-ce 。

安裝 Docker Engine-Community,以下介紹兩種方式。

1.使用 Docker 倉庫進行安裝

在新主機上首次安裝 Docker Engine-Community 之前,需要設置 Docker 倉庫。之後,您可以從倉庫安裝和更新 Docker 。

(1)設置倉庫

更新 apt 包索引。

sudo apt-get update

安裝 apt 依賴包,用於通過HTTPS來獲取倉庫:

sudo apt-get install \
    apt-transport-https \
    ca-certificates \
    curl \
    gnupg-agent \
    software-properties-common

添加 Docker 的官方 GPG 密鑰:

curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -

9DC8 5822 9FC7 DD38 854A E2D8 8D81 803C 0EBF CD88 通過搜索指紋的後8個字符,驗證您現在是否擁有帶有指紋的密鑰。

sudo apt-key fingerprint 0EBFCD88
   
pub   rsa4096 2017-02-22 [SCEA]
      9DC8 5822 9FC7 DD38 854A  E2D8 8D81 803C 0EBF CD88
uid           [ unknown] Docker Release (CE deb) <[email protected]>
sub   rsa4096 2017-02-22 [S]

使用以下指令設置穩定版倉庫

sudo add-apt-repository \
   "deb [arch=amd64] https://download.docker.com/linux/ubuntu \
  $(lsb_release -cs) \
  stable"

(2)安裝 Docker Engine-Community

更新 apt 包索引。

sudo apt-get update

安裝最新版本的 Docker Engine-Community 和 containerd ,或者轉到下一步安裝特定版本:

sudo apt-get install docker-ce docker-ce-cli containerd.io

要安裝特定版本的 Docker Engine-Community,請在倉庫中列出可用版本,然後選擇一種安裝。列出您的倉庫中可用的版本:

apt-cache madison docker-ce

顯示如下:

docker-ce | 5:18.09.1~3-0~ubuntu-xenial | https://download.docker.com/linux/ubuntu  xenial/stable amd64 Packages
docker-ce | 5:18.09.0~3-0~ubuntu-xenial | https://download.docker.com/linux/ubuntu  xenial/stable amd64 Packages
docker-ce | 18.06.1~ce~3-0~ubuntu       | https://download.docker.com/linux/ubuntu  xenial/stable amd64 Packages
docker-ce | 18.06.0~ce~3-0~ubuntu       | https://download.docker.com/linux/ubuntu  xenial/stable amd64 Packages
...

使用第二列中的版本字符串安裝特定版本,例如 5:18.09.1~3-0~ubuntu-xenial

sudo apt-get install docker-ce=<VERSION_STRING> docker-ce-cli=<VERSION_STRING> containerd.io

測試 Docker 是否安裝成功,輸入以下指令:

sudo docker run hello-world

打印出以下信息則安裝成功:

Unable to find image 'hello-world:latest' locally
latest: Pulling from library/hello-world
1b930d010525: Pull complete                                                                                                                                  Digest: sha256:c3b4ada4687bbaa170745b3e4dd8ac3f194ca95b2d0518b417fb47e5879d9b5f
Status: Downloaded newer image for hello-world:latest


Hello from Docker!
This message shows that your installation appears to be working correctly.


To generate this message, Docker took the following steps:
 1. The Docker client contacted the Docker daemon.
 2. The Docker daemon pulled the "hello-world" image from the Docker Hub.
    (amd64)
 3. The Docker daemon created a new container from that image which runs the
    executable that produces the output you are currently reading.
 4. The Docker daemon streamed that output to the Docker client, which sent it
    to your terminal.


To try something more ambitious, you can run an Ubuntu container with:
 $ docker run -it ubuntu bash


Share images, automate workflows, and more with a free Docker ID:
 https://hub.docker.com/


For more examples and ideas, visit:
 https://docs.docker.com/get-started/

2.使用 Shell 腳本進行安裝

Docker 在 get.docker.comtest.docker.com上提供了方便腳本,用於將快速安裝 Docker Engine-Community 的邊緣版本和測試版本。腳本的源代碼在 docker-install 倉庫中。 不建議在生產環境中使用這些腳本,在使用它們之前,您應該瞭解潛在的風險:

  • 腳本需要運行 root 或具有 sudo 特權。因此,在運行腳本之前,應仔細檢查和審覈腳本。
  • 這些腳本嘗試檢測 Linux 發行版和版本,併爲您配置軟件包管理系統。此外,腳本不允許您自定義任何安裝參數。從 Docker 的角度或您自己組織的準則和標準的角度來看,這可能導致不支持的配置。
  • 這些腳本將安裝軟件包管理器的所有依賴項和建議,而無需進行確認。這可能會安裝大量軟件包,具體取決於主機的當前配置。
  • 該腳本未提供用於指定要安裝哪個版本的 Docker 的選項,而是安裝了在 edge 通道中發佈的最新版本。
  • 如果已使用其他機制將 Docker 安裝在主機上,請不要使用便捷腳本。

本示例使用 get.docker.com上的腳本在 Linux 上安裝最新版本的Docker Engine-Community。要安裝最新的測試版本,請改用 test.docker.com。在下面的每個命令,取代每次出現 gettest

curl -fsSL https://get.docker.com -o get-docker.sh
sudo sh get-docker.sh

如果要使用 Docker 作爲非 root 用戶,則應考慮使用類似以下方式將用戶添加到 docker 組:

sudo usermod -aG docker your-user

(三)添加Docker鏡像加速

1. 獲取加速地址

(1)打開網址:

https://cr.console.aliyun.com/cn-hangzhou/instances/mirrors

(2) 登陸阿里雲

(3)複製加速器地址

我這邊使用的是下面的地址:

https://1uoakc5v.mirror.aliyuncs.com

2. 配置鏡像加速器

針對Docker客戶端版本大於 1.10.0 的用戶

可以通過修改daemon配置文件/etc/docker/daemon.json來使用加速器

sudo mkdir -p /etc/docker
sudo vim /etc/docker/daemon.json

增加下面的內容:

{
  "registry-mirrors": ["https://1uoakc5v.mirror.aliyuncs.com"]
}

重啓docker:

sudo systemctl daemon-reload
sudo systemctl restart docker

二、編譯環境配置

(一)創建編譯環境基礎鏡像

因爲官方的Ubuntu鏡像都不帶ssh服務,所以我們需要使用Dockerfile創建一個開機啓動ssh的基礎鏡像,然後在該鏡像中再添加我們所需要的編譯環境。

1.添加阿里雲源

我們基於官方Ubuntu16.04版本製作,所以先創建一個sources.list文件,裏面爲Ubuntu16.04阿里源。

vim sources.list

添加下面的內容:

deb-src http://archive.ubuntu.com/ubuntu xenial main restricted #Added by software-properties
deb http://mirrors.aliyun.com/ubuntu/ xenial main restricted
deb-src http://mirrors.aliyun.com/ubuntu/ xenial main restricted multiverse universe #Added by software-properties
deb http://mirrors.aliyun.com/ubuntu/ xenial-updates main restricted
deb-src http://mirrors.aliyun.com/ubuntu/ xenial-updates main restricted multiverse universe #Added by software-properties
deb http://mirrors.aliyun.com/ubuntu/ xenial universe
deb http://mirrors.aliyun.com/ubuntu/ xenial-updates universe
deb http://mirrors.aliyun.com/ubuntu/ xenial multiverse
deb http://mirrors.aliyun.com/ubuntu/ xenial-updates multiverse
deb http://mirrors.aliyun.com/ubuntu/ xenial-backports main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ xenial-backports main restricted universe multiverse #Added by software-properties
deb http://archive.canonical.com/ubuntu xenial partner
deb-src http://archive.canonical.com/ubuntu xenial partner
deb http://mirrors.aliyun.com/ubuntu/ xenial-security main restricted
deb-src http://mirrors.aliyun.com/ubuntu/ xenial-security main restricted multiverse universe #Added by software-properties
deb http://mirrors.aliyun.com/ubuntu/ xenial-security universe
deb http://mirrors.aliyun.com/ubuntu/ xenial-security multiverse

2.設置ssh啓動腳本

vim run.sh

添加下面的內容:

#!/bin/bash
/usr/sbin/sshd -D

3.編寫dockerfile

vim dockerfile

添加下面的內容:

# 以最新的Ubuntu鏡像爲模板
FROM ubuntu:16.04

# 將本目錄下的sources.list作爲容器的一個文件
ADD sources.list /root/sources.list
# 使用阿里Ubuntu源,更新快
RUN mv /etc/apt/sources.list  /etc/apt/sources.list_bak
RUN cp /root/sources.list  /etc/apt/sources.list

RUN apt-get update
# 安裝vim
RUN apt-get install -y vim
# 安裝ssh
RUN apt-get install -y openssh-server
RUN mkdir -p /var/run/sshd
# 修改root密碼,便於遠程登錄
RUN echo root:Software2020 | chpasswd
# 配置ssh可以使用root登陸
RUN sed -i 's/PermitRootLogin prohibit-password/PermitRootLogin yes/' /etc/ssh/sshd_config
# 複製配置文件到相應位置,並賦予腳本可執行權限
ADD run.sh /run.sh
RUN chmod 755 /run.sh

# 開放22端口
EXPOSE 22
#設置自啓動命令
CMD ["/run.sh"]

4.編譯docker鏡像

現在已經完成上面的步驟,那我們的當前文件夾應該有三個文件:

root@Ubuntu:~/docker# ls
dockerfile  run.sh  sources.list

現在在當前目錄執行鏡像編譯命令:

docker build -t base_env:16.04 .

如果一切OK的話,本地鏡像中會自動出現我們的base_env:16.04鏡像:

root@Ubuntu:~/docker# docker images
REPOSITORY                        TAG                 IMAGE ID            CREATED             SIZE
base_env                          16.04               ec9e3882279b        20 minutes ago      261MB

5.啓動鏡像

使用下面的命令啓動鏡像:

docker run -d  \
-v /virtual_env1/home:/home:rw \
-p 12306:22 \
--name=quectel \
base_env:16.04

參數解釋:

  • -d:表示在後臺運行
  • -v:掛載宿主機硬盤,表示將宿主機的/virtual_env1/home掛載到容器的/home目錄,主要爲了數據持久化,這樣容器裏的/home目錄的內容不會因爲容器的消失而消失。
  • -p:端口映射,將宿主機的12306端口映射進容器的22端口,這樣訪問宿主機的12306端口等於訪問容器的22端口。
  • --name=quectel:指定容器的名稱

這時候使用docker ps可以看到容器已經啓動:

root@Ubuntu:~# docker ps
CONTAINER ID        IMAGE                                   COMMAND                  CREATED             STATUS                  PORTS                                                               NAMES
83ef1192a91d        base_env:16.04                          "/run.sh"                3 seconds ago       Up 2 seconds            0.0.0.0:12306->22/tcp                                               quectel

6.使用ssh登陸

因爲我們再dockerfile中已經設置root密碼,所以使用設置的密碼直接登陸即可。

ip:宿主機ip
port:12306
用戶名:root
密碼:dockerfile中設置的密碼

這樣對ssh用戶實際上是沒有感知的,可以直接ssh連接後開始搭建編譯環境。

(二)搭建實際編譯環境

在使用ssh連接到編譯環境後,我們就可以在環境中安裝我們想要的軟件了,除了我們掛載的/home/目錄不在容器中,我們對容器系統做的所有操作都直接包含在容器內。

這裏每個編譯環境千差萬別,這裏不作詳述。

(三)導出容器給其他機器運行

好了,假設我們已經一頓操作猛如虎搭建好編譯環境,但是別的電腦上也想使用這個環境怎麼辦?

1.導出

我們可以使用docker export命令將容器導出爲鏡像。

docker export -o quectel-export.tar quectel

這樣我們的quectel容器就已經導出爲quectel-export.tar壓縮包了,實際上解壓後我們可以看到就是一個文件系統。

2.導入

這時候我們可以將quectel-export.tar壓縮包發送給另一臺電腦,另一臺電腦上也已經安裝了docker。

現在就可以使用docker import命令導入了。

docker import quectel-export.tar jfbuild:v1

該操作實際上將quectel-export.tar容器包導入爲一個名爲jfbuild:v1的鏡像,要想進入編譯系統,我們還需要運行鏡像。

3.運行

這時候你應該對docker容器的啓動很熟了,只需要使用docker run命令啓動,硬盤掛載與端口同樣可以按你的需求設置。

docker run -d  \
-v /final_env/home:/home:rw \
-p 12305:22 \
--name=final_env \
jfbuild:v1

設置完成後,直接使用ssh連接相應的端口即可進入編譯環境!

The end.

發佈了33 篇原創文章 · 獲贊 15 · 訪問量 6萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章