本文将一步步带你构建一个基于 Spring Boot
和 Docker
的单体应用,并通过 Docker 镜像将该应用部署在网易蜂巢
,创建容器服务,实现在线运行。
Spring Boot 是 Spring 社区发布的一个开源项目,旨在帮助开发者快速简单的构建可独立运行的项目。Spring Boot 会选择最适合的 Spring 子项目和第三方开源库进行整合。大部分 Spring Boot 应用只需要非常少的配置就可以快速运行起来。
官网地址:http://projects.spring.io/spring-boot/
Docker 是一套以容器技术为核心的,用于应用的构建、分发和执行的体系和生态。官网地址:
官网地址:https://docker.com
通俗地讲,“单体应用(monolith application)”就是将应用程序的所有功能都打包成一个独立的单元,可以是JAR、WAR、EAR或其它归档格式。
由网易公司推出的专业的容器云平台,深度整合了 IaaS、PaaS 及容器技术,提供弹性计算、DevOps 工具链及微服务基础设施等服务,帮助企业解决 IT、架构及运维等问题,使企业更聚焦于业务,是新一代的云计算平台。
官网地址:https://c.163.com
- 操作系统:64位,系统不限(需支持Docker),Windows 上建议安装 Git 客户端,方便支持 Linux 命令行操作
- JDK 1.8 + :推荐一款 Java 环境管理工具 jenv
- Maven 3.0 + :建议用杭研的 Maven 仓库
- Docker
- Linux安装教程参考:https://docs.docker.com/engine/installation/linux/
- 如果你使用的是Mac或Windows,官方已有原生应用支持,下载地址:https://docs.docker.com/
- Git及Github:文中源码通过 Git 做版本管理,并托管在 Github:https://github.com/163yun/spring-boot-docker-cloudcomb
- 一个你喜欢的编译器或IDE,推荐 Atom 或 Intellij IDEA
- 15分钟空挡时间(在以上环境准备好的情况下)
新建一个文件夹,名字就是你的项目名,这里以 spring-boot-docker-cloudcomb
为例。
mkdir spring-boot-docker-cloudcomb
在根目录下创建 pom.xml 文件
touch pom.xml
在当前目录下新建子目录:
mkdir -p src/main/java/com/bingohuang/hello
一个典型的 Maven 项目结构如下:
spring-boot-docker-cloudcomb
├── pom.xml
└── src
└── main
└── java
└── com
└── bingohuang
└── hello
在 pom.xml 中添加内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<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>bingohuang.com</groupId>
<artifactId>spring-boot-docker-cloudcomb</artifactId>
<version>0.1.0</version>
<packaging>jar</packaging>
<name>Spring Boot + Docker + Cloudcomb</name>
<description>一步步带你构建 Spring Boot + Docker 应用及网易蜂巢服务</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.3.3.RELEASE</version>
<relativePath/>
</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>
</plugins>
</build>
</project>
以上 pom 文件并不复杂,是一个 Spring Boot 的标准配置,Spring Boot 的 Maven 插件会提供以下功能:
- 收集的类路径上所有 jar 文件,并构建成一个单一的、可运行的 jar 文件,这使得它更方便地执行和传输服务。
- 搜索
public static void main()
方法来标记为可运行的类。 - 提供了一个内置的依赖解析器,用于设置版本号以匹配 Spring Boot 的依赖。你可以覆盖任何你想要的版本,但它会默认使用 Spring Boot 所设置的版本集。
创建一个简单的 Java 应用程序:
touch src/main/java/com/bingohuang/hello/Application.java
package com.bingohuang.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;
/**
* Sprint Boot 主应用入口
* @author <a href="http://bingohuang.com">bingohuang.com</a>
* @date 2016.11.15
*/
@SpringBootApplication
@RestController
public class Application {
@RequestMapping("/")
public String home() {
return "Hello Spring Boot, Docker and CloudComb!";
}
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
代码核心就是处理了根路径(/)的 web 请求,并包含可执行的 main 方法,比较好理解,解释一下其中几个关键点:
- 用 @SpringBootApplication 和 @RestController 注解类, 表示可用 Spring MVC 来处理 Web 请求
- @RequestMapping 将 / 映射到 home() 方法,并返回相应文本
- main() 方法使用 Spring Boot 的 SpringApplication.run() 方法来启动应用
该应用的核心代码就已完成,也就两个文件,可见 Spring Boot 非常简单,目录结构如下:
spring-boot-docker-cloudcomb
├── pom.xml
└── src
└── main
└── java
└── com
└── binghuang
└── hello
└── Application.java
在根目录执行:
mvn package
之后会在根目录下生成一个 target 目录,并在 target 目录下包含一个可执行的 jar 包。
Spring Boot 的强大之处是将应用打成一个可独立运行的 jar 文件:
java -jar target/spring-boot-docker-cloudcomb-0.1.0.jar
不出意外,输出日志,应用启动,默认会监听 8080 端口。
. ____ _ __ _ _
/\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
\\/ ___)| |_)| | | | | || (_| | ) ) ) )
' |____| .__|_| |_|_| |_\__, | / / / /
=========|_|==============|___/=/_/_/_/
:: Spring Boot :: (v1.3.3.RELEASE)
2016-11-15 22:21:26.789 INFO 91932 --- [ main] hello.Application : Starting Application v0.1.0 on BingoHuang.local with PID 91932 (/Users/bingo/Git/springboot/spring-boot-docker-cloudcomb/target/spring-boot-docker-cloudcomb-0.1.0.jar started by bingo in /Users/bingo/Git/springboot/spring-boot-docker-cloudcomb)
应用正常启动后,浏览器访问 http://127.0.0.1:8080/
,即可看到页面输出字样:
Hello Spring Boot, Docker and CloudComb!
在项目根目录下创建一个 Dockerfile 文件,内容如下:
touch Dockerfile
FROM hub.c.163.com/bingohuang/jdk8:latest
MAINTAINER Bingo Huang <me@bingohuang.com>
COPY target/spring-boot-docker-cloudcomb-0.1.0.jar app.jar
ENTRYPOINT ["java","-jar","/app.jar"]
此 Dockerfile 并不复杂,核心功能就是将可执行文件拷贝到镜像中,并在容器启动时默认执行启动命令 java -jar /app.jar
此时项目所有源文件编写完成,共三个文件,目录结构如下:
spring-boot-docker-cloudcomb
├── Dockerfile
├── pom.xml
└── src
└── main
└── java
└── com
└── bingohuang
└── hello
└── Application.java
在项目根目录下执行 docker 构建镜像命令:
docker build -t spring-boot-docker-cloudcomb:0.1.0 .
详情请查看 docker build 命令详解。
运行 docker 容器:
docker run -p 8080:8080 -t spring-boot-docker-cloudcomb:0.1.0
详情请查看 docker run 命令详解。
同样,会输出日志(略有不同),监听 8080 端口,浏览器访问 http://127.0.0.1:8080/
,输出文本。
. ____ _ __ _ _
/\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
\\/ ___)| |_)| | | | | || (_| | ) ) ) )
' |____| .__|_| |_|_| |_\__, | / / / /
=========|_|==============|___/=/_/_/_/
:: Spring Boot :: (v1.3.3.RELEASE)
2016-11-15 14:18:54.889 INFO 1 --- [ main] hello.Application : Starting Application v0.1.0 on 509da1aefb69 with PID 1 (/app.jar started by root in /)
Hello Spring Boot, Docker and CloudComb!
首先,需要有一个网易蜂巢的账号,可在蜂巢首页注册。
接下来,在命令行中登录蜂巢镜像仓库:
docker login hub.c.163.com
Username (me@bingohuang.com): me@bingohuang.com
Password:
Login Succeeded
接着,统一标记本地镜像:
docker tag spring-boot-docker-cloudcomb:0.1.0 hub.c.163.com/bingohuang/spring-boot-docker-cloudcomb:0.1.0
最后,推送镜像到蜂巢镜像仓库:
docker push hub.c.163.com/bingohuang/spring-boot-docker-cloudcomb:0.1.0
打开蜂巢控制台:https://c.163.com/dashboard ,点击左侧菜单栏服务管理,可以使用默认空间,点击创建服务:
创建服务总共分三步,可进可退。
第一步:设置服务名,服务状态,公网 IP 及计费模式设置,再点击下一步:
第二步:选择镜像,设置容器名称即可,SSH秘钥用于远程登录,对于一个服务来说,可以不选,点击下一步:
第三步:选择规格,默认SSD云硬盘,配置容器到服务的端口映射(对有状态的服务,对外暴露的端口默认还是容器端口),副本数限制为1,不到 5 分钱一个小时,非常实惠,立即创建:
再点击详细信息,查看基本信息中的公网IP,此服务是:59.111.114.43
打开浏览器,访问服务:http://59.111.114.43:8080/
,发现同样输出了:
注:此镜像我已经在蜂巢上公开,地址是:https://c.163.com/hub#/m/repository/?repoId=41359 (你也可以直接在蜂巢镜像中心搜索:spring-boot-docker-cloudcomb
),打开收藏,即可直接基于该镜像创建 Spring Boot + Docker 的应用服务。
至此,一个基于 Spring Boot 和 Docker 的应用就构建完成,并演示了如何在蜂巢上快速创建该应用的在线服务,希望对你有所帮助。
- ☛ 源代码:https://github.com/163yun/spring-boot-docker-cloudcomb
- ☛ Spring Boot:http://projects.spring.io/spring-boot/
- ☛ Docker: https://docker.com
- ☛ 网易蜂巢: https://c.163.com