Spring Boot 2 (四):使用 Docker 部署 Spring Boot

Spring Boot 2 (四):使用 Docker 部署 Spring Boot

Docker 技術發展爲微服務落地提供了更加便利的環境,使用 Docker 部署 Spring Boot 其實很是簡單,這篇文章咱們就來簡單學習下。java

首先構建一個簡單的 Spring Boot 項目,而後給項目添加 Docker 支持,最後對項目進行部署。web

1、一個簡單 Spring Boot 項目

在 pom.xml 中 ,使用 Spring Boot 2.0 相關依賴spring

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.0.0.RELEASE</version>
</parent>

添加 web 和測試依賴docker

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

建立一個 DockerController,在其中有一個index()方法,訪問時返回:Hello Docker!apache

@RestController
public class DockerController {
    
    @RequestMapping("/")
    public String index() {
        return "Hello Docker!";
    }
}

啓動類json

@SpringBootApplication
public class DockerApplication {

    public static void main(String[] args) {
        SpringApplication.run(DockerApplication.class, args);
    }
}

添加完畢後啓動項目,啓動成功後瀏覽器放問:http://localhost:8080/,頁面返回:Hello Docker!,說明 Spring Boot 項目配置正常。vim

2、Spring Boot 項目添加 Docker 支持

在 pom.xml-properties 中添加 Docker 鏡像名稱瀏覽器

<properties>
    <docker.image.prefix>springboot</docker.image.prefix>
</properties>

plugins 中添加 Docker 構建插件:springboot

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
        <!-- Docker maven plugin -->
        <plugin>
            <groupId>com.spotify</groupId>
            <artifactId>docker-maven-plugin</artifactId>
            <version>1.0.0</version>
            <configuration>
                <imageName>${docker.image.prefix}/${project.artifactId}</imageName>
                <dockerDirectory>src/main/docker</dockerDirectory>
                <resources>
                    <resource>
                        <targetPath>/</targetPath>
                        <directory>${project.build.directory}</directory>
                        <include>${project.build.finalName}.jar</include>
                    </resource>
                </resources>
            </configuration>
        </plugin>
        <!-- Docker maven plugin -->
    </plugins>
</build>

在目錄src/main/docker下建立 Dockerfile 文件,Dockerfile 文件用來講明如何來構建鏡像。服務器

FROM openjdk:8-jdk-alpine
VOLUME /tmp
ADD spring-boot-docker-1.0.jar app.jar
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]

這個 Dockerfile 文件很簡單,構建 Jdk 基礎環境,添加 Spring Boot Jar 到鏡像中,簡單解釋一下:

  • FROM ,表示使用 Jdk8 環境 爲基礎鏡像,若是鏡像不是本地的會從 DockerHub 進行下載
  • VOLUME ,VOLUME 指向了一個/tmp的目錄,因爲 Spring Boot 使用內置的Tomcat容器,Tomcat 默認使用/tmp做爲工做目錄。這個命令的效果是:在宿主機的/var/lib/docker目錄下建立一個臨時文件並把它連接到容器中的/tmp目錄
  • ADD ,拷貝文件而且重命名
  • ENTRYPOINT ,爲了縮短 Tomcat 的啓動時間,添加java.security.egd的系統屬性指向/dev/urandom做爲 ENTRYPOINT

3、構建打包環境

咱們須要有一個 Docker 環境來打包 Spring Boot 項目,在 Windows 搭建 Docker 環境很麻煩,所以我這裏以 Centos 7 爲例。

1,安裝 Docker 環境

安裝

yum install docker

安裝完成後,使用下面的命令來啓動 docker 服務,並將其設置爲開機啓動:

service docker start
chkconfig docker on

#LCTT 譯註:此處採用了舊式的 sysv 語法,如採用CentOS 7中支持的新式 systemd 語法,以下:
systemctl  start docker.service
systemctl  enable docker.service

使用Docker 中國加速器:

vi  /etc/docker/daemon.json

#添加後:
{
    "registry-mirrors": ["https://registry.docker-cn.com"],
    "live-restore": true
}

從新啓動docker:

systemctl restart docker

輸入docker version 返回版本信息則安裝正常。

2,安裝JDK

yum -y install java-1.8.0-openjdk*

配置環境變量 打開 vim /etc/profile 添加一下內容:

export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.161-0.b14.el7_4.x86_64 
export PATH=$PATH:$JAVA_HOME/bin 

修改完成以後,使其生效:

source /etc/profile

輸入java -version 返回版本信息則安裝正常。

3,安裝MAVEN

下載:http://mirrors.shu.edu.cn/apache/maven/maven-3/3.5.2/binaries/apache-maven-3.5.2-bin.tar.gz

## 解壓
tar vxf apache-maven-3.5.2-bin.tar.gz
## 移動
mv apache-maven-3.5.2 /usr/local/maven3

修改環境變量, 在/etc/profile中添加如下幾行:

MAVEN_HOME=/usr/local/maven3
export MAVEN_HOME
export PATH=${PATH}:${MAVEN_HOME}/bin

記得執行source /etc/profile使環境變量生效。

輸入mvn -version 返回版本信息則安裝正常。

4、使用 Docker 部署 Spring Boot 項目

將項目 spring-boot-docker 拷貝服務器中,進入項目路徑下進行打包測試。

#打包
mvn package
#啓動
java -jar target/spring-boot-docker-1.0.jar

看到 Spring Boot 的啓動日誌後代表環境配置沒有問題,接下來咱們使用 DockerFile 構建鏡像。

mvn package docker:build

第一次構建可能有點慢,當看到如下內容的時候代表構建成功:

...
Step 1 : FROM openjdk:8-jdk-alpine
 ---> 224765a6bdbe
Step 2 : VOLUME /tmp
 ---> Using cache
 ---> b4e86cc8654e
Step 3 : ADD spring-boot-docker-1.0.jar app.jar
 ---> a20fe75963ab
Removing intermediate container 593ee5e1ea51
Step 4 : ENTRYPOINT java -Djava.security.egd=file:/dev/./urandom -jar /app.jar
 ---> Running in 85d558a10cd4
 ---> 7102f08b5e95
Removing intermediate container 85d558a10cd4
Successfully built 7102f08b5e95
[INFO] Built springboot/spring-boot-docker
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 54.346 s
[INFO] Finished at: 2018-03-13T16:20:15+08:00
[INFO] Final Memory: 42M/182M
[INFO] ------------------------------------------------------------------------

使用docker images命令查看構建好的鏡像:

docker images
REPOSITORY                      TAG                 IMAGE ID            CREATED             SIZE
springboot/spring-boot-docker   latest              99ce9468da74        6 seconds ago       117.5 MB

springboot/spring-boot-docker 就是咱們構建好的鏡像,下一步就是運行該鏡像:

docker run -p 8080:8080 -t springboot/spring-boot-docker

啓動完成以後咱們使用docker ps查看正在運行的鏡像:

docker ps
CONTAINER ID        IMAGE                           COMMAND                  CREATED             STATUS              PORTS                    NAMES
049570da86a9        springboot/spring-boot-docker   "java -Djava.security"   30 seconds ago      Up 27 seconds       0.0.0.0:8080->8080/tcp   determined_mahavira

能夠看到咱們構建的容器正在在運行,訪問瀏覽器:http://192.168.0.x:8080/,返回

Hello Docker!

說明使用 Docker 部署 Spring Boot 項目成功!

相關文章
相關標籤/搜索