>  기사  >  운영 및 유지보수  >  도커 저장 방법은 무엇입니까?

도커 저장 방법은 무엇입니까?

青灯夜游
青灯夜游원래의
2022-02-08 16:55:477237검색

Docker에는 네 가지 저장 방법이 있습니다. 1. "기본 저장소", 컨테이너가 삭제된 후 데이터도 삭제됩니다. 2. "볼륨 데이터 볼륨" 3. "바인딩 마운트" " , 호스트 파일 시스템의 디렉터리나 파일을 직접 마운트합니다. 4. "tmpfs 마운트".

도커 저장 방법은 무엇입니까?

이 튜토리얼의 운영 환경: linux5.9.8 시스템, docker-1.13.1 버전, Dell G3 컴퓨터.

Docker 컨테이너의 여러 저장 방법

컨테이너 저장소는 크게 두 가지 범주로 나눌 수 있습니다.

하나는 이미지와 관련이 있는데, 이는 "Docker 컨테이너 기술의 기초 - 공동 파일"에서 논의한 내용입니다. 시스템 오버레이FS" 문서에 언급된 컨테이너 레이어 쓰기 시 복사 기능입니다. 기본적으로 컨테이너 내에서 생성된 모든 파일은 쓰기 가능한 컨테이너 계층에 저장됩니다. 컨테이너 계층에 파일을 직접 저장하는 이 방법은 스토리지 드라이버에 대한 의존성과 호스트에 대한 직접 쓰기 사용으로 인해 데이터를 유지하고 공유하기가 어렵습니다. 파일 시스템. 이 추가 추상화는 데이터 볼륨에 비해 성능을 저하시킵니다.

다른 하나는 호스트 디렉터리를 컨테이너에 바인딩하거나 매달아 사용하는 호스트 스토리지입니다. 컨테이너가 중지된 후에도 데이터가 지속될 수 있습니다. 후자를 주로 소개한다.

다양한 저장소 장착 방법

여기에서는 Docker 호스트에서 데이터가 저장되는 다양한 위치를 기반으로 다음 다이어그램을 그립니다.

도커 저장 방법은 무엇입니까?

Docker에는 기본, 볼륨 데이터 볼륨, 바인드 마운트의 네 가지 저장 방법이 있습니다. 마운트, tmpfs 마운트(Linux 환경에서만 사용 가능), 그 중 볼륨 및 바인드 마운트는 영구 컨테이너 데이터를 구현합니다.

1. 기본 저장소

데이터는 실행 중인 컨테이너에 저장됩니다. 컨테이너가 삭제되면 데이터도 삭제됩니다.

2.bind mounts

볼륨에 비해 바인딩 마운트는 기능이 제한됩니다. 바인드 마운트를 사용하면 호스트의 파일이나 디렉터리가 컨테이너에 마운트됩니다. 파일 또는 디렉터리는 호스트의 전체 경로로 참조됩니다. 디렉터리가 Docker 호스트에 이미 존재할 필요는 없습니다. 존재하지 않는 경우 Docker가 디렉터리를 생성합니다. 디렉토리만 자동으로 생성될 수 있습니다.

-v 옵션을 통해 /nginx/html 디렉터리 마운트를 바인드하고 컨테이너를 살펴봅니다.

docker run -dt -v /nginx/html:/usr/share/nginx/html --name nginx nginx

docker Inspection nginx

"Mounts": [
    {
        "Type": "bind",
        "Source": "/nginx/html",
        "Destination": "/usr/share/nginx/html",
        "Mode": "",
        "RW": true,
        "Propagation": "rprivate"
    }
],

를 통해 컨테이너 마운트 필드를 확인합니다. 그런 다음 Docker 호스트에서 index.html을 생성하고 hello nginx라고 쓰고 컨테이너 IP에 액세스하면 분명히 마운트가 적용됩니다.

[root@localhost ~]# echo "hello nginx" >  /nginx/html/index.html
[root@localhost ~]# curl 172.17.0.4
hello nginx

여기에 문제가 있습니다. 컨테이너의 파일을 유효하게 만들기 위해 Docker 호스트를 통해 파일을 수정할 수 있습니다. 컨테이너는 호스트 파일 시스템의 내용을 수정, 생성 및 삭제할 수 있습니다. 이 문제를 해결하기 위해 컨테이너를 생성할 때 다음과 같은 읽기 전용 권한과 같이 마운트 디렉터리의 권한을 구성할 수 있습니다. 다음 :

다른 응용 프로그램에 영향을 주지 않도록 마운트한 디렉터리에는 어떤 콘텐츠가 포함되어 있나요?

컨테이너가 이러한 디렉터리를 작동할 수 있는 권한을 가져야 하는지 여부입니다.

3.volumes 데이터 볼륨

볼륨 스토리지 볼륨은 Docker에 의해 생성 및 관리됩니다. docker Volume create 명령을 사용하여 명시적으로 볼륨을 생성하거나 컨테이너가 생성될 때 볼륨을 생성할 수 있습니다.

docker run -dt -v /nginx/html:/usr/share/nginx/html:ro --name nginx nginx

마운트 지점이 docker /var/lib/docker/volumes

docker 볼륨 rm/prune을 사용하여 단일 또는 모든 사용되지 않은 볼륨을 지우는 데 docker 명령을 사용하여 관리할 수 있습니다. 볼륨 비교 바인드 마운트의 장점 중 하나입니다.

