Docker-DockerFile制定镜像

简介: Docker-DockerFile制定镜像

概念说明

Docker

 &emspDocker是一种开源的容器化平台,它可以将应用程序及其依赖项打包到一个独立的、可移植的容器中,以实现快速部署和跨平台的运行。而Dockerfile则是用于定义Docker镜像的文本文件,其中包含了构建镜像所需的指令和配置。

1cf5608803c44b50a99d2b56091cfb55.png

DockerFile

 Dockerfile是用于定义镜像构建过程的文本文件。它由一系列指令组成,每个指令对应一个操作。常见的指令包括FROM、RUN、COPY、CMD等,它们用于指定基础镜像、运行命令、复制文件等操作。

 DockerFile是一个用来编写Docker镜像的文本文件,文本内容包含了一条条构建镜像所需要的指令和说明。DockerFile就想要一个脚本文件一样。把我们想要执行的操作放到文本文件里,一键执行。这样我们就可以复用这个DockerFile文件了。在别的服务器上执行这个文件也就会产生一个一模一样的Docker镜像。

提供服务

「 Dockerfile最佳实践」:编写高质量的Dockerfile需要遵循一些最佳实践。例如,使用多个RUN指令来避免不必要的镜像层、使用.gitignore文件来排除不必要的文件、使用ENTRYPOINT指令来定义容器启动时的命令等。

「 构建和管理镜像 」:使用docker build命令可以根据Dockerfile构建镜像。构建过程中可以使用参数来定制镜像的配置,如设置环境变量、指定工作目录等。构建完成后,可以使用docker push命令将镜像推送到仓库,并使用docker pull命令从仓库中获取镜像。

「 运行和管理容器 」:使用docker run命令可以根据镜像创建并运行容器。可以通过参数来配置容器的网络、端口映射、环境变量等。运行容器后,可以使用docker exec命令在容器内部执行命令,使用docker logs命令查看容器日志,使用docker stop命令停止容器等。

「 Docker生态系统和实用工具 」:Docker拥有丰富的生态系统和实用工具,可以帮助开发人员更好地使用和管理Docker。一些常用的工具包括Docker Compose用于定义和管理多容器应用、Docker Swarm用于构建和管理集群、Portainer用于可视化管理Docker等。

指令解析

 Dockerfile是用于定义镜像构建过程的文本文件。它由一系列指令组成,每个指令对应一个操作。常见的指令包括FROM、RUN、COPY、CMD等,它们用于指定基础镜像、运行命令、复制文件等操作。

1.基础镜像:FROM(制定基础镜像) 镜像的名字:版本号

FROM centos:6.8

2.制作镜像操作指令:安装一些依赖

RUN yum install openssh-server -y

3.容器启动后执行的事情

CMD ["参数1","参数2"]

4.ENTRYPOINT:容器启动后执行的事情

ENTRYPOINT["参数1","参数2"]

5.其他变量

ADD:将宿主机的文件添加到容器内,有自动解压的功能
COPY:将宿主机的文件添加到容器内,单纯复制文件
WORKDIR:设置当前工作目录,切换路径
VOLUME +路径 设置存储卷,挂载主机目录(将容器内的指定路径,在容器运行时,该目录自动挂载为匿名卷,任何向该目录中写入的数据的操作,都不会被容器记录,保证了容器存储层的无状态理念)
EXPOSE:指定对外的端口
ENV 变量名=“值” 通过$NAME 就可以直接获取变量值了,(容器间可以相互获取) 定义环境变量
ARG 定义环境变量
USER 用户身份 :用户切换用户身份  例如:USER admin切换为root权限

6.注意事项

 ENV是设置环境变量,定义了环境变量,那么在后续的指令中,就可以使用这个环境变量。而ARG是构建参数,与 ENV 作用一致。不过作用域不一样。ARG 设置的环境变量仅对 Dockerfile 内有效,也就是说只有 docker build 的过程中有效,构建好的镜像内不存在此环境变量。

应用实例

af441a8651264cbe810da5e7480bcdd6.png

常用命令

docker stats 查看cpu的状态

docker stop +镜像ID 停止正在运行的镜像

docker ps 查看正在运行的镜像

docker run -d(后台运行) -p(端口映射,宿主机端口:容器端口) -e(运行的限制条件 例如,ES_JACA_OPTS=“-Xms64m(最小运行内存) -Xms512m(最大运行内存)”)

docker image ls 查看本地已经安装的镜像文件

docker rmi(i为image的缩写) +镜像ID 删除本地已经安装好的镜像文件

docker rm +容器ID 删除容器

docker info | grep Root 查看docker 镜像的存储路径

docker run -it(表示开启一个交互式的终端) 容器名 bash(解释器) 运行镜像进入容器

docker exec -it 容器名 bash 进入正在运行的容器内

exit 退出镜像

docker image save 镜像名:版本号 >(重定向符号) /路径/文件名.tgz 导出镜像到指定路径

