在 Amazon ECS 任务定义中指定 Docker 卷
在您的容器可以使用数据卷之前,您必须在任务定义中指定卷和挂载点配置。此部分描述容器的卷配置。对于使用 Docker 卷的任务,请指定 dockerVolumeConfiguration。对于使用绑定挂载主机卷的任务,请指定 host 和可选的 sourcePath。
以下任务定义 JSON 显示容器的 volumes 和 mountPoints 对象的语法。
{ "containerDefinitions": [ { "mountPoints": [ { "sourceVolume": "string", "containerPath": "/path/to/mount_volume", "readOnly": boolean } ] } ], "volumes": [ { "name": "string", "dockerVolumeConfiguration": { "scope": "string", "autoprovision": boolean, "driver": "string", "driverOpts": { "key": "value" }, "labels": { "key": "value" } } } ] }
name-
类型:字符串
必需:否
卷的名称。最多允许 255 个字母(大写和小写字母)、数字、连字符(
-)和下划线(_)。此名称已在容器定义mountPoints对象的sourceVolume参数中引用。 dockerVolumeConfiguration-
类型:DockerVolumeConfiguration 对象
必需:否
使用 Docker 卷时将指定此参数。只有在 EC2 实例上运行任务时,才支持 Docker 卷。Windows 容器仅支持使用
local驱动程序。要使用绑定挂载,请改为指定host。scope-
类型:字符串
有效值:
task|shared必需:否
Docker 卷的范围,可确定其生命周期。当任务开始时,将自动预配置范围限定为
task的 Docker 卷;而当任务停止时销毁此卷。任务停止后,范围限定为shared的 Docker 卷将持续存在。 autoprovision-
类型:布尔值
默认值:
false必需:否
如果此值为
true,则将创建 Docker 卷(如果此卷不存在)。仅在scope为shared时使用此字段。如果scope为task,则必须省略此参数。 driver-
类型:字符串
必需:否
要使用的 Docker 卷驱动程序。由于驱动程序值用于任务放置,因此,该名称必须与 Docker 提供的驱动程序名称匹配。如果已使用 Docker 插件 CLI 创建驱动程序,则使用
docker plugin ls可从容器实例中检索驱动程序名称。如果已使用其他方法安装驱动程序,则使用 Docker 插件发现功能可检索驱动程序名称。 driverOpts-
类型:字符串
必需:否
要传递的 Docker 驱动程序特定的选项的映射。此参数将映射到 Docker 中“创建卷”部分中的
DriverOpts。 labels-
类型:字符串
必需:否
要添加到 Docker 卷的自定义元数据。
mountPoints-
类型:对象数组
必需:否
容器中数据卷的挂载点。此参数对应于 create-container Docker API 中的
Volumes和 docker run 命令的--volume选项。Windows 容器可在
$env:ProgramData所在的驱动器上挂载整个目录。Windows 容器无法在其他驱动器上挂载目录,并且挂载点不能跨驱动器使用。您必须指定挂载点才能将 Amazon EBS 卷直接附加到 Amazon ECS 任务。sourceVolume-
类型:字符串
必需:是,当使用
mountPoints时要挂载的卷的名称。
containerPath-
类型:字符串
必需:是,当使用
mountPoints时挂载卷的容器中的路径。
readOnly-
类型:布尔值
必需:否
如果此值为
true,则容器具有对卷的只读访问权。如果此值为false,则容器可对卷进行写入。默认值为false。对于在运行 Windows 操作系统的 EC2 实例上运行的任务,请保留默认值
false。