1.簡介
建議閱讀本文最好對Dokcer有一些瞭解
首先我們先了解一下Docker是什麼
Docker 屬於 Linux 容器的一種封裝,提供簡單易用的容器使用介面。它是目前最流行的 Linux 容器解決方案。
Docker 將應用程式與該程式的依賴,打包在一個檔案裡面。執行這個檔案,就會生成一個虛擬容器。程式在這個虛擬容器裡執行,就好像在真實的物理機上執行一樣。有了 Docker,就不用擔心環境問題。
總體來說,Docker 的介面相當簡單,使用者可以方便地建立和使用容器,把自己的應用放入容器。容器還可以進行版本管理、複製、分享、修改,就像管理普通的程式碼一樣。
Docker有什麼用途
- 提供一次性的環境
- 提供彈性的雲服務
- 組建微服務架構
如何搭建Docker環境
使用yum安裝
#檢視你當前的核心版本
uname -r
#安裝 Docker
yum -y install docker
#啟動 Docker 後臺服務
service docker start
#測試執行 hello-world,由於本地沒有hello-world這個映象,所以會下載一個hello-world的映象,並在容器內執行。
docker run hello-world
指令碼安裝:
#確保 yum 包更新到最新
sudo yum update
#執行 Docker 安裝指令碼,執行這個指令碼會新增 docker.repo 源並安裝 Docker。
curl -fsSL https://get.docker.com/ | sh
#啟動 Docker 程式
sudo service docker start
#驗證 docker 是否安裝成功並在容器中執行一個測試的映象
sudo docker run hello-world
因為國內下載映象速度較慢,推薦使用替換為國內的映象源
執行命令
vim /etc/docker/daemon.json
加入以下程式碼
{
"registry-mirrors": ["<your accelerate address>"]
}
2.建立專案
首先我們先建立一個SpringBoot的專案,這個步驟就不在重複了,可以使用IDEA構建或者訪問SpringBoot專案來進行構建專案。
完整的專案結構:
boot-docker
├── pom.xml
└── src
├── main
│ ├── java
│ │ └── com
│ │ └── example
│ │ └── bootdocker
│ │ └── BootDockerApplication.java
│ └── resources
│ ├── application.properties
│ ├── static
│ └── templates
然後建立一個控制器,這裡不做的太複雜,主要就是來演示Docker怎麼部署專案。
主要程式碼:
啟動然後開啟瀏覽器訪問介面地址:
專案完成,現在開始部署到Docker中。
3.部署專案
3.1 使用Dockerfile
在部署專案之前我們要先了解一下Dockerfile 是什麼?
Dockfile是一種被Docker程式解釋的指令碼,Dockerfile由一條一條的指令組成,每條指令對應Linux下面的一條命令。Docker程式將這些Dockerfile指令翻譯真正的Linux命令。Dockerfile有自己書寫格式和支援的命令,Docker程式解決這些命令間的依賴關係,類似於Makefile。Docker程式將讀取Dockerfile,根據指令生成定製的image。相比image這種黑盒子,Dockerfile這種顯而易見的指令碼更容易被使用者接受,它明確的表明image是怎麼產生的。有了Dockerfile,當我們需要定製自己額外的需求時,只需在Dockerfile上新增或者修改指令,重新生成image即可,省去了敲命令的麻煩。參考
我們先把專案進行打包執行,執行。
mvn package
建立Dockerfile檔案
touch Dockerfile
在Dockerfile中加入以下資訊:
注意Dockerfile必須和Jar包在同一路徑下
FROM java:8
EXPOSE 8080
VOLUME /slm
ADD boot-docker-0.0.1-SNAPSHOT.jar boot-docker.jar
RUN sh -c 'touch /boot-docker.jar'
ENV JAVA_OPTS=""
ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /boot-docker.jar" ]
FROM 基礎映象必要,代表你的專案將構建在這個基礎上面
EXPOSE 允許指定埠轉發
VOLUME 建立一個可以從本地主機或其他容器掛載的掛載點,一般用來存放資料庫和需要保持的資料等。
ADD 將檔案從路徑
複製新增到容器內部路徑 支援遠端url 如果是遠端url許可權將會是600 ENV 可以用於為docker容器設定環境變數
ENTRYPOINT 指定 Docker image 執行成 instance (也就是 Docker container) 時,要執行的命令或者檔案。
CMD 和 ENTRYPOINT 都能用來指定開始執行的程式,而且這兩個命令都有兩種不用的語法:
CMD ["ls",''-l"] CMD ls -l
開始構建:
docker build -t boot-docker .
-t boot-docker 代表你要構建的名字
更多引數輸入檢視:docker build --help
控制檯輸出:
Sending build context to Docker daemon 16.81MB
Step 1/7 : FROM java:8
---> d23bdf5b1b1b
Step 2/7 : EXPOSE 8080
---> Using cache
---> b2445bf62da8
Step 3/7 : VOLUME /slm
---> Using cache
---> b73d0b73b868
Step 4/7 : ADD boot-docker-0.0.1-SNAPSHOT.jar boot-docker.jar
---> Using cache
---> 2b4868aafca9
Step 5/7 : RUN sh -c 'touch /boot-docker.jar'
---> Using cache
---> 816b59f199af
Step 6/7 : ENV JAVA_OPTS=""
---> Using cache
---> 784f033b9dd6
Step 7/7 : ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /boot-docker.jar" ]
---> Using cache
---> 92a0da91ea19
Successfully built 92a0da91ea19
Successfully tagged bootdocker:latest
我們可以看到已經構建完成,Successfully built 92a0da91ea19
這句話指明瞭剛剛構建的映象ID現在我們可以根據這個ID來進行操作。
輸入run命令來啟動。
docker run -d -p 8080:8080 92a0da91ea19
控制檯輸出:
root@izz30yg92yl9i3z /# docker run -d -p 8080:8080 92a0da91ea19
62b837ac75e3d83a4be2d7b0f6edee5ff70c69a98bac4ff74c7ed6d3e70282ee
root@izz30yg92yl9i3z /#
-d 表示後臺執行
-p對映埠
已經執行成功訪問介面。注意這裡因為對映到了宿主機的埠所以訪問的是宿主機的IP加埠
更多引數輸入檢視:docker build --help
3.2 使用Maven構建
上面說了使用Dockerfile構建,現在使用Maven來構建,
在pom中加入docker構建依賴
<plugin>
<!--新增的docker maven外掛-->
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<version>0.4.13</version>
<configuration>
<!--映象名字-->
<imageName>${docker.image.prefix}/${project.artifactId}</imageName>
<!--DokcerFile檔案地址-->
<dockerDirectory>/slm/</dockerDirectory>
<resources>
<resource>
<targetPath>/</targetPath>
<directory>${project.build.directory}</directory>
<include>${project.build.finalName}.jar</include>
</resource>
</resources>
</configuration>
</plugin>
注意dockerDirectory還是要設定Dockerfile檔案的路徑
把專案複製到Linux主機中,執行解壓命令
unzip boot-docker.zip
cd boot-docker
執行命令:
mvn package docker:build
控制檯輸出:
[INFO] Building image boot-docker/boot-docker
Step 1/7 : FROM java:8
---> d23bdf5b1b1b
Step 2/7 : EXPOSE 8080
---> Using cache
---> b2445bf62da8
Step 3/7 : VOLUME /slm
---> Using cache
---> b73d0b73b868
Step 4/7 : ADD boot-docker-0.0.1-SNAPSHOT.jar boot-docker.jar
---> Using cache
---> 2b4868aafca9
Step 5/7 : RUN sh -c 'touch /boot-docker.jar'
---> Using cache
---> 816b59f199af
Step 6/7 : ENV JAVA_OPTS=""
---> Using cache
---> 784f033b9dd6
Step 7/7 : ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /boot-docker.jar" ]
---> Using cache
---> 92a0da91ea19
ProgressMessage{id=null, status=null, stream=null, error=null, progress=null, progressDetail=null}
Successfully built 92a0da91ea19
Successfully tagged boot-docker/boot-docker:latest
[INFO] Built boot-docker/boot-docker
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 19.908s
[INFO] Finished at: Wed Jul 10 16:00:21 CST 2019
[INFO] Final Memory: 35M/86M
[INFO] ------------------------------------------------------------------------
和上面相同。啟動
歡迎轉發點贊,文章首發於亂敲程式碼