docker image load -i /镜像存在的路径 导入指定路径下的镜像

docker logs -f(实时刷新) +容器id | tail -5(最新的五条信息) 查看容器对应的日志信息。

docker port 容器ID 查看容器的端口映射

docker bulid -t(-t代表tag) ‘镜像名称’ 脚本名称 用来创建自定义镜像文件的

docker tag 原镜像名 新镜像名 修改镜像名称

netstat -tunlp 查看宿主机的使用的端口

总结提升

 Docker和Dockerfile是现代化软件开发和部署的重要工具。通过使用Docker,开发人员可以实现快速、可靠和可移植的应用部署。而通过制作高质量的Dockerfile,可以确保镜像的可靠性和可维护性。对于开发人员来说,掌握Docker和Dockerfile的使用和最佳实践,将极大地提高开发和部署效率。


相关文章
|
26天前
|
Docker 容器
将本地的应用程序打包成Docker镜像
将本地的应用程序打包成Docker镜像
|
10天前
|
NoSQL PHP MongoDB
docker push推送自己搭建的镜像
本文详细介绍了如何搭建和复盘两个Web安全挑战环境:人力资源管理系统和邮件管理系统。首先,通过Docker搭建MongoDB和PHP环境,模拟人力资源管理系统的漏洞,包括nosql注入和文件写入等。接着,复盘了如何利用这些漏洞获取flag。邮件管理系统部分,通过目录遍历、文件恢复和字符串比较等技术,逐步绕过验证并最终获取flag。文章提供了详细的步骤和代码示例,适合安全研究人员学习和实践。
36 3
docker push推送自己搭建的镜像
|
14天前
|
Docker 容器
|
26天前
|
数据库 Docker 容器
Docker在现代软件开发中扮演着重要角色,通过Dockerfile自动化构建Docker镜像,实现高效、可重复的构建过程。
Docker在现代软件开发中扮演着重要角色,通过Dockerfile自动化构建Docker镜像,实现高效、可重复的构建过程。Dockerfile定义了构建镜像所需的所有指令,包括基础镜像选择、软件安装、文件复制等,极大提高了开发和部署的灵活性与一致性。掌握Dockerfile的编写,对于提升软件开发效率和环境管理具有重要意义。
48 9
|
1月前
|
缓存 Linux 网络安全
docker的镜像无法下载如何解决?
【10月更文挑战第31天】docker的镜像无法下载如何解决?
2068 30
|
26天前
|
存储 缓存 运维
Docker镜像采用分层存储,每层代表镜像的一部分,如基础组件或应用依赖,多层叠加构成完整镜像
Docker镜像采用分层存储,每层代表镜像的一部分,如基础组件或应用依赖,多层叠加构成完整镜像。此机制减少存储占用,提高构建和传输效率。Docker还通过缓存机制提升构建和运行效率,减少重复工作。文章深入解析了Docker镜像分层存储与缓存机制,包括具体实现、管理优化及实际应用案例,帮助读者全面理解其优势与挑战。
44 4
|
1月前
|
存储 关系型数据库 Linux
【赵渝强老师】什么是Docker的镜像
Docker镜像是一个只读模板,包含应用程序及其运行所需的依赖环境。镜像采用分层文件系统,每次修改都会以读写层形式添加到原只读模板上。内核bootfs用于加载Linux内核,根镜像相当于操作系统,上方为应用层。镜像在物理存储上是一系列文件的集合,默认存储路径为“/var/lib/docker”。
|
1月前
|
存储 监控 Linux
docker构建镜像详解!!!
本文回顾了Docker的基本命令和管理技巧,包括容器和镜像的增删改查操作,容器的生命周期管理,以及如何通过端口映射和数据卷实现容器与宿主机之间的网络通信和数据持久化。文章还详细介绍了如何使用Docker部署一个简单的Web应用,并通过数据卷映射实现配置文件和日志的管理。最后,文章总结了如何制作自定义镜像,包括Nginx、Python3和CentOS镜像,以及如何制作私有云盘镜像。
163 2
|
1月前
|
关系型数据库 MySQL Docker
docker环境下mysql镜像启动后权限更改问题的解决
在Docker环境下运行MySQL容器时,权限问题是一个常见的困扰。通过正确设置目录和文件的权限,可以确保MySQL容器顺利启动并正常运行。本文提供了多种解决方案,包括在主机上设置正确的权限、使用Dockerfile和Docker Compose进行配置、在容器启动后手动更改权限以及使用 `init`脚本自动更改权限。根据实际情况选择合适的方法,可以有效解决MySQL容器启动后的权限问题。希望本文对您在Docker环境下运行MySQL容器有所帮助。
205 1
|
1月前
|
缓存 JavaScript 安全
深入理解Docker镜像构建过程
深入理解Docker镜像构建过程
75 0

热门文章

最新文章