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)/相对路径或绝对路径,容器内路径不重复,提前创建本地目录并赋权。
相关推荐
w6100104661 天前
CKAD-2026-Ingress
运维·k8s·ckad
zzzsde1 天前
【Linux】库的制作和使用(3)ELF&&动态链接
linux·运维·服务器
CQU_JIAKE1 天前
4.3【A]
linux·运维·服务器
AI周红伟1 天前
OpenClaw是什么?OpenClaw能做什么?OpenClaw详细介绍及保姆级部署教程-周红伟
大数据·运维·服务器·人工智能·微信·openclaw
Elastic 中国社区官方博客1 天前
当 TSDS 遇到 ILM:设计不会拒绝延迟数据的时间序列数据流
大数据·运维·数据库·elasticsearch·搜索引擎·logstash
qing222222221 天前
Linux中修改mysql数据表
linux·运维·mysql
杨云龙UP1 天前
Oracle 中 NOMOUNT、MOUNT、OPEN 怎么理解? 在不同场景下如何操作?_20260402
linux·运维·数据库·oracle
Amctwd1 天前
【Linux】OpenCode 安装教程
linux·运维·服务器
和小潘一起学AI1 天前
SHH隧道内网穿透
运维·服务器
wwj888wwj1 天前
Docker基础(复习)
java·linux·运维·docker