Docker入门详解
简介
Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源。
Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的镜像中,然后发布到任何流行的 Linux 、Windows机器上,也可以实现虚拟化。
容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低。
官网:https://docs.docker.com/
概念
- 镜像(Image):Docker 镜像,是用于创建 Docker 容器的模板,是静态的定义。相当于Java中的类。
- 容器(Container):Docker 容器,是独立运行的一个或一组应用,是镜像运行时的实体。容器可以被创建、启动、停止、删除、暂停等。
- 仓库(Repository):仓库可看成一个代码控制中心,用来保存镜像。
Docker 使用客户端-服务器 (C/S) 架构模式,使用远程API来管理和创建Docker容器。
安装Docker
Centos:
-
安装yum-utils:
yum install -y yum-utils device-mapper-persistent-data lvm2
-
为yum源添加docker仓库位置:
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
-
安装docker:
yum install docker-ce
-
启动docker:
systemctl start docker
-
开机启动docker:
systemctl enable docker
Windows:
对于Windows 10以下的用户,推荐使用Docker Toolbox:http://mirrors.aliyun.com/docker-toolbox/windows/docker-toolbox/
对于Windows 10以上的用户,推荐使用Docker for Windows:http://mirrors.aliyun.com/docker-toolbox/windows/docker-for-windows/
Docker镜像常用命令
-
搜索镜像
docker search java
-
下载镜像
docker pull java:8
-
列出镜像
docker images
-
删除镜像
docker rmi java:8
-
指定名称删除镜像(强制)
docker rmi -f java:8
-
删除没有引用的镜像
docker rmi `docker images | grep none | awk '{print $3}'`
如有需要指定版本镜像,可在官网搜索,地址:https://hub.docker.com/
Docker容器常用命令
-
新建并启动容器
docker run -p 80:80 --name nginx -d nginx:1.17.0
-d选项:表示后台运行
–name选项:指定运行后容器的名字为nginx,之后可以通过名字来操作容器
-p选项:指定端口映射,格式为:hostPort:containerPort
-
启动容器
docker start $ContainerId
-
列出容器
docker ps docker ps -a
-
停止容器
docker stop $ContainerId
-
强制停止容器
docker kill $ContainerName(或者$ContainerId)
-
进入容器内部
docker exec -it $ContainerId /bin/sh
-
删除容器
docker rm $ContainerId
-
查看容器日志
docker logs $ContainerId
-
查看容器运行参数
docker inspect $ContainerId docker inspect --format '{{ .NetworkSettings.IPAddress }}' $ContainerName(或者$ContainerId)
-
宿主机与容器间文件拷贝
//将$ContainerId为4db8edd86202的容器内elasticsearch.yml文件拷贝到宿主机指定目录下:
docker cp 4db8edd86202:/usr/share/elasticsearch/config/elasticsearch.yml /home/haopeng/es
//将宿主机jenkins.war拷贝到$ContainerId为4db8edd86202的容器/usr/share/jenkins目录下
docker cp /home/jenkins.war 4db8edd86202:/usr/share/jenkins
Dockerfile介绍
# 该镜像需要依赖的基础镜像
FROM java:8
# 将当前目录下的jar包复制到docker容器的/目录下
ADD /target/*.jar /app.jar
# 声明服务运行在8080端口
EXPOSE 8080
# 指定docker容器启动时运行jar包
ENTRYPOINT ["java", "-jar","/app.jar"]
# 指定维护者的名字
MAINTAINER fangyan
DockerCompose介绍
# 指定版本
version: '2'
# 服务列表
services:
# 服务名称
order-service:
# Dockerfile路径
build: order-service/
# 端口设置
ports:
- "9091:9091"
# 环境变量
environment:
spring.profiles.active: dev
user-service:
build: user-service/
ports:
- "9090:9090"
environment:
spring.profiles.active: dev
Maven插件部署
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<!--版本可能会冲突,如果构建失败建议删除版本标签-->
<!--<version>1.0.0</version>-->
<executions>
<execution>
<id>build-image</id>
<phase>package</phase>
<goals>
<goal>build</goal>
</goals>
</execution>
</executions>
<configuration>
<imageName>park/${project.artifactId}:${project.version}</imageName>
<dockerHost>http://localhost:2375</dockerHost>
<!--第一种方式:使用Dockerfile-->
<dockerDirectory>${project.basedir}/src/main/docker</dockerDirectory>
<!--第二种方式:不使用Dockerfile-->
<!--<baseImage>java:8</baseImage>
<entryPoint>["java", "-jar","/${project.build.finalName}.jar"]
</entryPoint>-->
<resources>
<resource>
<targetPath>/</targetPath>
<directory>${project.build.directory}</directory>
<include>${project.build.finalName}.jar</include>
</resource>
</resources>
</configuration>
</plugin>
相关配置说明:
- executions.execution.phase:此处配置了在maven打包应用时构建docker镜像;
- imageName:用于指定镜像名称,mall-tiny是仓库名称, p r o j e c t . a r t i f a c t I d 为 镜 像 名 称 , {project.artifactId}为镜像名称, project.artifactId为镜像名称,{project.version}为仓库名称;
- dockerHost:打包后上传到的docker服务器地址;
- baseImage:该应用所依赖的基础镜像,此处为java;
- entryPoint:docker容器启动时执行的命令;
- resources.resource.targetPath:将打包后的资源文件复制到该目录;
- resources.resource.directory:需要复制的文件所在目录,maven打包的应用jar包保存在target目录下面;
- resources.resource.include:需要复制的文件,打包好的应用jar包。