https://docs.docker.com/engine/reference/commandline/docker/
를 바탕으로 정리하는 도커 명령어입니다.
도커에서는 도커 이미지를 이용하여 컨테이너를 생성할 수 있는데,
도커 이미지를 이용하면 이미지에 설정해둔 대로 컨테이너의 구성환경을 적용할 수 있다.
Dockerfile
이든 docker-compose.yml
파일이든 명령어를 작성하는 경로는 그 파일이 있는 위치
에서다. 그렇지 않으면 명령어가 적용이 안되니 주의하자.
# -a : 모든 container 출력, -q : ID만 출력
docker ps -aq
# 컨테이너 삭제
# -f : force
docker rm -f $(docker ps -aq)
# 이미지 삭제
docker rmi -f $(docker images -aq)
# 안쓰는 네트워크 삭제
docker network prune -f
# 안쓰는 볼륨 삭제
docker volume prune -f
# 도커 프로젝트 삭제
sudo rm -rf /docker/projects
sudo rm -rf /docker/_projects
# 모든 exited 된 컨테이너 삭제 f: filter
docker rm $(docker ps -aq -f status=exited)
# none 처리된 이미지들만 삭제 -> tag 없는 이미지
docker rmi $(docker images -q -f "dangling=true")
## docker 프로그램 에러 확인
$ sudo docker -f logs [container ID]
f
: 프로그램 로그가 끝까지 출력$ sudo docker images
$ sudo docker search [이미지 이름]
# Dockerfile 있어야됨
$ sudo docker build -t [dockerID]/[이미지 이름]:[버전] [경로]
# Dockerhub registry에 등록
$ sudo docker push [dockerID]/[이미지 이름]:[버전]
# Dockerhub registry에서 image 가져옴
$ sudo docker pull [dockerID]/[이미지 이름]:[버전]
:latest
를 쓰면 최신 버전으로 받을수 있다. 안써도 암묵적으로 latest이다.$ sudo docker rmi -f [이미지 id]
-f
: 이미지 강제 삭제사용하지 않는 컨테이너, 이미지 삭제
container에서 중지 또는 삭제를 해야 image도 삭제가 된다.
# 중지된 지 1시간 이상 지난 이미지만 삭제
sudo docker container prune --filter until=1h
# 사용하지 않는(dangling) image 삭제
sudo docker image prune -f
💥Docker error : no space left on device
: 컨테이너들 용량이 도커의 용량을 초과해서 생기는 오류
# 사용하지 않는 모든 데이터(컨테이너, 네트워크, 이미지, 볼륨)를 삭제
sudo docker system prune -a -f
# 위 prune 명령어를 써도 space가 부족하면 안쓰는 images들도 삭제하자!
sudo docker rmi -f [이미지 id]
1. docker-compose down --volumes
2. docker system prune --volumes
3. docker rmi $(docker images -q -f "dangling=true")
다양한 프로그램(nginx, database, WAS 등)을 컨테이너 라는 격리된 환경을 이용하여 실행시킬수 있다.
$ sudo docker start [컨테이너 id 또는 name]
$ sudo docker restart [컨테이너 id 또는 name]
Bash Shell에서 exit 또는 Ctrl + D
를 입력하면 컨테이너가 정지된다.
Ctrl + P
, Ctrl + Q
를 차례대로 입력하여 컨테이너를 정지하지 않고, 컨테이너에서 빠져나온다.
$ sudo docker ps [OPTION]
옵션
-a
: all, 모든 컨테이너(중지된 컨테이너까지) 목록 출력-q
: quiet, 컨테이너 ID만 표시.# docker run [이미지 이름]
$ sudo docker run [options] image[:TAG|@DIGEST] [COMMAND] [ARG...]
예) ex) $ sudo docker run -p [외부port]:[도커port] -it --name server ubuntu:latest /bin/bash
✅run은 자동으로 pull
도 해준다.
# mysql 환경 설정 -e
sudo docker run --name mysql-container -e MYSQL_ROOT_PASSWORD=1234 -d -p 9876:3306 mysql:8.0.22 --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
# jenkins 실행 -v
sudo docker run -d -p 9090:8080 -p 50000:50000 --name=jenkinscicd -v /jenkinsDir:/var/jenkins_home -v /var/run/docker.sock:/var/run/docker.sock mooh2jj/myjenkins
-it
: iteractive + tty(가상터미널)1) attach : 정적인 container(ex. ubuntu, 내부에 아무 프로그램이 없어서 run되지가 않는 것) 실행시 사용한다.
💡 `-dit' : 정적 container 는 이 옵션으로 bash 프로그램이 돌아가 run 될수 있으며, bash 로 접속이 가능해진다!
$ sudo docker run -dit ubuntu --name [name]
$ sudo docker attach [컨테이너 id 또는 name]
2) exec : 외부에서 container(데몬프로세스 ex.httpd, nginx, mysql, while문으로 계속 도는 프로그램 등) 진입할 때 사용
$ sudo docker exec -it [컨테이너 id 또는 name] /bin/bash
or
$ sudo docker exec -it [컨테이너 id 또는 name] bash
# 컨테이너 접속없이 바로 bash에 command를 입력할 수 있음
$ sudo docker exec it [컨테이너 id 또는 name] bash -c ls
3) inspect : container ip주소를 확인할 때 많이 사용한다.
$ sudo docker inspect [컨테이너 id 또는 name]
$ sudo docker stop [컨테이너 id 또는 name]
$ sudo docker rm -f [컨테이너 id 또는 name]
# 아예 실행되는 것을 가져올 수 있음
$ sudo docker rm -f $(sudo docker ps -aq)
docker-compose ps
# build + run 백그라운드 실행
docker-compose up -d
# Dockerfile 이미지까지 build + run
docker-compose up -d --build
# build한 image + container 삭제
docker-compose down
# build + run 했던 list
docker-compose ls (x)
docker compose ls (o)
docker-compose images
docker-compose -f logs
docker-compose -f docker-compose-mysql up -d