DevSoupe
  • 🙂welcome
    • Hi there, I'm Seth!
  • ✍️blog
    • macOS 개발 환경 설정
    • SDKMAN!으로 자바 버전 관리
    • 도커 환경에서 MySQL 설치 및 접속
    • 도커를 사용하여 GitLab Runner 구성
    • 스프링부트 H2 DB mem 모드 사용시 테이블 접근
    • Git 서브모듈 삭제
  • 📚Book
    • 자바에서 코틀린으로 (코틀린으로 리팩터링하기)
      • 1장 - 소개
      • 2장 - 자바 프로젝트에서 코틀린 프로젝트
      • 3장 - 자바 클래스에서 코틀린 클래스로
      • 4장 - 옵셔널에서 널이 될 수 있는 타입으로
    • 오브젝트 (코드로 이해하는 객체지향 설계)
    • 이펙티브 코틀린
      • 1장 - 안정성
        • 아이템 1 - 가변성을 제한하라
        • 아이템 2 - 변수의 스코프를 최소화하라
        • 아이템 3 - 최대한 플랫폼 타입을 사용하지 말라
        • 아이템 4 - inferred 타입으로 리턴하지 말라
        • 아이템 5 - 예외를 활용해 코드에 제한을 걸어라
        • 아이템 6 - 사용자 정의 오류보다는 표준 오류를 사용하라
        • 아이템 7 - 결과 부족이 발생할 경우 null과 Failure를 사용하라
        • 아이템 8 - 적절하게 null을 처리하라
        • 아이템 9 - use를 사용하여 리소스를 닫아라
        • 아이템 10 - 단위 테스트를 만들어라
  • 🧑‍🏫Seminar
    • 우아한 모노리스
    • 우아한 객체지향
    • 점진적 추상화
  • 🌎English
    • 영어 피트니스 50일의 기적 ①
      • PART 1 워밍업
        • 1. '말문 트기'란?
      • PART 2 말문 트기 훈련 코스
        • DAY 1
          • STEP 1. Do (~해, ~하지 마)
          • STEP 2. Do + 말늘리기
    • 라이브 아카데미 토들러
      • Lesson 001 - 기본적인 문장 구성하기
      • Lesson 002 - 문장 만들기
Powered by GitBook
On this page
  • 1. 도커 설치
  • 2. MySQL 이미지 다운로드
  • 3. MySQL 도커 이미지로 컨테이너 생성 및 실행
  • 4. 실행중인 도커 컨테이너 리스트 출력
  • 5. 실행중인 MySQL 도커 컨테이너 접속
  1. blog

도커 환경에서 MySQL 설치 및 접속

macOS 기준으로 도커 환경에서 MySQL 설치 및 접속에 대한 가이드를 제공한다.

Last updated 8 months ago

1. 도커 설치

다운로드 및 설치

  • 에서 자신의 OS에 맞는 파일을 내려 받은 후 설치한다.

버전 확인

  • 설치가 완료되면 버전을 출력해 정상적으로 출력되는지 확인한다.

$ docker -v 
Docker version 24.0.2, build cb74dfc

다운로드 및 설치

1. Homebrew

  • macOS에서 사용되는 인기있는 패키지 매니저이다.

  • CLI를 통해 손쉽게 소프트웨어 패키지와 의존성을 설치, 업데이트 및 관리할 수 있다.

  • 에 나와있는 명령어로 Homebrew를 설치한다.

$ /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"

2. Homebrew Cask

  • Homebrew의 확장으로 명령줄을 통해 그래픽 애플리케이션(예: GUI 앱)을 설치할 수 있다.

  • 이를 설치하기 위해서는 먼저 Homebrew가 설치되어 있어야 한다.

$ brew install cask

3. 도커

  • 설치한 Homebrea Cask를 사용해 도커를 설치한다.

$ brew install --cask docker

버전 확인

  • 설치가 완료되면 버전을 출력해 정상적으로 출력되는지 확인한다.

$ docker -v 
Docker version 24.0.2, build cb74dfc

2. MySQL 이미지 다운로드

  • docker pull 명령어를 사용해 MySQL 도커 이미지를 다운로드 한다.

  • 태그에 버전을 명시하지 않으면 자동으로 최신 버전을 다운로드 한다.

