본문 바로가기

도커

(11)
Docker 컨테이너에서 크론 작업(cronJob) 실행하기: 설정 및 예제 가이드 크론 작업을 Docker 컨테이너 안에서 실행하는 방법은 개발 및 운영 환경에서 자주 다루어지는 문제 중 하나입니다. 이 글에서는 Docker 컨테이너 내부에서 크론 작업(cron jobs)을 설정하고 실행하는 방법을 단계별로 알아보겠습니다.Docker 컨테이너 내부에서 크론 작업 실행하기1. 크론 작업이란?크론(cron)은 유닉스 계열 운영 체제에서 시간 기반의 작업 스케줄링을 위해 사용되는 시스템 도구입니다. 이를 통해 정기적으로 실행되어야 하는 작업을 자동화할 수 있습니다.2. 기본 Docker 이미지에 크론 설치하기Docker 컨테이너 내에서 크론 작업을 실행하기 위해서는 컨테이너에 크론 데몬(cron daemon)이 설치되어 있어야 합니다. 일반적으로 Linux 기반 컨테이너에서 크론을 설정할 ..
Docker 컨테이너 최적화를 위한 빌드 컨텍스트 외부 파일 포함 방법 Docker 컨테이너 최적화를 위한 빌드 컨텍스트 외부 파일 포함 방법Docker로 애플리케이션을 컨테이너화할 때, 우리는 종종 프로젝트 루트 경로 외부에 있는 특정 파일이나 디렉토리를 Docker 이미지에 포함해야 하는 상황을 맞이합니다.예를 들어, 보안 자격 증명 파일이나 공용 설정 파일을 사용하고자 할 때 이러한 필요가 발생할 수 있습니다. Docker의 빌드 컨텍스트에 이러한 외부 파일을 포함하는 것은 몇 가지 제한이 있지만, 이를 해결하기 위한 몇 가지 전략이 존재합니다.1. Docker 빌드 컨텍스트란?Docker 빌드 컨텍스트는 docker build 명령어가 실행되는 디렉토리와 그 하위 파일 및 디렉토리의 집합을 말합니다. Docker가 이미지를 빌드할 때, 빌드 컨텍스트 외부에 있는 파일..
[Docker] Docker 이미지 정리하기: 불필요한 이미지 제거하는 완벽 가이드 Docker 이미지 관리는 시스템의 성능과 공간 효율성을 유지하기 위해 중요합니다. 오래되거나 사용하지 않는 이미지를 제거하는 것은 디스크 공간을 확보하고, 관리를 용이하게 하며, 보안을 강화할 수 있습니다. 이 글에서는 Docker 이미지를 효과적으로 정리하는 방법에 대해 설명합니다. Docker 이미지 제거의 기본 Docker에서 이미지를 제거하는 가장 기본적인 명령어는 docker image rm 입니다. 이 명령어는 하나 이상의 이미지를 제거하는 데 사용됩니다. docker image rm [OPTIONS] IMAGE [IMAGE...] 옵션으로는 -f 또는 --force를 사용하여 이미지의 강제 삭제를 할 수 있고, --no-prune 옵션을 사용하여 태그되지 않은 부모 이미지를 삭제하지 않도록..
[Docker] 도커(Docker)에서 한 번에 모든 이미지 삭제하는 방법 도커(Docker)를 사용하면서 로컬에 쌓인 이미지들을 일괄적으로 삭제할 필요가 있을 때가 있습니다. 특히, 디스크 공간을 확보하거나 정리를 하기 위한 작업을 필요로 합니다. 이 글에서는 도커에서 모든 로컬 이미지를 삭제하는 방법에 대해 알아보겠습니다. 도커 이미지 삭제 기본 도커에서 이미지를 삭제하는 기본 명령어는 docker rmi입니다. 이 명령어는 하나 또는 여러 개의 이미지를 호스트 노드에서 삭제합니다. 이미지가 여러 태그를 가지고 있다면, 해당 태그만 제거하고, 태그가 이미지에 대한 유일한 참조일 경우 이미지와 태그 모두 삭제됩니다. 예시: 특정 이미지 삭제 docker rmi 모든 이미지 일괄 삭제 모든 로컬 도커 이미지를 삭제하려면, 아래의 명령어를 사용할 수 있습니다. 이 명령어는 로컬에..
[Docker] 볼륨 추가 시 필요 없는 특정 폴더 쉽게 제외하기 (.dockerignore) 도커(Docker)는 애플리케이션을 컨테이너화하여 개발 및 배포를 간편하게 해주는 툴입니다. 때때로, 우리는 특정 볼륨을 도커 컨테이너에 추가하고 싶지만 그 안의 일부 서브 폴더는 제외하고 싶을 수 있습니다. 이 글에서는 도커에 볼륨을 추가하면서 특정 서브 폴더를 제외하는 방법에 대해 알아보겠습니다. 1. 볼륨 추가의 기본 먼저, 도커에 볼륨을 추가하는 기본적인 방법부터 이해해야 합니다. 볼륨은 컨테이너의 데이터를 보존하고, 컨테이너 사이에 데이터를 공유하는 데 사용됩니다. 도커 볼륨을 추가하는 가장 간단한 방법은 docker run 명령어에 -v 또는 --volume 옵션을 사용하는 것입니다. 예를 들어, 로컬의 /mydata 폴더를 컨테이너의 /data 폴더에 마운트하는 경우 아래와 같이 명령을 실행..
[Docker] Dockerfile의 COPY와 ADD 명령어 비교: 언제 어떤 명령어를 사용해야 할까? Docker 이미지를 구축할 때 Dockerfile의 COPY와 ADD 명령어는 파일과 디렉토리를 이미지로 복사하는 데 사용됩니다. 이 글에서는 이 두 명령어의 차이점과 각각의 사용 사례를 살펴보겠습니다.>공식문서COPY 명령어COPY 명령어는 Docker 호스트의 파일이나 디렉토리를 Docker 이미지로 복사하는 데 사용됩니다. 이 명령어는 로컬 파일 시스템에서만 작동하며, URL이나 다른 원격 소스에서 직접 파일을 복사할 수는 없습니다.COPY 사용 예시# DockerfileCOPY ./local_directory /container_directory이 예시에서 local_directory는 호스트 시스템의 디렉토리이며, /container_directory는 대상 이미지 내의 디렉토리입니다.ADD ..
[Docker] Docker 컨테이너에서 호스트 머신의 로컬호스트에 접속하는 방법 (host.docker.internal) Docker를 사용하는 많은 개발자들이 직면하는 일반적인 문제 중 하나는 컨테이너 내부에서 호스트 머신의 로컬호스트에 어떻게 접근하는지에 관한 것입니다. 이 글에서는 Docker 컨테이너 내부에서 호스트 시스템의 로컬호스트에 연결하는 방법을 설명하겠습니다. Docker 네트워크 이해 Docker 컨테이너는 기본적으로 격리된 환경을 제공합니다. 이 때문에 컨테이너는 자체적인 로컬호스트를 가지고, 이는 호스트 머신의 로컬호스트와는 다릅니다. 따라서, 컨테이너 내부에서 localhost 또는 127.0.0.1을 사용하여 호스트 머신의 서비스에 접근하려고 하면 연결되지 않습니다. 호스트 머신에 접근하기 Docker의 특수 DNS 이름 사용 Docker 18.03 버전 이후부터는 host.docker.intern..
[Docker] Docker 호스트에서 컨테이너 IP 주소 찾는 쉬운 방법 Docker 컨테이너의 IP 주소 확인하기 Docker는 개발 및 배포 과정을 간소화하는 데 널리 사용되는 컨테이너화 도구입니다. 때때로, 호스트 시스템에서 실행 중인 Docker 컨테이너의 IP 주소를 확인해야 할 필요가 있습니다. 이 글에서는 Docker 컨테이너의 IP 주소를 호스트에서 어떻게 확인하는지 단계별로 설명하겠습니다. Docker 컨테이너 IP 주소 확인 방법 1. Docker 컨테이너 실행 확인 먼저, 실행 중인 Docker 컨테이너가 있는지 확인해야 합니다. 이를 위해 다음 명령어를 사용할 수 있습니다: docker ps 이 명령어는 실행 중인 모든 컨테이너의 목록을 보여줍니다. 2. 컨테이너의 세부 정보 확인 컨테이너의 IP 주소를 얻기 위해서는 컨테이너의 세부 정보를 조회해야 합니..
[Docker] 이미지를 깨끗하게 재빌드하는 방법 도커 이미지를 깨끗하게 재빌드하려면 다음과 같은 단계를 따르면 됩니다. 1. 컨테이너 및 이미지 삭제 우선 해당 이미지를 사용하는 모든 컨테이너를 중지하고 삭제해야합니다. 이는 다음 명령을 통해 수행할 수 있습니다. docker stop [container_name] docker rm [container_name] 이미지를 직접 삭제하려면 다음과 같이 입력합니다. docker rmi [image_name] 2. 캐시된 빌드 삭제 이전 빌드에서 캐시가 사용될 가능성이 있으므로 빌드 캐시를 삭제해야합니다. 다음 명령을 사용하여 모든 캐시를 삭제할 수 있습니다. docker builder prune 3. 새로운 이미지 빌드 모든 이전 이미지 및 캐시가 제거되었으므로 새 이미지를 빌드할 수 있습니다. 다음 명령..
[Docker] Docker Buildx를 통한 Multi-architecture 이미지 빌드(x86, ARM) 최근 ARM 기반 프로세서(AWS Graviton, Apple M1 등) 사용이 증가로 인하여 Multi-architecture 빌드가 중요해지고 있습니다. (특히 Apple M1 칩의 등장으로 ARM 기반 프로세서에서 동작하는 프로그램을 개발하는 엔지니어가 증가할 것이라 예측됩니다..) 기존의 서버는 보통 x86 또는 AMD CPU를 사용하여 실행하였고, 동일한 환경에서 개발된 프로그램이라면 배포하는 것에는 아무 문제가 없습니다. 하지만 ARM 환경에서 개발된 프로그램을 AMD 환경에 배포하거나, AMD 환경에서 개발된 프로그램을 ARM 환경에 배포한다면 문제가 생길 수 있습니다. Docker buildx를 이용하여 Multi-architecture에 배포할 수 있는 컨테이너 이미지를 빌드하는 방법에 ..