docker掃盲?面試連這都不會就等著掛吧

docker掃盲?面試連這都不會就等著掛吧

現在很多公司項目部署都是採用K8S docker容器方式,出門面試被問的概率極大,如果被面試官問docker相關知識點直接懵逼,那麼基本就是被pass了,除非其他方面技術過硬。所以這種相對前沿的技術,就算達不到精通的程度,起碼還是要了解基礎理論和操作

一.安裝docker

Docker要求運行在Centos 7上,要求系統為64位,系統內核版本3.10以上

  • uname -an 查看當前系統版本
  • yum -y install docker 下載安裝docker
  • service docker start 啟動docker服務
  • docker version 檢查docker是否安裝成功

當看到下圖的信息,就是表示本機docker已經安裝成功,很簡單

docker掃盲?面試連這都不會就等著掛吧


二.鏡像操作

創建容器要以鏡像為基礎,所以先講下docker鏡像的操作

搜索鏡像

docker images ll 查看下本機的是否已經有了鏡像

目前機器裡還沒有鏡像,去Docker Hub下載(鏡像還可自定義,這裡就不細說了)

docker search java ,還能指定具體的版本進行下載,

例如:docker search Ubuntu:1.2.5.4,可以進行搜docker Hub 會列出很多鏡像


docker掃盲?面試連這都不會就等著掛吧


下載鏡像

docker pull docker.io/nginx 進行下載

下載到本地的鏡像要比docker Hub上搜索出來的要大,因為下載過程中自動解壓了,在查看鏡像列表就有了剛才下載的鏡像

列表包含了倉庫名,版本標籤,鏡像ID,創建時間以及所佔用的空間

docker掃盲?面試連這都不會就等著掛吧


刪除鏡像

刪除沒用的鏡像docker rmi 鏡像id


docker掃盲?面試連這都不會就等著掛吧


三.容器的操作

前邊我們已經下載好了Nginx的鏡像,接下來我們就創建一個只有Nginx應用的容器

docker run -i -t <image> /bin/bash/<image>

-i:標準輸入給容器 -t:分配一個虛擬終端 /bin/bash:執行bash腳本

<code>docker run -idt --name container_nginx -p 8080:80  docker.io/nginx複製代碼/<code>

啟動一個使用鏡像docker.io/nginx,名字container_nginx的容器,-p 8080:80表示將容器的80端口映射到主機的8080端口,這樣我們只要訪問主機的8080端口就可以訪問到容器的服務了。

注意:name前面是兩個-, 端口前面有-p, docker.io/nginx是鏡像名,8080是主機的端口,80是Nginx應用的端口

主機上的一個端口只能映射一個容器端口,不可以多個容器端口對應一個主機端口(如果容器安裝的centos類的系統,那麼容器端口隨便設定,但如果容器內只是單純的應用,那麼容器端口要是應用自身的端口)


docker掃盲?面試連這都不會就等著掛吧


這樣我們就創建並啟動了一個容器!

exit 退出容器

docker ps 查看運行中的容器

docker ps -a 查看運行中和非運行中的所有容器

docker exec -it container_nginx /bin/bash 進入容器

如果容器還未啟動 執行docker start container_nginx

進入容器後啟動Nginx

whereis nginx 找Nginx的啟動目錄

<code>[root@iz2zehzeir87zi8q99krk1z ~]# docker start container_nginxcontainer_nginx[root@iz2zehzeir87zi8q99krk1z ~]# docker exec -it container_nginx /bin/bashroot@84683e425116:/# whereis  nginxnginx: /usr/sbin/nginx /usr/lib/nginx /etc/nginx /usr/share/nginxroot@84683e425116:/#  /usr/sbin/nginx 複製代碼/<code>

此時在瀏覽器訪問 http://51.110.218.9:8080/ 就可以直接訪問容器內的Nginx

docker掃盲?面試連這都不會就等著掛吧


如果訪問不成功,可能是主機端口的防火牆開著,執行下邊的命令關閉

<code>/ sbin / iptables -I INPUT -p tcp --dport 8080 -j ACCEPT複製代碼/<code>

由於我用的阿里雲服務器,所以需要在阿里雲把8080端口開放

docker掃盲?面試連這都不會就等著掛吧


刪除容器

容器刪除之前先將容器停止

docker stop container_nginx 或者是容器的id

docker rm -f container_nginx 容器刪除

docker start 與 docker run 的區別

docker start name 啟動一個已經創建的容器

docker run 創建並啟動一個容器

docker run 命令其實是 docker create 和 docker start 的命令組合,先執行docker create 創建一個容器 再接著docker start啟動

主機和容器文件相互複製

<code>從主機複製到容器 sudo docker cp host_path containerID:container_path從容器複製到主機 sudo docker cp containerID:container_path host_path複製代碼/<code>

請注意,以上這兩個命令都是在主機中執行的,不能再容器中執行

<code>docker cp container_nginx:/usr/local/xin.txt  /usr/local/software/   容器向主機複製文件docker cp /usr/local/xinzhifu.txt  container_nginx:/usr/local/  主機向容器複製文件複製代碼/<code>

這樣一個基礎的docker容器就創建完了 。。。。。。。。。。。。

反過來大家再看一看docker的容器與鏡像的區別 www.cnblogs.com/linjiaxin/p…

那麼其實鏡像與容器的本質區別並不大,那麼鏡像可以生成容器 ,容器是否可以做成鏡像呢?

<code>docket commit container_nginx  image_nginx:v1複製代碼/<code>


docker掃盲?面試連這都不會就等著掛吧

container_nginx 容器名


image_nginx:v1 自己起一個鏡像的名字:版本號


這樣做有什麼好處呢?

例如:A、B兩臺機器都想安裝redis,A機器上創建容器並在容器中做好redis的一切配置,讓後將這個容器docker commit 成鏡像image_redis,B機器也想要安裝redis,直接用鏡像image_redis創建容器就行了,docker就是做這樣一勞永逸的事情。

而且傳統方式得在每臺機器上安裝配置redis非常麻煩

四.鏡像的導入與導出

鏡像壓縮打包 (主機上進行操作),有兩種方式 docker save 與 docker load 和 docker export 與 docker import

<code>docker save nginx | gzip > nginx_xin_image.tar.gz  將現有的鏡像壓縮打包docker load -i nginx_xin_image.tar.gz  壓縮的鏡像解壓docker images 進行查看複製代碼/<code>

docker save 是直接將鏡像進行打包 docker save 或

<code>docker export container_nginx> nginx_image.tar  cat nginx_image.tar | sudo docker import  - nginx_image:import複製代碼/<code>

docker export 是直接將容器進行打包 docker export 或

需要注意兩種方法配套的,切不可混用。雖然導入導出時沒問題,但是在創建容器時候會報錯

如果使用import導入save產生的文件,雖然導入不提示錯誤,但是啟動容器時會提示失敗,

會出現類似"docker: Error response from daemon: Container command not found or does not exist"的錯誤。

類似,使用load載入export產生的文件,也會出現問題。

先寫到這,文章略顯粗糙,希望對您有一點用,學無止境加油!


作者:程序員內點事
鏈接:https://juejin.im/post/5e38e60d6fb9a07c9f3fcaed
來源:掘金
著作權歸作者所有。商業轉載請聯繫作者獲得授權,非商業轉載請註明出處。


分享到:


相關文章: