Docker之数据卷&Dockerfile创建镜像

本文详细介绍了Docker管理数据的两种主要方式:数据卷和数据卷容器,包括它们的定义、特性及常用命令。同时,深入讲解了如何使用Dockerfile创建自定义镜像,包括Dockerfile的基本结构、构建步骤和注意事项。内容涵盖了数据持久化和镜像定制的关键知识点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

一、Docker管理数据方式

        一、数据卷

                   1、定义:

                   2、特性:

                   3、命令:

        二、数据卷容器

                   1、定义

                   2、命令

二、Dockerfile创建镜像

        1、定义:

        2、构建基础镜像

        3、基本结构

        4、准备工作

                 1、创建文件夹上传jdk的安装包,和在同级目录下编写Dockerfile文件

                 2、编写 Dockerfile 文件

        5、创建镜像 


一、Docker管理数据方式

           具体讲解:管理容器数据 | Docker-guide

        一、数据卷

                   1、定义:

为了很好的实现数据保存和数据共享,Docker提出了Volume这个概念,简单的说就是绕过默认的联合文件系统,而以正常的文件或者目录的形式存在于宿主机上。又被称作数据卷

                   2、特性:

数据卷 是一个可供一个或多个容器使用的特殊目录,它绕过 UFS,可以提供很多有用的特性

1、数据卷可以在容器之间共享和重用
2、对数据卷的修改会立马生效
3、对数据卷的更新,不会影响镜像
4、数据卷默认会一直存在,即使容器被删除

                   3、命令:

                            3.1创建数据卷

docker volume create my-vol

                            3.2查看所有数据卷

docker volume ls

                            3.3查看数据卷信息

docker volume inspect my-vol

                            3.4删除一个volume

docker volume rm my-vol

补充:

数据卷 是被设计用来持久化数据的,它的生命周期独立于容器,Docker不会在容器被删除后自动删除数据卷,并且也不存在垃圾回收这样的机制来处理没有任何容器引用的数据卷,无主的数据卷可能会占据很多空间,所以要及时删除

                            3.5挂载数据卷

在用 docker run 命令的时候,使用 --mount 标记来将 数据卷 挂载到容器里。在一次 docker run中可以挂载多个 数据卷 

docker run -itd \
--name 容器名字 \
--mount source=数据卷名称,target=容器中的对应目录 \
镜像名称

注意:

最好是通过run而非create/start创建启动容器,create/start命令创建启动容器后,再挂载数据卷相当麻烦,要修改很多配置文件,但并非不可以

加了“\”意为将最后的回车换行给注释了,系统理解为命令还没有结束,因而是继续等待用户进行输入,直到读到结束符,如回车

如果数据卷不存在,docker会自动创建
如果容器上目录不存在, docker会自动创建

                            3.6查看数据卷的具体信息

docker inspect name

                            3.7挂载目录

docker run -itd \
--name 容器名字 \
--mount type=bind,source=宿主机目录,target=容器中的对应目录 \
镜像名称

        二、数据卷容器

                   1、定义

如果用户需要在多个容器之间共享一些持续更新的数据,最简单的方式是使用数据卷容器。
数据卷容器也是一个容器,但是它的目的是专门提供数据卷给其他容器挂载                          

                   2、命令

                            2.1创建数据卷容器

docker run -itd --name name -v dir centos

                            2.2挂载数据卷容器

docker run -itd --name name --volumes-from db_data centos

二、Dockerfile创建镜像

           具体讲解:Docker 镜像 | Docker-guide

        1、定义:

Dockerfile 是一个文本格式的配置文件, 用户可以使用 Dockerfile 来快速创建自定义的镜像,另外,使用Dockerfile去构建镜像好比使用pom去构建maven项目一样,有异曲同工之妙

        2、构建基础镜像

构建基础镜像有两种方式,第一种是centos,第二种是alpine

这两种方式区别如下:

1. 空间大小差异,alpine默认5M左右,centos等都在200M左右。
 

2. 默认软件包差异,alpine选用busybox,centos等则是bash+coreutils几件套。
 

3. alpine中,国际化组件被优化掉了。
 

4. 还有一点,alpine中选用的都是“最简依赖”,这点和archlinux比较像,举个例子,
openssh包不会自带pam插件,于是他也就不支持ldap。这点我给alpinelinux官方提过
issue。和php不一样,php可以做成php-pdo,php-dom的包,然后动态加载共享库。
openssh不行,“没带就是没写”。

5. glibc差异,alpine选用musl,centos等选用glibc,其他的倒还好,libc的差异对开发很重要。

        3、基本结构

Dockerfile 由一行行命令语句组成,并且支持以 # 开头的注释行。
一般的,Dockerfile 分为四部分:基础镜像信息、维护者信息、镜像操作指令和容器启动时执行指令
 

四部分对比
部分命令
基础镜像信息FROM
维护者信息MAINTAINER
镜像操作指令RUN、ENV、COPY、ADD、EXPOSE、WORKDIR、ONBUILD、USER、
VOLUME等
容器启动时执行指
CMD、ENTRYPOINT

        4、准备工作

                 1、创建文件夹上传jdk的安装包,和在同级目录下编写Dockerfile文件

                 2、编写 Dockerfile 文件

#1.指定基础镜像,并且必须是第一条指令
FROM centos:latest


#2.指明该镜像的作者和其电子邮件
MAINTAINER xx "xx@qq.com"


#3.在构建镜像时,指定镜像的工作目录,之后的命令都是基于此工作目录,如果不存在,则会创建目录
WORKDIR /usr/local/java


#4.一个复制命令,把jdk安装文件复制到镜像中,注意:jdk*.tar.gz使用的是相对路径
ADD jdk-8u221-linux-x64.tar.gz /usr/local/java/


#5.配置环境变量
ENV JAVA_HOME=/usr/local/java/jdk1.8.0_221
ENV CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV PATH=$JAVA_HOME/bin:$PATH
#容器启动时需要执行的命令

#CMD ["java","-version"]

区别:ADD和COPY

 使用add命令拖入到文件夹中,先会进行解压,然后再放入进去

copy命令注解是将压缩文件拖入其中

        5、创建镜像 

编写完成 Dockerfile 之后,可以通过 docker build 命令来创建镜像。

docker build -t jdk8:v1.0 .

 注1:-t jdk8:v1.0 给新构建的镜像取名为 jdk8, 并设定版本为 v1.0
注2:注意最后有个点,代表使用当前路径的 Dockerfile 进行构建

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值