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)/相对路径或绝对路径,容器内路径不重复,提前创建本地目录并赋权。
相关推荐
实心儿儿2 小时前
Linux —— 进程概念 - 初识进程
linux·运维·服务器
数通工程师2 小时前
实操教程:华为防火墙HRP主备模式完整配置步骤
运维·服务器·网络·网络协议·tcp/ip·华为
航Hang*2 小时前
计算机等级考试(三级Linux技术)--- 考纲与知识点
linux·运维·服务器·计算机三级·计算机等级考试
txinyu的博客2 小时前
虚拟内存
linux·运维·服务器
楼田莉子2 小时前
Linux进程间通信——管道
linux·运维·服务器·c++·学习
gettingolder2 小时前
haproxy的简单负载均衡实现
运维·服务器·负载均衡
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.2 小时前
HAPROXY安装,双网卡负载均衡实战指南
运维·负载均衡
礼拜天没时间.3 小时前
《Docker实战入门与部署指南:从核心概念到网络与数据管理》:初识Docker——概念与优势
linux·运维·网络·docker·容器·centos
雅菲奥朗3 小时前
工信部教考中心《系统可靠性工程师(高级)》开课通知
运维·sre