亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Spring Boot利用Docker快速部署項目的完整步驟

 更新時間:2019年07月11日 14:42:59   作者:亂敲代碼  
這篇文章主要給大家介紹了關(guān)于Spring Boot利用Docker快速部署項目的完整步驟,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Spring Boot具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

1.簡介

建議閱讀本文最好對Dokcer有一些了解

首先我們先了解一下Docker是什么

Docker 屬于 Linux 容器的一種封裝,提供簡單易用的容器使用接口。它是目前最流行的 Linux 容器解決方案。

Docker 將應(yīng)用程序與該程序的依賴,打包在一個文件里面。運行這個文件,就會生成一個虛擬容器。程序在這個虛擬容器里運行,就好像在真實的物理機上運行一樣。有了 Docker,就不用擔心環(huán)境問題。

總體來說,Docker 的接口相當簡單,用戶可以方便地創(chuàng)建和使用容器,把自己的應(yīng)用放入容器。容器還可以進行版本管理、復(fù)制、分享、修改,就像管理普通的代碼一樣。

Docker有什么用途

  • 提供一次性的環(huán)境
  • 提供彈性的云服務(wù)
  • 組建微服務(wù)架構(gòu)

如何搭建Docker環(huán)境

使用yum安裝

#查看你當前的內(nèi)核版本
uname -r

#安裝 Docker
yum -y install docker

#啟動 Docker 后臺服務(wù)
service docker start

#測試運行 hello-world,由于本地沒有hello-world這個鏡像,所以會下載一個hello-world的鏡像,并在容器內(nèi)運行。
docker run hello-world

腳本安裝:

#確保 yum 包更新到最新
sudo yum update

#執(zhí)行 Docker 安裝腳本,執(zhí)行這個腳本會添加 docker.repo 源并安裝 Docker。
curl -fsSL https://get.docker.com/ | sh

#啟動 Docker 進程
sudo service docker start

#驗證 docker 是否安裝成功并在容器中執(zhí)行一個測試的鏡像
sudo docker run hello-world

因為國內(nèi)下載鏡像速度較慢,推薦使用替換為國內(nèi)的鏡像源

執(zhí)行命令

vim /etc/docker/daemon.json
加入以下代碼
{
 "registry-mirrors": ["<your accelerate address>"]
}

2.創(chuàng)建項目

首先我們先創(chuàng)建一個SpringBoot的項目,這個步驟就不在重復(fù)了,可以使用IDEA構(gòu)建或者訪問SpringBoot項目來進行構(gòu)建項目。

完整的項目結(jié)構(gòu):

boot-docker
├── pom.xml
└── src
    ├── main
    │   ├── java
    │   │   └── com
    │   │       └── example
    │   │           └── bootdocker
    │   │               └── BootDockerApplication.java
    │   └── resources
    │       ├── application.properties
    │       ├── static
    │       └── templates

然后創(chuàng)建一個控制器,這里不做的太復(fù)雜,主要就是來演示Docker怎么部署項目。

主要代碼:

啟動然后打開瀏覽器訪問接口地址:

項目完成,現(xiàn)在開始部署到Docker中。

3.部署項目

3.1 使用Dockerfile

在部署項目之前我們要先了解一下Dockerfile 是什么?

Dockfile是一種被Docker程序解釋的腳本,Dockerfile由一條一條的指令組成,每條指令對應(yīng)Linux下面的一條命令。Docker程序?qū)⑦@些Dockerfile指令翻譯真正的Linux命令。Dockerfile有自己書寫格式和支持的命令,Docker程序解決這些命令間的依賴關(guān)系,類似于Makefile。Docker程序?qū)⒆x取Dockerfile,根據(jù)指令生成定制的image。相比image這種黑盒子,Dockerfile這種顯而易見的腳本更容易被使用者接受,它明確的表明image是怎么產(chǎn)生的。有了Dockerfile,當我們需要定制自己額外的需求時,只需在Dockerfile上添加或者修改指令,重新生成image即可,省去了敲命令的麻煩。參考

我們先把項目進行打包執(zhí)行,執(zhí)行。

mvn package

創(chuàng)建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 基礎(chǔ)鏡像必要,代表你的項目將構(gòu)建在這個基礎(chǔ)上面
  • EXPOSE 允許指定端口轉(zhuǎn)發(fā)
  • VOLUME 創(chuàng)建一個可以從本地主機或其他容器掛載的掛載點,一般用來存放數(shù)據(jù)庫和需要保持的數(shù)據(jù)等。
  • ADD 將文件從路徑
  • ENV 可以用于為docker容器設(shè)置環(huán)境變量
  • ENTRYPOINT 指定 Docker image 運行成 instance (也就是 Docker container) 時,要執(zhí)行的命令或者文件。
    • CMD 和 ENTRYPOINT 都能用來指定開始運行的程序,而且這兩個命令都有兩種不用的語法:
CMD ["ls",''-l"]
CMD ls -l

開始構(gòu)建:

docker build -t boot-docker .

-t boot-docker 代表你要構(gòu)建的名字

更多參數(shù)輸入查看: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

我們可以看到已經(jīng)構(gòu)建完成,Successfully built 92a0da91ea19這句話指明了剛剛構(gòu)建的鏡像ID現(xiàn)在我們可以根據(jù)這個ID來進行操作。

輸入run命令來啟動。

docker run -d -p 8080:8080 92a0da91ea19

控制臺輸出:

root@izz30yg92yl9i3z /# docker run -d -p 8080:8080 92a0da91ea19
62b837ac75e3d83a4be2d7b0f6edee5ff70c69a98bac4ff74c7ed6d3e70282ee
root@izz30yg92yl9i3z /#

-d 表示后臺運行

-p映射端口

已經(jīng)運行成功訪問接口。注意這里因為映射到了宿主機的端口所以訪問的是宿主機的IP加端口

更多參數(shù)輸入查看:docker build --help

3.2 使用Maven構(gòu)建

上面說了使用Dockerfile構(gòu)建,現(xiàn)在使用Maven來構(gòu)建,

在pom中加入docker構(gòu)建依賴

 <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還是要設(shè)置Dockerfile文件的路徑

把項目復(fù)制到Linux主機中,執(zhí)行解壓命令

unzip boot-docker.zip
cd boot-docker

執(zhí)行命令:

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] ------------------------------------------------------------------------

和上面相同。啟動

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

相關(guān)文章

  • 關(guān)于Java?float和double精度范圍大小

    關(guān)于Java?float和double精度范圍大小

    這篇文章主要介紹了關(guān)于Java?float和double精度范圍大小,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • IDEA操作MongoDB及安全認證方式

    IDEA操作MongoDB及安全認證方式

    這篇文章主要介紹了IDEA操作MongoDB及安全認證方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • 最新評論