Hello! 欢迎来到小浪云!


如何理解docker镜像和容器的区别? run命令怎么使用?


docker镜像和容器的区别在于镜像是静态模板,而容器是运行实例。具体来说:1. 镜像是只读的,包含应用所需的所有文件、依赖和配置,相当于打包好的软件安装包;2. 容器是基于镜像创建的可读写实例,是实际运行程序的载体;3. 镜像不会占用运行资源,只有启动镜像生成容器后,才会真正运行程序;4. 使用docker run命令可以从镜像启动容器,并通过参数如-d后台运行、-p端口映射、-v目录挂载、–name指定名称、-e设置环境变量进行配置;5. 容器停止后数据不会丢失,但若删除容器则数据可能丢失,可通过-v挂载宿主机目录实现数据持久化保存。

如何理解docker镜像和容器的区别? run命令怎么使用?

docker镜像和容器的区别其实可以简单理解成“蓝图”和“房子”的关系。镜像是一个静态的模板,包含了运行某个应用所需的所有文件、依赖和配置;而容器则是根据这个镜像实际运行起来的一个实例,是真正跑起来的程序。

你可以把镜像想象成一个封装好的系统快照,它本身不会变化,也不会占用运行资源。只有当你用docker run命令启动它时,才会生成一个容器,这个容器才是你真正操作的对象


镜像 vs 容器:它们到底差在哪?

镜像(Image) 是只读的,比如你从 Docker Hub 拉下来的 Ubuntunginx 这些,都是镜像。它们是构建容器的基础。你可以把它理解为一个打包好的软件安装包。

容器(Container) 是可读写的,并且在运行状态中。它是由镜像创建出来的具体实例。比如你运行了一个 nginx 镜像,就生成了一个 nginx 容器,你可以进到这个容器里执行命令、修改配置、查看日志等。

举个例子:

  • 你写了个 Python 应用,打成了一个镜像叫 myapp:latest。这个镜像无论传给谁,内容都是一样的。
  • 别人拿到这个镜像后,用 docker run 启动,就会得到一个属于他自己的容器,他在里面做的修改不会影响原始镜像。

docker run 命令怎么用?常见参数有哪些?

docker run 是用来从镜像创建并启动容器的核心命令。基本格式是:

docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

几个常用参数说明一下:

  • -d:后台运行容器。如果你不加这个,容器会占据当前终端窗口。
  • -p:端口映射。比如 -p 8080:80 表示把宿主机的 8080 端口映射到容器的 80 端口。
  • -v:挂载目录。例如 -v /host/data:/container/data,这样容器里的数据会直接使用宿主机上的文件。
  • –name:给容器起个名字,方便后续管理。比如 –name mynginx
  • -e:设置环境变量,比如 -e mysql_ROOT_PASSWORD=123456。

举个简单的例子:

docker run -d -p 80:80 --name mynginx nginx

这条命令的意思就是:以后台方式运行一个基于 nginx 镜像的容器,把宿主机的 80 端口映射到容器的 80 端口,并给这个容器命名为 mynginx。


容器停止后,数据会不会丢?

这个问题很常见。默认情况下,容器停止后,你在容器里做的修改还是存在的,只要容器没有被删除。但如果你运行完就删了容器(比如用了 –rm 参数),那数据就没了。

如果你希望数据持久化保存,可以用 -v 把宿主机的一个目录挂载到容器里,这样即使容器删了,数据还在宿主机上。

比如运行 MySQL 容器时,通常都会把数据目录挂载出来:

docker run -d --name mysql -v /mydata/mysql:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 mysql

这样就算容器出问题或者重建了,数据还在 /mydata/mysql 里。


基本上就这些。镜像和容器的关系搞清楚之后,再配合 run 的各种参数,就能灵活地管理你的应用了。刚上手的时候可能会觉得概念多,但用几次就自然明白了。

相关阅读