Docker:更改存储 docker 卷的文件夹
Docker: change folder where to store docker volumes
在我的 Ubuntu EC2
上,我托管了一个使用 docker 容器的应用程序。 db
数据和 upload
数据存储在使用以下命令创建的卷 CaseBook-data-db
和 CaseBook-data-uploads
中:
docker volume create --name=CaseBook-data-db
docker volume create --name=CaseBook-data-uploads
通过 docker-compose
文件附加的卷:
version: '2'
services:
mongo:
container_name: "CaseBook-db"
restart: always
image: mongo:3.2.7
ports:
- "27017"
volumes:
- data_db:/data/db
labels:
- "ENVIRONMENT_TYPE=meteor"
app:
container_name: "CaseBook-app"
restart: always
image: "meteor/casebook"
build: .
depends_on:
- mongo
environment:
- MONGO_URL=mongodb://mongo:27017/CaseBook
ports:
- "80:3000"
volumes:
- data_uploads:/Meteor-CaseBook-Container/.uploads
labels:
- "ENVIRONMENT_TYPE=meteor"
volumes:
data_db:
external:
name: CaseBook-data-db
data_uploads:
external:
name: CaseBook-data-uploads
我需要将那些 docker 卷存储在主机的不同文件夹(例如 /home/ubuntu/data/
)中。如何更改 docker 卷的存储文件夹?或者有更好的方法吗?提前谢谢你。
命名卷将存储在 docker 的文件夹 (/var/lib/docker) 中。如果要在特定主机文件夹中创建卷,请使用具有以下语法的主机卷:
docker run -v /home/ubuntu/data/app-data:/app-data my-image
或来自您的撰写文件:
version: '2'
services:
mongo:
container_name: "CaseBook-db"
restart: always
image: mongo:3.2.7
ports:
- "27017"
volumes:
- /home/ubuntu/data/db:/data/db
labels:
- "ENVIRONMENT_TYPE=meteor"
app:
container_name: "CaseBook-app"
restart: always
image: "meteor/casebook"
build: .
depends_on:
- mongo
environment:
- MONGO_URL=mongodb://mongo:27017/CaseBook
ports:
- "80:3000"
volumes:
- /home/ubuntu/data/uploads:/Meteor-CaseBook-Container/.uploads
labels:
- "ENVIRONMENT_TYPE=meteor"
对于主机卷,映像中卷的任何内容都将被主机文件夹的确切内容覆盖,包括主机文件夹的 UID。空主机文件夹不会像空命名卷那样从映像中初始化。 UID 映射往往是使用主机卷最困难的部分。
编辑:从下面的评论中,如果您需要一个命名卷作为主机卷,有一个 local persist volume plugin that's listed on docker's plugin list。安装插件后,您可以创建指向主机文件夹的卷,其特点是即使在删除命名卷后,主机目录仍然存在。插件的示例用法包括:
docker volume create -d local-persist -o mountpoint=/data/images --name=images
docker run -d -v images:/path/to/images/on/one/ one
docker run -d -v images:/path/to/images/on/two/ two
它们还包含一个 v2 组合文件,示例如下:
volumes:
data:
driver: local-persist
driver_opts:
mountpoint: /data/local-persist/data
我在过去一个月中了解到的一个附加选项是使用本地卷驱动程序的安装选项来手动创建绑定安装。这类似于 docker 中的主机卷,但有以下区别:
- 如果该目录不存在,尝试使用指向绑定安装的命名卷启动容器将失败。对于主机卷,docker 会将其初始化为 root 拥有的空目录。
- 如果目录为空,命名卷将使用挂载位置的映像内容初始化绑定挂载,包括文件和目录 ownership/permissions。对于主机卷,主机目录内容没有初始化。
要创建命名卷作为绑定安装,您可以提前创建它:
docker volume create --driver local \
--opt type=none \
--opt device=/home/user/test \
--opt o=bind \
test_vol
从 docker run
命令,这可以通过 --mount
:
完成
docker run -it --rm \
--mount type=volume,dst=/container/path,volume-driver=local,volume-opt=type=none,volume-opt=o=bind,volume-opt=device=/home/user/test \
foo
或者在撰写文件中,您可以创建命名卷:
volumes:
data:
driver: local
driver_opts:
type: none
o: bind
device: /home/user/test
如果您需要命名卷功能,我的偏好是将命名卷与本地驱动程序一起使用,而不是使用 local-persist 第三方驱动程序。
内置驱动程序本地的另一种方式:
docker volume create --opt type=none --opt device=/home/ubuntu/data/ --opt o=bind data_db
(此使用 DimonVersace 示例:data_db 在 docker-compose 和 [=23= 中声明为外部命名卷]/ 作为主机上的文件夹)
在我的 Ubuntu EC2
上,我托管了一个使用 docker 容器的应用程序。 db
数据和 upload
数据存储在使用以下命令创建的卷 CaseBook-data-db
和 CaseBook-data-uploads
中:
docker volume create --name=CaseBook-data-db
docker volume create --name=CaseBook-data-uploads
通过 docker-compose
文件附加的卷:
version: '2'
services:
mongo:
container_name: "CaseBook-db"
restart: always
image: mongo:3.2.7
ports:
- "27017"
volumes:
- data_db:/data/db
labels:
- "ENVIRONMENT_TYPE=meteor"
app:
container_name: "CaseBook-app"
restart: always
image: "meteor/casebook"
build: .
depends_on:
- mongo
environment:
- MONGO_URL=mongodb://mongo:27017/CaseBook
ports:
- "80:3000"
volumes:
- data_uploads:/Meteor-CaseBook-Container/.uploads
labels:
- "ENVIRONMENT_TYPE=meteor"
volumes:
data_db:
external:
name: CaseBook-data-db
data_uploads:
external:
name: CaseBook-data-uploads
我需要将那些 docker 卷存储在主机的不同文件夹(例如 /home/ubuntu/data/
)中。如何更改 docker 卷的存储文件夹?或者有更好的方法吗?提前谢谢你。
命名卷将存储在 docker 的文件夹 (/var/lib/docker) 中。如果要在特定主机文件夹中创建卷,请使用具有以下语法的主机卷:
docker run -v /home/ubuntu/data/app-data:/app-data my-image
或来自您的撰写文件:
version: '2'
services:
mongo:
container_name: "CaseBook-db"
restart: always
image: mongo:3.2.7
ports:
- "27017"
volumes:
- /home/ubuntu/data/db:/data/db
labels:
- "ENVIRONMENT_TYPE=meteor"
app:
container_name: "CaseBook-app"
restart: always
image: "meteor/casebook"
build: .
depends_on:
- mongo
environment:
- MONGO_URL=mongodb://mongo:27017/CaseBook
ports:
- "80:3000"
volumes:
- /home/ubuntu/data/uploads:/Meteor-CaseBook-Container/.uploads
labels:
- "ENVIRONMENT_TYPE=meteor"
对于主机卷,映像中卷的任何内容都将被主机文件夹的确切内容覆盖,包括主机文件夹的 UID。空主机文件夹不会像空命名卷那样从映像中初始化。 UID 映射往往是使用主机卷最困难的部分。
编辑:从下面的评论中,如果您需要一个命名卷作为主机卷,有一个 local persist volume plugin that's listed on docker's plugin list。安装插件后,您可以创建指向主机文件夹的卷,其特点是即使在删除命名卷后,主机目录仍然存在。插件的示例用法包括:
docker volume create -d local-persist -o mountpoint=/data/images --name=images
docker run -d -v images:/path/to/images/on/one/ one
docker run -d -v images:/path/to/images/on/two/ two
它们还包含一个 v2 组合文件,示例如下:
volumes:
data:
driver: local-persist
driver_opts:
mountpoint: /data/local-persist/data
我在过去一个月中了解到的一个附加选项是使用本地卷驱动程序的安装选项来手动创建绑定安装。这类似于 docker 中的主机卷,但有以下区别:
- 如果该目录不存在,尝试使用指向绑定安装的命名卷启动容器将失败。对于主机卷,docker 会将其初始化为 root 拥有的空目录。
- 如果目录为空,命名卷将使用挂载位置的映像内容初始化绑定挂载,包括文件和目录 ownership/permissions。对于主机卷,主机目录内容没有初始化。
要创建命名卷作为绑定安装,您可以提前创建它:
docker volume create --driver local \
--opt type=none \
--opt device=/home/user/test \
--opt o=bind \
test_vol
从 docker run
命令,这可以通过 --mount
:
docker run -it --rm \
--mount type=volume,dst=/container/path,volume-driver=local,volume-opt=type=none,volume-opt=o=bind,volume-opt=device=/home/user/test \
foo
或者在撰写文件中,您可以创建命名卷:
volumes:
data:
driver: local
driver_opts:
type: none
o: bind
device: /home/user/test
如果您需要命名卷功能,我的偏好是将命名卷与本地驱动程序一起使用,而不是使用 local-persist 第三方驱动程序。
内置驱动程序本地的另一种方式:
docker volume create --opt type=none --opt device=/home/ubuntu/data/ --opt o=bind data_db
(此使用 DimonVersace 示例:data_db 在 docker-compose 和 [=23= 中声明为外部命名卷]/ 作为主机上的文件夹)