1、docker简介
Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口
2、docker优点
简化配置
虚拟机的最大好处是能在你的硬件设施上运行各种配置不一样的平台(软件, 系统), Docker在降低额外开销的情况下提供了同样的功能. 它能让你将运行环境和配置放在代码汇总然后部署, 同一个Docker的配置可以在不同的环境环境中使用, 这样就降低了硬件要求和应用环境之间耦合度.代码流水线管理
代码从开发者的机器到最终在生产环境上的部署, 需要经过很多的中间环境. 而每一个中间环境都有自己微小的差别, Docker给应用提供了一个从开发到上线均一致的环境, 让代码的流水线变得简单不少.提升开发效率
不同环境中, 开发者的共同目标:
1)想让开发环境尽量贴近生产环境.
2)想快速搭建开发环境
开发环境的机器通常内存比较小, 使用虚拟机, 经常需要为开发环境的机器加内存, 而现在Docker可以轻易的让几十个服务在Docker中跑起来.隔离应用
开发时会在一个台机器上运行不同的应用:
1)为了降低成本, 进行服务器整合
2) 将一个整体式的应用拆分成低耦合的单个服务(微服务架构)整合服务器
Docker隔离应用的能力使得Docker可以整合多个服务器以降低成本. 由于没有多个操作系统的内存占用, 以及能在多个实例之间共享没有使用的内存, Docker可以比虚拟机提供更好的服务器整合解决方案.快速部署
Docker为进程创建一个容器, 不需要启动一个操作系统, 时间缩短为秒级别.
可以在数据中心创建销毁资源而无须担心重新启动带来的开销. 通常数据中心的资源利用率只有30% , 通过使用Docker并进行有效的资源分配可以提高资源的利用率.
3、准备工作
环境条件:
- linux系统,不建议windows
- docker最新版本
- jdk 1.8
- maven3.0
采用maven的方式去构建项目,并采用docker-maven-plugin去构建docker镜像。
4、构建eureka服务镜像
1)在pom文件加上插件:
<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.3</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>
</plugins>
</build>
Spotify 的 docker-maven-plugin 插件是用maven插件方式构建docker镜像的。
- imageName指定了镜像的名字
- dockerDirectory指定 Dockerfile 的位置
- resources是指那些需要和 Dockerfile 放在一起,在构建镜像时使用的文件,一般应用 jar 包需要纳入。
2)修改下配置文件:
server:
port: 8761
eureka:
instance:
prefer-ip-address: true
client:
registerWithEureka: false
fetchRegistry: false
3)编写dockerfile文件:
FROM frolvlad/alpine-oraclejdk8:slim
VOLUME /tmp
ADD eureka-server-0.0.1-SNAPSHOT.jar app.jar
#RUN bash -c 'touch /app.jar'
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
EXPOSE 8761
4)docker file编写指令:
- FROM
FROM <image>
FROM <image>:<tag>
FROM <image> <digest>
FROM指令必须指定且需要在Dockerfile其他指令的前面,指定的基础image可以是官方远程仓库中的,也可以位于本地仓库。后续的指令都依赖于该指令指定的image。当在同一个Dockerfile中建立多个镜像时,可以使用多个FROM指令。
- VOLUME
格式为:
VOLUME ["/data"]
使容器中的一个目录具有持久化存储数据的功能,该目录可以被容器本身使用,也可以共享给其他容器。当容器中的应用有持久化数据的需求时可以在Dockerfile中使用该指令。
ADD
从src目录复制文件到容器的dest。其中src可以是Dockerfile所在目录的相对路径,也可以是一个URL,还可以是一个压缩包ENTRYPOINT
指定Docker容器启动时执行的命令,可以多次设置,但是只有最后一个有效。EXPOSE
为Docker容器设置对外的端口号。在启动时,可以使用-p选项或者-P选项。
5) 构建镜像
执行构建docker镜像maven命令:
mvn clean
mvn package docker:build
构建eureka-server镜像成功。
5、构建service-hi镜像
- pom文件导入同eurek-server
- 修改下配置文件:
eureka:
client:
serviceUrl:
defaultZone: http://eureka-server:8761/eureka/
server:
port: 8763
spring:
application:
name: service-hi
在这里说下:defaultZone发现服务的host改为镜像名。
- dockefile 编写同eureka-server
- 构建镜像:
mvn clean
mvn package docker:build
这时我们运行docke的eureka-server 和service-hi镜像:
docker run -p 8761: 8761 -t forezp/eureka-server
docker run -p 8763: 8763 -t forezp/service-hi
访问localhost:8761
6、采用docker-compose启动镜像
Compose 是一个用于定义和运行多容器的Docker应用的工具。使用Compose,你可以在一个配置文件(yaml格式)中配置你应用的服务,然后使用一个命令,即可创建并启动配置中引用的所有服务。下面我们进入Compose的实战吧。
采用docker-compose的方式编排镜像,启动镜像:
version: '3'
services:
eureka-server:
image: forezp/eureka-server
restart: always
ports:
- 8761:8761
service-hi:
image: forezp/service-hi
restart: always
ports:
- 8763:8763
输入命令: docker-compose up
7、采用docker-compose编排并启动镜像
docker-compose也可以构建镜像,现在我们采用docker-compose的方式构建镜像。
现在以eureka-server为例: 将Dockerfile移到eureka-server的主目录,改写ADD的相对路径:
FROM frolvlad/alpine-oraclejdk8:slim
VOLUME /tmp
ADD ./target/eureka-server-0.0.1-SNAPSHOT.jar app.jar
#RUN bash -c 'touch /app.jar'
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
EXPOSE 8761
同理修改service-hi目录;
编写构建镜像docker-compose-dev文件:
version: '3'
services:
eureka-server:
build: eureka-server
ports:
- 8761:8761
service-hi:
build: service-hi
ports:
- 8763:8763
命令构建镜像并启动:
docker-compose -f docker-compose.yml -f docker-compose-dev.yml up