Docker Ubuntu Repository를 운영중이다. 저장소를 등록하고 설치한다. ubuntu 버전별 주의점도 읽어봐야 한다.
/etc/apt/sources.list.d/additional-repositories.list
파일을 열어서 Mint에 해당하는 Ubuntu LTS로 변경해줘야 한다. Linux 배포판과 버전 확인# docker 에서 제공해주는 리포지토리 설정할 경우 curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg echo \ "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu \ $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
# docker 제공 저장소 설정을 마친뒤에 sudo apt-get install docker-ce docker-ce-cli containerd.io # 만약, Ubuntu 기본 제공 docker를 사용하고자 한다면 sudo apt-get install docker
docker
Service로 자동 등록된다. Ubuntu Service
매번 sudo
명령을 사용하는게 싫을 경우 docker
Group에 사용자를 등록해준다. 단, 이 경우 docker
그룹에 속하는 사용자는 root
와 맞먹는 권한을 갖기 때문에 보안에 주의해야한다.
# sudo groupadd docker # 보통 미리 추가됨 sudo usermod -aG docker $USER sudo service docker restart # logout/login # newgrp docker 로그아웃 없이 group 적용됨. # 잘 되는지 확인 sudo 없이 docker run hello-world # ctop 모니터링용 sudo apt-get install ctop
만약 Cannot connect to the Docker daemon. Is 'docker daemon' running on this host?
와 같은 메시지가 나오면서 실행이 안된다면 재시작/재로그인을 안 한 때문이거나 DOCKER_HOST
환경변수를 잘못 설정했기 때문이다. 재부팅 하고 DOCKER_HOST
환경변수를 삭제해준다.
# systemd sudo systemctl enable docker
sudo apt-get purge docker-ce rm -rf /var/lib/docker
아래와 같은 경고를 만난다면, Memory 옵션과 Swap Accounting Kernel 옵션을 설정하자. docker를 안 사용하더라도 성능상 좋다고 한다.
WARNING: Your kernel does not support cgroup swap limit. WARNING: Your kernel does not support swap limit capabilities. Limitation discarded.
/etc/default/grub
파일을 열어서
GRUB_CMDLINE_LINUX="cgroup_enable=memory swapaccount=1"
sudo update-grub # 이후 재부팅한다.
Ubuntu Linux Firewall 사용시 Forwarding 기능을 활성화해야한다. TBD
TBD
/var/lib/docker
/etc/default/docker
파일에서 옵션을 지정한다. Best way to move docker directory · Issue #3127 · docker/dockersudo rm /var/lib/docker sudo ln -s /path/to/docker-storage /var/lib/docker # /etc/default/docker - /var/lib/docker 링크가 가리키는 실제 디렉토리를 지정해 줌 DOCKER_OPTS="-g $(readlink -f /var/lib/docker)"
14.10
이하는 upstartd
를 사용하며, 설치 과정에서 자동시작으로 등록된다.15.04
이상은 systemd
를 사용하며, 아래 명령으로 자동시작 등록한다.sudo systemctl enable docker
설치 테스트가 끝났으니 삭제한다.
docker rm `sudo docker ps -aq` # 컨테이너 삭제 docker rmi hello-world # 이미지 삭제