docker 構建dockerfile


 

版本為:

使用cenotos 7

docker  版本

[root@zhao ~]# docker --version
Docker version 17.03.1-ce, build c6d412e

 

第一步:

 查看官網 安裝docker ce版  網址:     https://docs.docker.com/engine/installation/linux/centos/#install-using-the-repository

2:構建 java 鏡像

  1:springboot鏡像

  

springboot鏡像的內容摘錄自 : http://www.cnblogs.com/niloay/p/6261784.html 

本人在測試中遇到了點問題 ,做了些改動 。

創建鏡像:

1、准備jdk、需要運行的spring boot小項目

  將jdk壓縮包解壓到Dockerfile所在的目錄中,將spring boot小項目websocket.jar復制到Dockerfile所在的目錄下:

  

2、創建Dockerfile,內容如下:

復制代碼
 1 FROM centos #指定基鏡像 centos  2  3 MAINTAINER yaolin #指定維護者信息 yaolin  4  5 COPY jdk1.7.0_79 jdk1.7.0_79 #復制jdk  6 ADD websocket.jar app.jar #添加spring boot 小項目,並重命名為app.jar  7  8 ENV JAVA_HOME=/jdk1.7.0_79 # 配置jdk環境  9 ENV PATH=$JAVA_HOME/bin:$PATH 10 ENV CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar 11 12 EXPOSE 8080 #暴露8080端口 13 14 ENTRYPOINT ["java","-jar","/app.jar"] #指定執行啟動spring boot小項目 ENTRYPOINT 為容器啟動后執行的命令

編譯並生成鏡像 (. 表示當前路徑) 

原博客 build 方式: docker build -t yaolin/websocket . "." 代表 當前目錄 並且dockerfile 必須在當前目錄

我改動之后 為: docker build -t centos:springDemo -f /home/Dockfie /home -f 為指定dockfile的路徑 -t: 為容器重新分配一個偽輸入終端,通常與 -i 同時使用;


  

查看生成的鏡像 

docker images

 

 創建容器並運行

docker run -p 8080:8080 springbootdemo [springbootdemo 為容器名稱 通過 docker images 查看 其容器名稱 ]

 

   docker run -d -p 8080:8080 springbootdemo        在后台啟動  -d: 后台運行容器,並返回容器ID;

 

 -p 指定端口號  第一個8080 為 容器內部的端口號  第二個8080位外界訪問的端口號  ——》 將容器內的8080端口號映射到外部的8080端口號

 

    其次 開啟Linus 指定的防火牆端口號

   firewall-cmd --permanent --zone=public --add-port=8080-8080/tcp 開啟8080端口號
     irewall-cmd --reload 防火牆重新加載

 

   最后就可以在外界瀏覽器訪問了

 192.168.1.130:8080


刪除鏡像 docker rmi -f 鏡像名:tag


2:搭建javaweb環境 ,





Dockerfile指令:

1、FROM

格式:FROM <image>或 FROM <image>:<tag>

第一條指令必須為FROM指令,並且,如果在同一個Dockerfile中創建多個鏡像時,可以使用多個FROM指令(每個鏡像一次)

2、MAINTAINET

格式:MAINTAINET <name>

指定維護者的信息

3、RUN

格式:RUN <command> 或 RUN ["", "", ""]

每條指令將在當前鏡像基礎上執行,並提交為新的鏡像。(可以用“\”換行)

4、CMD

格式:CMD ["","",""]

指定啟動容器時執行的命令,每個Dockerfile只能有一條CMD指令,如果指定了多條指令,則最后一條執行。(會被啟動時指定的命令覆蓋)

5、EXPOSE

格式:EXPOSE <port>  [ <port> ...]

告訴Docker服務端暴露端口,在容器啟動時需要通過 -p 做端口映射

6、ENV

格式:ENV <key> <value>

指定環境變量,會被RUN指令使用,並在容器運行時保存

7、ADD

格式:ADD  <src>  <dest>

復制指定的<src>到容器的<dest>中,<src>可以是Dockerfile所在的目錄的一個相對路徑;可以是URL,也可以是tar.gz(自動解壓)

8、COPY

格式:COPY <src>  <dest>

復制本地主機的 <src> ( 為 Dockerfile 所在目錄的相對路徑)到容器中的 <dest> (當使用本地目錄為源目錄時,推薦使用 COPY)

9、ENTRYPOINT

格式:ENTRYPOINT ["","",""]

配置容器啟動后執行的命令,並且不可被 docker run 提供的參數覆蓋。(每個 Dockerfile 中只能有一個 ENTRYPOINT ,當指定多個時,只有最后一個起效)

10、VOLUME

格式:VOLUME ["/mnt"] 

創建一個可以從本地主機或其他容器掛載的掛載點,一般用來存放數據庫和需要保持的數據等

11、USER

格式:USER daemon

指定運行容器時的用戶名或 UID,后續的 RUN 也會使用指定用戶。

12、WORKDIR

格式:WORKDIR /path/to/workdir

為后續的 RUN 、 CMD 、 ENTRYPOINT 指令配置工作目錄。(可以使用多個 WORKDIR 指令,后續命令如果參數是相對路徑, 則會基於之前命令指定的路徑)

13、ONBUILD

格式:ONBUILD [INSTRUCTION]

配置當所創建的鏡像作為其它新創建鏡像的基礎鏡像時,所執行的操作指令

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM