現在 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 是容器化部署的基礎,二者結合使用更加方便微服務架構運維部署落地。