찾다
운영 및 유지보수Docker도커 저장 방법은 무엇입니까?

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으로 문의하세요.
Docker 마스터 링 : Linux 사용자를위한 안내서Docker 마스터 링 : Linux 사용자를위한 안내서Apr 18, 2025 am 12:08 AM

Linux에서 Docker를 사용하면 개발 효율성을 향상시키고 응용 프로그램 배포를 단순화 할 수 있습니다. 1) Ubuntu 이미지를 당기기 : Dockerpullubuntu. 2) 우분투 컨테이너 실행 : Dockerrun-itubuntu/bin/bash. 3) nginx를 포함하는 dockerfile : fromubuntu; runapt-getupdate && apt-getinstall-ynginx; Expose80을 만듭니다. 4) 이미지를 빌드 : DockerBuild-tmy-nginx. 5) 컨테이너 실행 : Dockerrun-D-P8080 : 80

Linux의 Docker : 응용 프로그램 및 사용 사례Linux의 Docker : 응용 프로그램 및 사용 사례Apr 17, 2025 am 12:10 AM

Docker는 Linux의 응용 프로그램 배포 및 관리를 단순화합니다. 1) Docker는 응용 프로그램과 그 종속성을 경량 및 휴대용 컨테이너로 포장하는 컨테이너화 된 플랫폼입니다. 2) Linux에서 Docker는 CGroup 및 네임 스페이스를 사용하여 컨테이너 격리 및 리소스 관리를 구현합니다. 3) 기본 사용에는 이미지를 당기고 컨테이너를 실행하는 것이 포함됩니다. DockerCompose와 같은 고급 사용법은 다중 컨테이너 응용 프로그램을 정의 할 수 있습니다. 4) 일반적으로 사용되는 DockerLogs 및 DockerExec 명령 디버그. 5) 성능 최적화는 다단계 구성을 통해 이미지 크기를 줄일 수 있으며 Dockerfile을 단순하게 유지하는 것이 가장 좋은 방법입니다.

Docker : 이식성 및 확장 성을위한 컨테이너화 응용 프로그램Docker : 이식성 및 확장 성을위한 컨테이너화 응용 프로그램Apr 16, 2025 am 12:09 AM

Docker는 응용 프로그램을 패키지, 배포 및 실행하는 데 사용되는 Linux 컨테이너 기술 기반 도구입니다. 1) DockerBuild 및 Dockerrun 명령을 사용하여 Docker 컨테이너를 구축하고 실행할 수 있습니다. 2) DockerCompose는 마이크로 서비스 관리를 단순화하기 위해 멀티 컨테이너 Docker 응용 프로그램을 정의하고 실행하는 데 사용됩니다. 3) 다단계 구성을 사용하면 이미지 크기를 최적화하고 응용 프로그램 시작 속도를 향상시킬 수 있습니다. 4) 컨테이너 로그보기는 컨테이너 문제를 디버깅하는 효과적인 방법입니다.

Docker가 컨테이너를 시작하는 방법Docker가 컨테이너를 시작하는 방법Apr 15, 2025 pm 12:27 PM

Docker Container Startup 단계 : 컨테이너 이미지를 당기기 : "Docker Pull [Mirror Name]"을 실행하십시오. 컨테이너 생성 : "docker"[옵션] [미러 이름] [명령 및 매개 변수]를 사용하십시오. 컨테이너를 시작하십시오 : "Docker start [컨테이너 이름 또는 ID]"를 실행하십시오. 컨테이너 상태 확인 : 컨테이너가 "Docker PS"로 실행 중인지 확인하십시오.

Docker에서 로그를 보는 방법Docker에서 로그를 보는 방법Apr 15, 2025 pm 12:24 PM

Docker Logs를 보는 방법에는 다음이 포함됩니다. Docker Logs 명령 사용 : Docker Logs Container_name Docker Exec 명령을 사용하여 RUN /BIN /SH를 사용하여 로그 파일을 봅니다. cat /var/log/container_name.log docker-compose logs docker compose의 명령 : docker-compose -f docker-com 사용

Docker 컨테이너의 이름을 확인하는 방법Docker 컨테이너의 이름을 확인하는 방법Apr 15, 2025 pm 12:21 PM

단계를 따르면 Docker 컨테이너 이름을 쿼리 할 수 ​​있습니다. 모든 컨테이너 (Docker PS)를 나열하십시오. 컨테이너 목록을 필터링합니다 (GREP 명령 사용). 컨테이너 이름 ( "이름"열에 위치)을 가져옵니다.

Docker 용 컨테이너를 만드는 방법Docker 용 컨테이너를 만드는 방법Apr 15, 2025 pm 12:18 PM

Docker에서 컨테이너 만들기 : 1. 이미지를 당기기 : Docker Pull [Mirror Name] 2. 컨테이너 만들기 : Docker Run [옵션] [미러 이름] [명령] 3. 컨테이너 시작 : Docker Start [컨테이너 이름]

Docker가 컨테이너를 빠져 나가는 방법Docker가 컨테이너를 빠져 나가는 방법Apr 15, 2025 pm 12:15 PM

도커 컨테이너를 종료하는 4 가지 명령 사용 Docker Kill & lt; Container_name & gt; 호스트 터미널의 명령 (힘 출구)

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.