$ docker pull mysql
Using default tag: latest
latest: Pulling from library/mysql
1817bc1e6309: Pull complete 
740bd54462bc: Pull complete 
a7e5ed4e69b3: Pull complete 
8fdf88d7bbb7: Pull complete 
a1a5f8560950: Pull complete 
82b514ba21a5: Pull complete 
d6a4cb36f5f9: Pull complete 
3392803e2ec5: Pull complete 
dcc1a15c36b9: Pull complete 
3e1c4ca2fc97: Pull complete 
Digest: sha256:6a5dbd2819e36048669639811461f27fee48da1e22039e5d31f4273a20d542f6
Status: Downloaded newer image for mysql:latest
docker.io/library/mysql:latest
  • 특정한 MySQL 도커 이미지를 다운로드 받으려면 태그에 버전을 지정하면 된다.

  • 사용 가능한 버전은 에서 확인할 수 있다.

  • 8.0.34 버전을 다운로드 하려면 다음과 같이 태그에 버전을 지정하면 된다.

$ docker pull mysql:8.0.34
8.0.34: Pulling from library/mysql
1817bc1e6309: Already exists 
740bd54462bc: Already exists 
a7e5ed4e69b3: Already exists 
8fdf88d7bbb7: Already exists 
a1a5f8560950: Already exists 
6d2014e71aa1: Pull complete 
a65eef362898: Pull complete 
1086465c0f61: Pull complete 
6d718a732c3a: Pull complete 
c724fd4b412f: Pull complete 
74fcbdd515b3: Pull complete 
Digest: sha256:51c4dc55d3abf4517a5a652794d1f0adb2f2ed1d1bedc847d6132d91cdb2ebbf
Status: Downloaded newer image for mysql:8.0.34
docker.io/library/mysql:8.0.34
  • docker images 명령어를 사용해 설치되어 있는 최신 버전과 지정한 8.0.34 버전을 확인할 수 있다.

$ docker images
REPOSITORY             TAG       IMAGE ID       CREATED       SIZE
mysql                  latest    de7c37d1d5ac   3 days ago    599MB
mysql                  8.0.34    2031a058d3ba   12 days ago   599MB

3. MySQL 도커 이미지로 컨테이너 생성 및 실행

  • docker run 명령어를 사용해 다운로드 받은 이미지로 컨테이너를 실행할 수 있다.

  • 생성 및 실행되는 컨테이너 이름은 mysql-container이다.

  • MySQL 접속시 사용되는 루트 패스워드는 <password>에 지정해주면 된다.

$ docker run --name mysql-container -e MYSQL_ROOT_PASSWORD=<password> -d -p 3306:3306 mysql:latest

4. 실행중인 도커 컨테이너 리스트 출력

  • docker ps -a 명령어로 컨테이너 생성 및 실행 후 정상적으로 실행되고 있는지 확인할 수 있다.

$ docker ps -a
CONTAINER ID   IMAGE                         COMMAND                  CREATED          STATUS          PORTS                               NAMES
70c1ef9b8e8c   772571a08c67                  "docker-entrypoint.s…"   56 minutes ago   Up 50 minutes   0.0.0.0:3306->3306/tcp, 33060/tcp   mysql-container

실행중인 MySQL 도커 컨테이너 시작/중지/재시작 하려면 다음과 같은 명령어를 사용해야 한다.

# MySQL 도커 컨테이너 중지

$ docker stop mysql-container

# MySQL Docker 컨테이너 시작

$ docker start mysql-container # MySQL 도커 컨테이너 재시작

$ docker restart mysql-container

5. 실행중인 MySQL 도커 컨테이너 접속

  • docker exec 명령어를 사용하여 도커 Docker 컨테이너를 정상적으로 실행했으면 컨테이너에 접속한다.

  • 컨테이너에 접속해 MySQL 에도 접속하여 원하는 작업을 수행할 수 있다.

$ docker exec -it mysql-container bash
bash-4.4# mysql -u root -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 20
Server version: 8.0.33 MySQL Community Server - GPL

Copyright (c) 2000, 2023, Oracle and/or its affiliates.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| library            |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
5 rows in set (0.01 sec)

mysql> 
✍️
도커 홈페이지
Homebrew 홈페이지
dockerhub