Spring Boot與Docker部署詳解
本文介紹了Spring Boot與Docker部署,分享給大家,希望對大家有幫助
開啟Docker遠(yuǎn)程訪問
首先需要開啟docker遠(yuǎn)程訪問功能,以便可以進行遠(yuǎn)程操作。
CentOS 6
修改/etc/default/docker文件,重啟后生效(service docker restart)。
DOCKER_OPTS="-H=unix:///var/run/docker.sock -H=0.0.0.0:2375"
CentOS 7
打開/usr/lib/systemd/system/docker.service文件,修改ExecStart這行。
ExecStart=/usr/bin/dockerd -H tcp://0.0.0.0:2375 -H unix:///var/run/docker.sock
重啟后生效
systemctl daemon-reload systemctl restart docker.service
測試是否生效
curl http://127.0.0.1:2375/info
新建Maven工程
pom.xml配置如下:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>test.springboot.docker</groupId> <artifactId>docker-springboot</artifactId> <version>0.0.1-SNAPSHOT</version> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.3.RELEASE</version> </parent> <properties> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> <plugin> <groupId>com.spotify</groupId> <artifactId>docker-maven-plugin</artifactId> <version>0.4.14</version> <configuration> <imageName>${docker.image.prefix}/${project.artifactId}</imageName> <dockerDirectory>src/main/docker</dockerDirectory> <dockerHost>http://192.168.1.200:2375</dockerHost> <resources> <resource> <targetPath>/</targetPath> <directory>${project.build.directory}</directory> <include>${project.build.finalName}.jar</include> </resource> </resources> </configuration> </plugin> </plugins> </build> </project>
imageName:指定了鏡像的名字
dockerDirectory:指定Dockerfile的位置
dockerHost:指定Docker遠(yuǎn)程API地址
resources:指那些需要和Dockerfile放在一起,在構(gòu)建鏡像時使用的文件,一般應(yīng)用jar包需要納入
創(chuàng)建Java類
package hello; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @SpringBootApplication @RestController public class Application { @RequestMapping("/") public String home() { return "Hello Docker World"; } public static void main(String[] args) { SpringApplication.run(Application.class, args); } }
創(chuàng)建Dockerfile
在src/main/docker目錄下創(chuàng)建一個名為Dockerfile的文件,配置如下:
FROM java VOLUME /tmp ADD docker-springboot-0.0.1-SNAPSHOT.jar app.jar RUN bash -c 'touch /app.jar' ENV JAVA_OPTS="" ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /app.jar" ]
FROM java:指Docker Hub上官方提供的java鏡像,有了這個基礎(chǔ)鏡像后,Dockerfile可以通過FROM指令直接獲取它的狀態(tài)——也就是在容器中java是已經(jīng)安裝的,接下來通過自定義的命令來運行Spring Boot應(yīng)用。
VOLUME /tmp:創(chuàng)建/tmp目錄并持久化到Docker數(shù)據(jù)文件夾,因為Spring Boot使用的內(nèi)嵌Tomcat容器默認(rèn)使用/tmp作為工作目錄。
ADD docker-springboot-0.0.1-SNAPSHOT.jar app.jar:將應(yīng)用jar包復(fù)制到/app.jar
ENTRYPOINT:表示容器運行后默認(rèn)執(zhí)行的命令
完整目錄結(jié)構(gòu)如下所示:
運行以下命令創(chuàng)建Docker鏡像:package docker:build
Docker啟動鏡像
查看項目是否上傳成功
啟動鏡像
docker run -p 8888:8080 springboot/docker-springboot
通過瀏覽器訪問
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 詳解springboot項目docker部署實踐
- 使用Docker部署 spring-boot maven應(yīng)用的方法
- 使用Docker部署Spring Boot的應(yīng)用示例
- Mac下部署springBoot項目到Docker中(demo)
- Docker 部署 SpringBoot 項目整合 Redis 鏡像做訪問計數(shù)示例代碼
- springboot整合docker部署實現(xiàn)兩種構(gòu)建Docker鏡像方式
- Spring Boot與Docker部署實踐
- Docker部署Spring-boot項目的示例代碼
- Spring Boot和Docker實現(xiàn)微服務(wù)部署的方法
- Spring Boot利用Docker快速部署項目的完整步驟
相關(guān)文章
Eclipse 導(dǎo)出可執(zhí)行Java工程/可執(zhí)行Jar文件(包含第三方Jar包)
這篇文章主要介紹了Eclipse 導(dǎo)出可執(zhí)行Java工程/可執(zhí)行Jar文件(包含第三方Jar包)的相關(guān)資料,需要的朋友可以參考下2016-11-11