现在 Docker 的使用已经很是广泛,特别是在一线互联网公司,使用 Docker 技术能够帮助企业快速水平扩展服务,从而达到弹性部署业务的能力。在云服务概念兴起以后,Docker 的使用场景和范围进一步发展,现在在微服务架构愈来愈流行的状况下,微服务 + Docker 的完美组合,更加方便微服务架构运维部署落地。java
Docker 属于 Linux 容器的一种封装,提供简单易用的容器使用接口,它是目前最流行的 Linux 容器解决方案。Docker 将应用程序与该程序的依赖打包在一个文件里面,运行这个文件,就会生成一个虚拟容器。程序在这个虚拟容器里运行,就好像在真实的物理机上运行同样,有了 Docker,就不用担忧环境问题了。nginx
容器除了运行其中应用外,基本不消耗额外的系统资源,使得应用的性能很高,同时系统的开销尽可能小。传统虚拟机方式是运行 10 个不一样的应用就要启动 10 个虚拟机,而 Docker 只须要启动 10 个隔离的应用便可。web
具体说来,Docker 在以下几个方面具备较大的优点:spring
Docker 是 CS 架构,主要有两个概念,具体以下:docker
Docker 的组成有三个主要概念,具体以下:apache
https://hub.docker.com/
)查看,也能够搭建本身私有的 Docker registry。镜像就至关于打包好的版本,镜像启动以后运行在容器中,仓库就是装存储镜像的地方json
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.0.RELEASE</version> </parent>
<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>
@RestController public class DockerController { @RequestMapping("/") public String index() { return "Hello Docker!"; } }
@SpringBootApplication public class DockerApplication { public static void main(String[] args) { SpringApplication.run(DockerApplication.class, args); } }
添加完毕后启动项目,启动成功后浏览器访问网址:
http://localhost:8080/
,页面返回:Hello Docker!,说明 Spring Boot 项目配置正常。ubuntu
<properties> <docker.image.prefix>springboot</docker.image.prefix> </properties>
<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>
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"]
这样 Spring Boot 项目添加 Docker 依赖就完成了,下面解释一下什么是 Dockerfile?vim
Docker 镜像是一个特殊的文件系统,除了提供容器运行时所需的程序、库、资源、配置等文件外,还包含了为运行时准备的一些配置参数(如匿名卷、环境变量、用户等)。镜像不包含任何动态数据,其内容在构建以后也不会被改变。centos
镜像的定制实际上就是定制每一层所添加的配置、文件。若是能够把每一层修改、安装、构建、操做的命令都写入一个脚本,用这个脚原本构建、定制镜像,那么以前说起的没法重复的问题、镜像构建透明性的问题、体积的问题就都会解决,这个脚本就是 Dockerfile。
Dockerfile 是一个文本文件,其内包含了一条条的指令(Instruction),每一条指令构建一层,所以每一条指令的内容,就是描述该层应当如何构建。有了 Dockerfile,当须要定制本身额外的需求时,只需在 Dockerfile 上添加或者修改指令,从新生成 image 便可,省去了敲命令的麻烦。
Dockerfile 文件格式以下:
##Dockerfile 文件格式 # This dockerfile uses the ubuntu image # VERSION 2 - EDITION 1 # Author: docker_user # Command format: Instruction [arguments / command] .. #(1)第一行必须指定基础镜像信息 FROM ubuntu # (2)维护者信息 MAINTAINER docker_user docker_user@email.com # (3)镜像操做指令 RUN echo "deb http://archive.ubuntu.com/ubuntu/ raring main universe" >> /etc/apt/sources.list RUN apt-get update && apt-get install -y nginx RUN echo "\ndaemon off;" >> /etc/nginx/nginx.conf # (4)容器启动执行指令 CMD /usr/sbin/nginx
Dockerfile 分为四部分:
一开始必需要指明所基于的镜像名称,接下来通常会说明维护者信息;后面则是镜像操做指令,如 RUN 指令。每执行一条 RUN 指令,镜像添加新的一层,并提交;最后是 CMD 指令,来指明运行容器时的操做命令。
Spring Boot 应用 Docker 部署须要使用 Dockerfile 定义部署方案。
建议在 Linux 环境下安装 Docker,Window 环境搭建比较复杂且容易出错,使用 Centos7 + yum 来安装 Docker 环境很方便。
yum install docker
service docker start chkconfig docker on
systemctl start docker.service systemctl enable docker.service
vi /etc/docker/daemon.json #添加后: { "registry-mirrors": ["https://registry.docker-cn.com"], "live-restore": true }
systemctl restart docker
docker version
输入上述命令,返回 docker 的版本相关信息,证实 docker 安装成功。
yum -y install java-1.8.0-openjdk*
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
返回版本信息则安装正常。## 解压 tar vxf apache-maven-3.5.2-bin.tar.gz ## 移动 mv apache-maven-3.5.2 /usr/local/maven3
MAVEN_HOME=/usr/local/maven3 export MAVEN_HOME export PATH=${PATH}:${MAVEN_HOME}/bin
source /etc/profile
使环境变量生效mvn -version
返回版本信息则安装正常#打包 mvn clean package #启动 java -jar target/spring-boot-docker-1.0.jar
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
docker run -p 8080:8080 -t springboot/spring-boot-docker
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 项目成功!
除过以上使用的 Docker 命令外,还有一些其余经常使用的命令,经过这些命令能够查看容器的相关状态。
拉取 docker 镜像:
docker pull image_name
docker images
docker rmi docker.io/tomcat:7.0.77-jre7 或者 docker rmi b39c68b7af30
docker ps
docker ps -a
docker start container_name/container_id docker stop container_name/container_id docker restart container_name/container_id
docker attach container_name/container_id
docker rm container_name/container_id
docker rm $(docker ps -a -q)
docker info
docker pull centos:latest
经过这些命令能够发现 Docker 的使用方式很是灵活,能够把项目作成镜像来管理,部署的时候直接下载对应版本的镜像直接运行便可。
Docker 是容器化技术的基础,服务编排、弹性水平扩充都依赖于 Docker 的使用,使用 Docker 部署 Spring Boot 项目,能够把项目当作版本库同样管理,不须要关注环境、迁移等问题。Spring Boot 是微服务开发的基础,Docker 是容器化部署的基础,二者结合使用更加方便微服务架构运维部署落地。