Docker가 호스트 DNS와 통신할 수 없는 문제를 해결하는 방법
Docker가 호스트 DNS와 작동하지 않는 솔루션
Docker는 이식 가능하고 확장 가능한 컨테이너화 환경을 제공하는 널리 사용되는 애플리케이션 컨테이너화 플랫폼입니다. 그러나 Docker를 호스트 DNS와 함께 사용할 때 도메인 이름을 확인할 수 없거나 대기 시간이 길어지는 등 다양한 문제가 발생하는 경우가 있습니다. 이 기사에서는 Docker를 호스트 DNS와 함께 사용할 수 없는 이유와 솔루션을 소개합니다.
Reason
Docker는 Cgroup 및 Namespace와 같은 기술을 사용하여 컨테이너의 호스트와 완전히 격리된 환경을 제공합니다. 이 격리 환경은 컨테이너를 보호하지만 컨테이너가 호스트의 DNS 서버를 통해 통신하는 것을 방지합니다. 따라서 컨테이너 내부의 도메인 이름 확인에 호스트 DNS 서비스를 사용할 수 없습니다.
해결 방법
Docker를 호스트 DNS와 함께 사용할 수 없는 문제를 해결하려면 다음 조치를 취할 수 있습니다.
1. Docker 컨테이너에 사용자 지정 DNS 서버를 설정합니다
사용자 지정 DNS 서버를 설정할 수 있습니다. Docker에서 기본 DNS 서버를 대체합니다. Dockerfile에서 다음 명령을 사용하여 맞춤 DNS 서버를 설정할 수 있습니다.
RUN echo "nameserver 8.8.8.8" >> /etc/resolv.conf
그러면 Google의 공개 DNS 서버 8.8.8.8이 컨테이너의 /etc/resolv.conf 파일에 추가됩니다. 여러 개의 네임서버를 추가하여 여러 개의 DNS 서버를 설정할 수 있습니다.
2. 호스트에 Docker의 DNS 서버 설정
컨테이너가 호스트를 통해 도메인 이름 확인을 수행할 수 있도록 호스트에 Docker의 DNS 서버를 설정할 수 있습니다. /etc/docker/daemon.json 파일에 다음 구성을 추가하여 Docker DNS 서버를 설정할 수 있습니다.
{ "dns": ["8.8.8.8", "8.8.4.4"] }
그러면 Google의 공개 DNS 서버 8.8.8.8 및 8.8.4.4가 Docker DNS 서버에 추가됩니다. 여러 개의 DNS 서버를 추가하여 여러 개의 DNS 서버를 설정할 수 있습니다.
3. Docker 컨테이너의 --dns 옵션을 사용하세요.
Docker 컨테이너를 시작할 때 --dns 옵션을 사용하여 컨테이너의 DNS 서버를 설정할 수 있습니다. 예:
docker run --dns 8.8.8.8 -it ubuntu:latest
이렇게 하면 Google의 공개 DNS 서버 8.8.8.8이 컨테이너의 DNS 서버로 설정됩니다.
요약
Docker는 컨테이너에 격리된 환경을 제공하기 위해 일부 기술을 사용하므로 호스트 DNS와 함께 사용할 수 없습니다. 이 문제를 해결하려면 Docker 컨테이너에 사용자 지정 DNS 서버를 설정하거나, 호스트에 Docker의 DNS 서버를 설정하거나, Docker 컨테이너의 --dns 옵션을 사용하여 컨테이너의 DNS 서버를 설정할 수 있습니다. 이러한 솔루션을 통해 Docker는 호스트 DNS와 함께 작동할 수 있으므로 Docker 컨테이너화 플랫폼을 더 잘 사용할 수 있습니다.
위 내용은 Docker가 호스트 DNS와 통신할 수 없는 문제를 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Docker는 DevOps 엔지니어에게 필수 기술입니다. 1. Docker는 포장 애플리케이션 및 컨테이너에 대한 종속성을 통해 격리 및 휴대 성을 달성하는 오픈 소스 컨테이너화 플랫폼입니다. 2. Docker는 네임 스페이스, 제어 그룹 및 연합 파일 시스템과 함께 작동합니다. 3. 기본 사용에는 컨테이너 생성, 실행 및 관리가 포함됩니다. 4. 고급 사용법에는 DockerCompose를 사용하여 다중 컨테이너 응용 프로그램을 관리하는 것이 포함됩니다. 5. 일반적인 오류에는 컨테이너 고장, 포트 매핑 문제 및 데이터 지속성 문제가 포함됩니다. 디버깅 기술에는 로그보기, 컨테이너 입력 및 자세한 정보보기가 포함됩니다. 6. 성능 최적화 및 모범 사례에는 이미지 최적화, 리소스 제약 조건, 네트워크 최적화 및 Dockerfile 사용을위한 모범 사례가 포함됩니다.

DockErvolumes는 컨테이너가 다시 시작, 삭제 또는 마이그레이션 될 때 데이터가 안전하게 유지되도록합니다. 1. 볼륨 생성 : dockervolumecreatemydata. 2. 컨테이너를 실행하고 볼륨을 장착하십시오 : Dockerrun-it-vmydata :/app/dateubuntubash. 3. 고급 사용에는 데이터 공유 및 백업이 포함됩니다.

Docker 이미지를 업데이트하는 단계는 다음과 같습니다. 최신 이미지 태그 가져 오기 새 이미지 특정 태그의 이전 이미지 삭제 (선택 사항) 컨테이너를 다시 시작하십시오 (필요한 경우)

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

Docker의 외부 호스트에 파일을 복사하는 방법 : Docker CP 명령 사용 : Docker CP 실행 [옵션] & lt; 컨테이너 경로 & gt; & lt; 호스트 경로 & gt;. 데이터 볼륨 사용 : 호스트에서 디렉토리를 만들고 -V 매개 변수를 사용하여 양방향 파일 동기화를 달성하기 위해 컨테이너를 만들 때 컨테이너에 디렉토리를 장착하십시오.

Docker Security 향상 방법에는 다음이 포함됩니다. 1.-캡 드롭 매개 변수를 사용하여 Linux 기능을 제한, 2. 읽기 전용 컨테이너 생성, 3. Selinux 태그 설정. 이러한 전략은 취약성 노출을 줄이고 공격자 기능을 제한함으로써 컨테이너를 보호합니다.

Docker 컨테이너를 다시 시작하는 방법 : 컨테이너 ID (Docker PS)를 가져옵니다. 컨테이너 중지 (Docker Stop & lt; container_id & gt;); 컨테이너를 시작하십시오 (Docker start & lt; container_id & gt;); 재시작이 성공했는지 확인하십시오 (Docker PS). 기타 방법 : Docker Compose (Docker-Compose Restart) 또는 Docker API (Docker 문서 참조).

Docker Desktop을 사용하는 방법? Docker Desktop은 로컬 머신에서 Docker 컨테이너를 실행하는 도구입니다. 사용 단계는 다음과 같습니다. 1. Docker Desktop 설치; 2. Docker Desktop을 시작하십시오. 3. Docker 이미지를 만듭니다 (Dockerfile 사용); 4. Docker Image 빌드 (Docker 빌드 사용); 5. 도커 컨테이너를 실행하십시오 (Docker Run 사용).
