【Docker使用】从拉取到运行

最近我在尝试使用Docker运行LocalAI大模型服务,在这个过程中遇到了不少疑问。通过实践和查阅资料,我总结了一些经验,希望能够帮助大家更好地理解Docker的工作机制。

1. Docker镜像查找流程

当我们执行docker run命令时,Docker会按照以下步骤查找镜像:

  1. 本地查找:首先在本地镜像仓库中查找是否存在指定名称和标签的镜像。
  2. 远程拉取:如果本地没有,Docker会默认从Docker Hub(或配置的其他镜像仓库)拉取镜像。

在本文的例子中,我使用了localai/localai:master-aio-gpu-nvidia-cuda-12这个镜像。由于本地没有,所以Docker开始从远程仓库拉取。

2. 镜像参数配置详解

在运行Docker容器时,我们可以通过参数配置容器的各种行为。下面是我使用的命令及其参数说明:

bash 复制代码
docker run -d \
  --name localai \          # 为容器指定一个名称
  --gpus all \              # 允许容器使用所有GPU资源
  -p 8080:8080 \            # 端口映射,将宿主机的8080端口映射到容器的8080端口
  -v D:/local-ai/models:/models \  # 卷挂载,将宿主机的D:/local-ai/models目录挂载到容器的/models目录
  -e THREADS=6 \            # 设置环境变量THREADS,控制线程数
  -e CONTEXT_SIZE=4096 \    # 设置上下文大小
  -e GPU_LAYERS=35 \        # 设置使用GPU的层数
  -e BATCH_SIZE=512 \       # 设置批处理大小
  -e MODEL_FILE=llama-2-7b-chat.Q4_K_M.gguf \  # 设置模型文件
  localai/localai:master-aio-gpu-nvidia-cuda-12  # 使用的镜像名

3. 镜像下载过程解析

当我们看到Docker开始下载镜像时,会显示多个层的下载进度。每个层都是镜像的一部分,采用分层存储的方式。

为什么有些层已经存在?

在下载过程中,你可能会注意到有些层显示"Already exists",这通常是因为:

  1. 本地已有相同层:如果你之前拉取过其他镜像,而这些镜像与当前镜像共享某些相同的层,那么这些层就已经存在于本地,无需重新下载。
  2. Docker的层复用机制:Docker镜像由多个只读层组成,不同的镜像可以共享相同的层。例如,很多基于Ubuntu的镜像都会共享相同的Ubuntu基础层。

下载的镜像存储在哪里?

Docker镜像默认存储在宿主机的特定目录中:

  • Linux系统/var/lib/docker
  • Windows系统(WSL2) :通常位于WSL2子系统的/var/lib/docker目录中
  • macOS :同样位于Docker虚拟机的/var/lib/docker目录

可以通过以下命令查看Docker的存储位置:

bash 复制代码
docker info | grep "Docker Root Dir"

4. 删除镜像和容器的影响

删除容器

当删除容器时,只会删除容器层(即可写层),而不会删除镜像层。这意味着:

  • 容器内的数据更改(如果不使用卷挂载)会丢失
  • 镜像本身保持不变

删除镜像

删除镜像会删除该镜像的所有层,但前提是这些层没有被其他镜像共享。如果某个层被多个镜像共享,那么删除其中一个镜像不会删除共享层。

5. 常见问题解答

Q1:为什么Docker镜像要分层存储?

A:分层存储有多个优势:

  • 节省存储空间:多个镜像可以共享相同的层
  • 加快下载速度:如果本地已有某些层,则无需重复下载
  • 提高构建效率:构建镜像时,只需要重新构建发生变化的层

Q2:如何清理不再使用的Docker资源?

A:可以使用以下命令:

bash 复制代码
# 删除所有停止的容器
docker container prune

# 删除所有未被使用的镜像
docker image prune -a

# 删除所有未被使用的卷
docker volume prune

# 删除所有未被使用的网络
docker network prune

# 一键清理所有未被使用的资源
docker system prune -a

Q3:如何查看镜像的层结构?

A:使用docker history命令可以查看镜像的层结构:

bash 复制代码
docker history localai/localai:master-aio-gpu-nvidia-cuda-12

Q4:如何备份和迁移Docker镜像?

A:可以使用docker savedocker load命令:

bash 复制代码
# 将镜像保存为tar文件
docker save -o localai.tar localai/localai:master-aio-gpu-nvidia-cuda-12

# 从tar文件加载镜像
docker load -i localai.tar

6. 总结

通过这次LocalAI的部署实践,我深刻理解了Docker的工作原理。分层存储机制让Docker在镜像管理上变得高效,但也带来了一些复杂性。掌握这些基本概念后,我们就能更好地使用Docker来部署和管理应用。

相关推荐
蒜丶2 小时前
openEuler 22.03 修改 ssh 22 端口
运维·ssh
小明_GLC2 小时前
关于在window系统安装虚拟机出现不兼容的问题:如何禁用Hyper-V
运维·安装冲突
不屈的铝合金2 小时前
MySQL 数据库服务多实例部署指南
运维·数据库·mysql·多实例部署·维度隔离
学习者0072 小时前
NE相关知识之------路由知识
运维·服务器
杨云龙UP3 小时前
SQL Server定时自动备份配置:使用SSMS维护计划向导配置数据库每日自动备份_20260101
运维·服务器·数据库·sql·sqlserver·桌面
oscar9993 小时前
CI_CD Pipeline趋势:加速集成与交付
运维·ci/cd·devops
qq_317620313 小时前
06:Docker安全加固与性能优化
docker·性能优化·权限控制·安全加固·镜像扫描
java_logo3 小时前
ComfyUI Docker 镜像部署指南
运维·docker·容器·comfyui部署·docker部署comfyui·comfyui部署文档·comfyui部署教程
天才程序YUAN3 小时前
Windows自动修改系统环境变量(PATH)中所有 D 盘路径的脚本
运维·windows