這是一個開始使用 Docker 的 Tutorial
大無語事件發生!大數據課實驗課要用到Hadoop,實驗指導是在一個Ubuntu虛機上通過安裝包安裝Hadoop並運行一個詞頻統計程序,整個實驗就是安裝環境,做了4h才把環境搭好。因為我不想裝虛擬機用centos雲服務器的,期間遇到centos沒有sudo用戶組問題,遇到文件目錄結構不一樣等等各種問題,在解決這些問題上消磨了大量時間精力,而在解決這些問題的時候卻沒有實質性的知識提升和效果產出。每每在這個時候我就想,要是有Docker就好了。
Docker 的好處
粗淺的說,Docker 是一個生產效率工具,他最大的應用價值是抹平不同機器,不同系統的差距,所有程序運行在Docker的平台下,就可以做到兩件很重要的事:
- 簡化開發環境配置
- 方便不同系統(Linux服務器,Mac或者Windows開發機),不同環境(生產環境,預發環境和開發環境)的程序部署遷移

1. 安裝 Docker
因為在不同環境中安裝有不同的方式,Docker 官網的指引很好,所以在這里給出安裝方式的文檔鏈接和在Centos下安裝的流程。
正常情況下, 只需要配置docker源+ 安裝最新版兩步, 下面給出卸載老版本, 安裝指定版本的方法進行拓展學習。
其他系統可以參考官網
https://docs.docker.com/get-docker/
1.1 Centos環境下安裝Docker
安裝之前可以先查看一下是否已安裝docker
docker version # 查看Docker版本, 驗證是否已裝Docker
如果已安裝, 可以嘗試卸載Docker
sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine # 卸載老版本Docker
/etc/systemd -name '*docker*' -exec rm -f {} ; #清除配置文件和依賴文件
find /etc/systemd -name '*docker*' -exec rm -f {} \;
find /lib/systemd -name '*docker*' -exec rm -f {} \;
在下載docker之前, 最好安裝yumutils,並配置yumutils的yum-config-manager來設置穩定版的倉庫/源, 方便之后的更新
yum install -y yum-utils # 安裝
yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo # 配置
安裝最新版的docker
sudo yum install docker-ce docker-ce-cli containerd.io
安裝好了之后可以和開頭一樣使用docker version驗證是否安裝成功
docker version

如果想要安裝特定版本可以采用一下方式
-
查看能使用的版本
yum list docker-ce --showduplicates | sort -r -
安裝特定版本
yum install docker-ce-<VERSION_STRING> docker-ce-cli-<VERSION_STRING> containerd.io
2. 認識Docker
裝好了docker先跑起來吧
systemctl start docker
這條命令啟動docker服務, 類似windows中的服務, 一直運行在后台提供功能, 也就是以一種特殊的, 受保護的模式運行docker本體
關於 systemctl : http://linux.51yip.com/search/systemctl
docker run hello-world
這條命令將會下載hello-world鏡像並運行
然后你就會看到一些說明文字
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.1 Docker的基本概念
- 鏡像(Image):是一個包含有文件系統的面向Docker引擎的只讀模板。鏡像是一個模板,裝了一些系統的配置文件, 我們可以通過鏡像建立更多的容器, 容器從鏡像啟動時,Docker在鏡像的上層創建一個可寫層, 鏡像本身不變。
- 容器(Container):容器是基於鏡像創建, 相互隔離的, 可以理解為小型虛擬機,真正的執行單元。
- 倉庫(Repository):存放鏡像的倉庫
- 注冊服務器(Registry)的區別:注冊服務器是存放倉庫的地方,一般會有多個倉庫;而倉庫是存放鏡像的地方,一般每個倉庫存放一類鏡像,每個鏡像利用tag進行區分.
Docker Hub是Docker公司提供的一個注冊服務器(Register)來保存多個倉庫

2.2 啟動一個裝有Centos的Docker容器
2.2.1 下載鏡像
在DockerHub查找centos的鏡像並拉取centos鏡像
docker search ubuntu # 查看
docker pull centos # 拉取
查看docker中的所有鏡像
docker images # 查看當前系統中的images信息
# 會獲得下面信息
# REPOSITORY TAG IMAGE ID CREATED SIZE
# centos latest 0584b3d2cf6d 9 days ago 196.5 MB
2.2.2 啟動容器
docker run -it centos:latest /bin/bash # 啟動一個容器
run運行容器
-it 使用交互模式運行容器並且分配一個偽輸入終端
centos:latest 指定啟動的容器的鏡像
/bin/bash 是啟動容器后運行的指令
2.2.3 在Docker的Centos中安裝git並保存鏡像
git --version # 此時的容器中沒有git
# bash: git: command not found
yum install git # 利用yum安裝git
git --version # 此時的容器中已經裝有git了
# git version 1.8.3.1
退出容器並查看運行中的容器
docker ps -a