[root@localhost ~]# docker volume create nginx_volume
nginx_volume
[root@localhost volumes]# docker inspect  nginx_volume
[
    {
        "CreatedAt": "2021-08-12T01:58:04-04:00",
        "Driver": "local",
        "Labels": {},
        "Mountpoint": "/var/lib/docker/volumes/nginx_volume/_data",
        "Name": "nginx_volume",
        "Options": {},
        "Scope": "local"
    }
]

컨테이너를 생성할 때 컨테이너 마운트 소스를 지정하지 않으면 docker는 자동으로 익명 볼륨을 생성합니다. 이 볼륨은 역시 docker 루트 디렉터리에 있습니다.

[root@localhost ~]# docker volume ls
DRIVER    VOLUME NAME
local     owncloud-docker-server_files
local     owncloud-docker-server_mysql
local     owncloud-docker-server_redis
[root@localhost ~]# docker volume prune
WARNING! This will remove all local volumes not used by at least one container.
Are you sure you want to continue? [y/N] y
Deleted Volumes:
owncloud-docker-server_files
owncloud-docker-server_mysql
owncloud-docker-server_redis

Total reclaimed space: 199.4MB

마운트 볼륨을 생성한 후 이때의 스토리지는 바인드 마운트와 일치합니다. 그러나 도커 호스트가 특정 디렉터리나 파일 구조를 보장할 수 없는 경우 볼륨은 도커 호스트의 구성을 컨테이너 런타임 분리. 이러한 방식으로 한 Docker 호스트에서 다른 Docker 호스트로 데이터를 백업, 복원 또는 마이그레이션해야 할 때 볼륨이 매우 편리하고 호스트 경로의 제한에서 벗어날 수 있습니다.

바인드 마운트 및 볼륨을 사용하는 경우 다음 전파 적용 범위 원칙에 주의해야 합니다.

도커 저장 방법은 무엇입니까?빈 볼륨을 마운트하는 경우: 컨테이너에 있는 디렉터리의 내용이 볼륨에 전파(복사)됩니다.

마운트된 볼륨 또는 비어 있지 않은 볼륨을 바인딩하는 경우: 볼륨 또는 바인딩된 호스트 디렉터리가 컨테이너에 있는 디렉터리의 내용을 덮어씁니다.

4.tmpfs 마운트

tmpfs 마운트는 Linux 호스트에서만 사용할 수 있습니다. tmpfs 마운트를 사용하여 컨테이너를 생성하면 컨테이너는 컨테이너의 쓰기 가능한 레이어 외부에 파일을 생성할 수 있습니다. 데이터를 메모리에 보관하고 컨테이너가 중지되면 작성된 데이터도 제거됩니다. 호스트 또는 컨테이너 쓰기 가능 계층에 남아 있기를 원하지 않는 민감한 파일의 임시 저장에 주로 사용됩니다.

--tmpfs 옵션을 통해 메모리 블록을 마운트하세요.

[root@localhost volumes]# docker run -dt -v /usr/share/nginx/html --name nginx_with_volume nginx
d25bdfce9c7ac7bde5ae35067f6d9cf9f0cd2c9cbea6d1bbd7127b3949ef5ac6
[root@localhost volumes]# docker volume ls 
DRIVER    VOLUME NAME
local     d8e943f57d17a255f8a4ac3ecbd6471a735aa64cc7a606c52f61319a6c754980
local     nginx_volume
[root@localhost volumes]# ls /var/lib/docker/volumes/
backingFsBlockDev  d8e943f57d17a255f8a4ac3ecbd6471a735aa64cc7a606c52f61319a6c754980  metadata.db  nginx_volume

임시 저장 크기를 지정하려면 --mount 메소드를 통해 매개변수를 입력하세요.

docker run -dt --name busybox_tmpfs --tmpfs /etc/running busybox

스토리지 데이터 공유

在容器之间共享数据主要有两种方法,第一种比较简单,只需要将目录或者volume挂载到多个容器中即可。这里不做赘述,我们来看一下通过中间容器实现共享的方式。

我们创建一个中间容器,包含绑定挂载目录和一个卷。

docker create -v /share:/volume1 -v /volume2  --name volume_share  busybox

在我们需要共享的容器中通过选项--volumes-from拿过来用即可

docker run -d -t --volumes-from volume_share  --name container1  busybox

我们inspect检查一下Mounts字段,此时container1已经挂载到了一个bind目录和一个volume

"Mounts": [
    {
        "Type": "bind",
        "Source": "/share",
        "Destination": "/volume1",
        "Mode": "",
        "RW": true,
        "Propagation": "rprivate"
    },
    {
        "Type": "volume",
        "Name": "21605e49a0ba90a1b952a32c1b3f0d42735da8bfe718f0dc76c37e91f1e51c0e",
        "Source": "/var/lib/docker/volumes/21605e49a0ba90a1b952a32c1b3f0d42735da8bfe718f0dc76c37e91f1e51c0e/_data",
        "Destination": "/volume2",
        "Driver": "local",
        "Mode": "",
        "RW": true,
        "Propagation": ""
    }
],

推荐学习:《docker视频教程

위 내용은 도커 저장 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.