Docker run 挂载本地两个目录到容器内的写法(核心规则+实操示例)

Docker run 挂载本地两个目录到容器内的写法(核心规则+实操示例)

docker run 挂载多个本地目录/文件 到容器内的核心规则 是:多次使用 -v 参数每个 -v 对应一组「本地路径:容器内路径」的映射关系,参数顺序无要求,可根据需求任意排列,适配所有Docker镜像(含你的Label Studio)。

一、通用标准写法(核心格式)

bash 复制代码
docker run [其他参数(-d/-p/--name等)] \
  -v 本地目录1的路径:容器内目标目录1的路径 \
  -v 本地目录2的路径:容器内目标目录2的路径 \
  镜像名:标签
关键说明:
  1. 每个 -v 独立配置一个挂载关系,无数量限制(可挂载2个、3个及以上);
  2. 本地路径支持相对路径$(pwd)/xxx,推荐,代表当前终端目录下的xxx)和绝对路径/root/xxx);
  3. 容器内路径需写绝对路径,且建议和程序实际需要的路径一致(如Label Studio的固定路径);
  4. \ 是换行符,仅为命令可读性,也可将所有参数写在一行(无\)。

二、贴合你的需求:Label Studio 挂载两个本地目录实操示例

结合你一直操作的Label Studio容器 ,以「本地mydata/db挂载到容器数据库目录、本地mydata/annotations挂载到容器标注数据目录」为例(按需自定义本地/容器路径),搭配后台运行、端口映射、容器命名等常用参数,命令可直接复制执行

bash 复制代码
# 推荐:换行写法(可读性高,易修改)
docker run -d -p 8080:8080 --name label-studio \
  -v $(pwd)/mydata/db:/label-studio  \ # 本地数据库目录 → 容器数据库根目录(含label_studio.sqlite3)
  -v $(pwd)/mydata/annotations:/label-studio/data \ # 本地标注目录 → 容器标注数据目录
  heartexlabs/label-studio:latest

# 简洁:单行写法(无换行符,直接执行)
docker run -d -p 8080:8080 --name label-studio -v $(pwd)/mydata/db:/label-studio -v $(pwd)/mydata/annotations:/label-studio/data heartexlabs/label-studio:latest
该命令实现:
  1. 本地当前目录/mydata/db → 容器/label-studio(存放数据库文件label_studio.sqlite3);
  2. 本地当前目录/mydata/annotations → 容器/label-studio/data(存放标注项目、数据集、标注记录);
  3. 两个目录的数据各自独立持久化,容器内修改会实时同步到本地对应目录。

三、通用场景示例(非Label Studio,快速参考)

若为普通镜像,需挂载本地/opt/logs(日志)和/opt/config(配置)到容器/app/logs/app/config,命令如下:

bash 复制代码
docker run -d --name my-app \
  -v /opt/logs:/app/logs \ # 本地绝对路径1 → 容器路径1
  -v /opt/config:/app/config \ # 本地绝对路径2 → 容器路径2
  my-image:latest

四、挂载两个目录的关键注意事项(避坑)

  1. 本地目录自动创建 :若本地指定的目录不存在(如$(pwd)/mydata/db),Docker会自动创建该目录 ,但可能导致权限问题,建议提前手动创建并赋权:

    bash 复制代码
    mkdir -p $(pwd)/mydata/db $(pwd)/mydata/annotations && chmod -R 777 $(pwd)/mydata
  2. 路径分隔符 :Linux系统中本地和容器路径均使用正斜杠 / ,切勿用反斜杠 \

  3. 容器内路径唯一性 :两个挂载的容器内路径不能重复,否则会相互覆盖,导致数据异常;

  4. 相对路径必带 $(pwd) :本地相对路径需以$(pwd)/开头(代表当前目录),直接写mydata/db会识别失败;

  5. 支持混合挂载-v 可同时混合挂载目录单个文件 (如同时挂载目录+数据库文件),规则不变:

    bash 复制代码
    # 示例:挂载目录+单个文件(Label Studio场景)
    docker run -d -p 8080:8080 --name label-studio \
      -v $(pwd)/mydata/annotations:/label-studio/data \ # 挂载目录
      -v $(pwd)/mydata/label_studio.sqlite3:/label-studio/label_studio.sqlite3 \ # 挂载单个文件
      heartexlabs/label-studio:latest

五、验证挂载是否成功(快速检查)

容器启动后,执行以下命令查看容器内的挂载关系,确认两个本地目录均已成功映射:

bash 复制代码
# 查看容器的挂载详情(替换为你的容器名/ID)
docker inspect label-studio | grep -A 10 "Mounts"
正常输出示例(包含两个挂载记录):
json 复制代码
"Mounts": [
    {
        "Type": "bind",
        "Source": "/root/mydata/db", # 本地实际路径
        "Destination": "/label-studio", # 容器内路径
        "Mode": "",
        "RW": true,
        "Propagation": "rprivate"
    },
    {
        "Type": "bind",
        "Source": "/root/mydata/annotations", # 本地实际路径
        "Destination": "/label-studio/data", # 容器内路径
        "Mode": "",
        "RW": true,
        "Propagation": "rprivate"
    }
],

输出中能看到两个Source(本地)和Destination(容器)的对应关系,即表示挂载成功。

核心总结

  1. 多目录挂载核心:多次使用 -v 参数 ,一个-v对应一组本地-容器路径映射;
  2. 标准格式:-v 本地路径:容器路径 -v 本地路径2:容器路径2,换行/单行均可;
  3. Label Studio适配:结合容器固定路径/label-studio(数据库)和/label-studio/data(标注数据)挂载,数据可持久化;
  4. 避坑关键:本地路径用$(pwd)/相对路径或绝对路径,容器内路径不重复,提前创建本地目录并赋权。
相关推荐
China_Yanhy10 分钟前
入职 Web3 运维日记 · 第 8 日:黑暗森林 —— 对抗 MEV 机器人的“三明治攻击”
运维·机器人·web3
艾莉丝努力练剑17 分钟前
hixl vs NCCL:昇腾生态通信库的独特优势分析
运维·c++·人工智能·cann
酉鬼女又兒24 分钟前
每天一个Linux命令_printf
linux·运维·服务器
虾说羊29 分钟前
docker容器化部署项目流程
运维·docker·容器
Trouvaille ~30 分钟前
TCP Socket编程实战(三):线程池优化与TCP编程最佳实践
linux·运维·服务器·网络·c++·网络协议·tcp/ip
大大大反派33 分钟前
CANN 生态中的自动化部署引擎:深入 `mindx-sdk` 项目构建端到端 AI 应用
运维·人工智能·自动化
WHD3061 小时前
苏州勒索病毒加密 服务器数据解密恢复
运维·服务器
骇客野人1 小时前
通过脚本推送Docker镜像
java·docker·容器
蜡笔小炘1 小时前
LVS -- 持久链接(Persistent Connection)实现会话粘滞
运维·服务器
liux35282 小时前
基于kubeadm部署Kubernetes 1.26.4 集群指南
云原生·容器·kubernetes