將一個容器轉化成鏡像保存起來
docker commit -m "centos with git" -a "zjeff" 3a2ed26119d3 zjeff/centos:git
查看docker中的鏡像
docker images

-m指定說明信息
-a指定用戶信息
3a2ed26119d3 代表容器的id
zjeff/centos:git 指定目標鏡像的用戶名、倉庫名和 tag 信息
現在我們可以使用新保存的鏡像創建一個包含git的centos容器
docker run -it zjeff/centos:git /bin/bash

2.3 停止容器和刪除鏡像
現在把之前下載的hello-world刪了
刪除鏡像之前要停止所有基於鏡像的容器
查看運行中的容器
docker ps -a
停止這些容器
docker rm 9f069
然后查看運行中的容器, 沒有對應鏡像的容器就可以刪除鏡像

查看鏡像
docker images

刪除鏡像
docekr rmi d1165

3. 利用Dockerfile創建鏡像
Dockerfile是一種配置文件, 可以看作批處理腳本, 但是是以一種配置化的形式進行編寫
官方說明 https://docs.docker.com/engine/reference/builder/
新建一個Dockerfile文件( 無后綴 ), 寫入下面內容
# 選擇一個鏡像作為基礎
FROM centos:latest
# 維護者的信息
MAINTAINER zjeff
# 啟動鏡像后進行的操作
RUN yum update -y
RUN yum install -y git
# 拷貝本地文件到鏡像中
COPY ./* /usr/share/gitdir/
# 前面是容器中的路徑, 后面是本地路徑
使用Dockerfile新建一個鏡像
docker build -t="zjeff/centos:gitdir" .
t用來指定新鏡像的用戶信息、tag等
最后的點表示在當前目錄尋找Dockerfile
構建完成之后,可以使用docker images命令查看
如果提示不是root用戶可以使用這條命令進入容器
docker exec -it --user root <container id> /bin/bash
如果你忘了加-y 可能會提示你輸入yes 提示會停止構建鏡像的過程
還有的時候不能使用-y
如果是安裝腳本的場合
比如我們用sh Anaconda3-4.4.0-Linux-x86_64.sh來安裝anaconda的時候,”煩人”的anaconda會問四個問題,我的回答順序分別是Enter,yes,Enter,yes。於是你可以這樣寫:RUN sh -c '/bin/echo -e "\nyes\nyes" | sh Anaconda3-4.4.0-Linux-x86_64.sh'
4. 鏡像的文件備份和加載
docker save -o centos.tar zjeff/centos:git
# 保存鏡像, -o也可以是--output
docker load -i centos.tar
# 加載鏡像, -i也可以是--input
5. Docker的 常用操作
run可以運行一個鏡像, 創建一個容器 ,之前已經用過了
現在補充一下后台運行和日志的用法
docker run -d xxxx
這樣就可以后台運行一個容器
后台啟動一個容器后,如果想進入到這個容器,可以使用attach命令:
docker attach container_name/container_id
刪除
docker rm container_name/container_id
啟動, 停止 , 重啟容器
docker start container_name/container_id
docker stop container_name/container_id
docker restart container_name/container_id
6. 使用DockerHub保存你的鏡像
- 注冊一個DockerHub賬號 , https://hub.docker.com/
- 登錄
docker login
# Login with your Docker ID to push and pull images from Docker Hub. If you don't have a Docker ID, head over to https://hub.docker.com to create one.
# Username: zjeff
# Password:
# Login Succeeded
- 推送
推送的時候, 要把用戶名和登錄名一致
docker push zjeff/centos:git # 成功推送
docker push xxx/centos:git # 失敗
# The push refers to a repository [docker.io/xxx/centos]
# unauthorized: authentication required
- pull 鏡像
docker pull zjeff/centos:git
7. 拓展閱讀
深入原理 https://zhuanlan.zhihu.com/p/96858321
減小你的鏡像體積 https://zhuanlan.zhihu.com/p/115845957
docker 常用操作總結 https://www.docker.org.cn/dockerppt/106.html
Keep curious, keep learning
【Jeff 在寫代碼】有關代碼的一切的一切
