Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 479. docker - MySQL 컨테이너 실행 [링크 복사], [링크+제목 복사],
조회: 11186
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

docker - MySQL 컨테이너 실행

mysql도,

mysql - Docker Official Images
; https://hub.docker.com/_/mysql

"SQL Server 2019"와 유사한 사용자 경험으로 컨테이너를 실행할 수 있습니다.

c:\temp> docker pull mysql
c:\temp> docker run --name mysql1 -p 3306:3306 -e MYSQL_ROOT_PASSWORD=test_1234 -d mysql

마찬가지로 데이터베이스 변경에 대한 유지를 위해 볼륨 매핑을 추가할 수 있고,

c:\temp> docker run --name mysql1 -e MYSQL_ROOT_PASSWORD=test_1234 -v mysql:/var/lib/mysql -d mysql

(Docker Desktop의 경우 DockerDesktopVM의 공유된 볼륨 디렉터리는 "DockerDesktopVM의 파일 시스템 접근"을 참고)

DB 성격상 매번 자동으로 올라오게 설정할 것입니다.

c:\temp> docker run --name mysql1 -e MYSQL_ROOT_PASSWORD=test_1234 --restart=always -v mysql:/var/lib/mysql -d mysql

이후의 동작은 예전 글에 따라 동일하게 테스트할 수 있고,

.NET 개발자가 처음 해보는 PHP + MySQL 연동
; https://www.sysnet.pe.kr/2/0/1058

공식 도구인 "MySQL Workbench"를 이용하는 것도 좋습니다.

MySQL Workbench
; https://www.mysql.com/products/workbench/




컨테이너 내부에서 SQL 쿼리를 실행하기 위한 mysql 명령행 프로그램을,

# docker ps | grep mysql
ef39cf452adc mysql:8.0  "docker-entrypoint.s…" 2 months ago   Up 2 weeks  0.0.0.0:3306->3306/tcp, 33060/tcp  mysql1

# docker exec -it ef39cf452adc /bin/bash

/# find / -name mysql
/etc/mysql
/usr/bin/mysql
/usr/lib/mysql
find: '/proc/1/map_files': Permission denied
/var/lib/mysql
/var/lib/mysql/mysql

실행해 .NET 개발자가 처음 해보는 PHP + MySQL 연동 글에서 설명한 내용을 그대로 실습할 수 있습니다.

/# /usr/bin/mysql -u root -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 13
Server version: 8.0.18 MySQL Community Server - GPL

Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved.

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> 

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

mysql> use mysql;
Database changed

mysql>  select host, user from user;
+-----------+------------------+
| host      | user             |
+-----------+------------------+
| %         | root             |
| localhost | mysql.infoschema |
| localhost | mysql.session    |
| localhost | mysql.sys        |
| localhost | root             |
+-----------+------------------+
5 rows in set (0.00 sec)


mysql> use mydbtest;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed

mysql> create table mytable( id int NOT NULL, name varchar(50), age int, description varchar (150));
Query OK, 0 rows affected (0.04 sec)

mysql> show tables;
+--------------------+
| Tables_in_mydbtest |
+--------------------+
| mytable            |
+--------------------+
1 rows in set (0.01 sec)

mysql> SHOW PROCESSLIST;
+---------+-----------------+------------------+----------+---------+---------+------------------------+------------------+
| Id      | User            | Host             | db       | Command | Time    | State                  | Info             |
+---------+-----------------+------------------+----------+---------+---------+------------------------+------------------+
|       5 | event_scheduler | localhost        | NULL     | Daemon  | 4401885 | Waiting on empty queue | NULL             |
| 5537517 | root            | 172.17.0.1:48522 | mydbtest | Sleep   |       6 |                        | NULL             |
| 5634486 | root            | localhost        | NULL     | Query   |       0 | init                   | SHOW PROCESSLIST |
+---------+-----------------+------------------+----------+---------+---------+------------------------+------------------+
4 rows in set (0.00 sec)




참고로, 아래는 mysql container가 정상적으로 올라온 경우 보이는 로그 내용입니다.

2020-03-08 03:05:40+00:00 [Note] [Entrypoint]: Entrypoint script for MySQL Server 8.0.19-1debian10 started.
2020-03-08 03:05:41+00:00 [Note] [Entrypoint]: Switching to dedicated user 'mysql'
2020-03-08 03:05:41+00:00 [Note] [Entrypoint]: Entrypoint script for MySQL Server 8.0.19-1debian10 started.
2020-03-08 03:05:41+00:00 [Note] [Entrypoint]: Initializing database files
2020-03-08T03:05:41.379340Z 0 [Warning] [MY-011070] [Server] 'Disabling symbolic links using --skip-symbolic-links (or equivalent) is the default. Consider not using this option as it' is deprecated and will be removed in a future release.
2020-03-08T03:05:41.379427Z 0 [System] [MY-013169] [Server] /usr/sbin/mysqld (mysqld 8.0.19) initializing of server in progress as process 41
2020-03-08T03:06:18.368699Z 5 [Warning] [MY-010453] [Server] root@localhost is created with an empty password ! Please consider switching off the --initialize-insecure option.
2020-03-08 03:06:59+00:00 [Note] [Entrypoint]: Database files initialized
2020-03-08 03:06:59+00:00 [Note] [Entrypoint]: Starting temporary server
2020-03-08T03:06:59.967239Z 0 [Warning] [MY-011070] [Server] 'Disabling symbolic links using --skip-symbolic-links (or equivalent) is the default. Consider not using this option as it' is deprecated and will be removed in a future release.
2020-03-08T03:06:59.967420Z 0 [System] [MY-010116] [Server] /usr/sbin/mysqld (mysqld 8.0.19) starting as process 91
2020-03-08T03:07:04.101642Z 0 [Warning] [MY-010068] [Server] CA certificate ca.pem is self signed.
2020-03-08T03:07:04.207886Z 0 [Warning] [MY-011810] [Server] Insecure configuration for --pid-file: Location '/var/run/mysqld' in the path is accessible to all OS users. Consider choosing a different directory.
2020-03-08T03:07:04.257707Z 0 [System] [MY-010931] [Server] /usr/sbin/mysqld: ready for connections. Version: '8.0.19'  socket: '/var/run/mysqld/mysqld.sock'  port: 0  MySQL Community Server - GPL.
2020-03-08 03:07:04+00:00 [Note] [Entrypoint]: Temporary server started.
2020-03-08T03:07:04.533260Z 0 [System] [MY-011323] [Server] X Plugin ready for connections. Socket: '/var/run/mysqld/mysqlx.sock'
Warning: Unable to load '/usr/share/zoneinfo/iso3166.tab' as time zone. Skipping it.
Warning: Unable to load '/usr/share/zoneinfo/leap-seconds.list' as time zone. Skipping it.
Warning: Unable to load '/usr/share/zoneinfo/zone.tab' as time zone. Skipping it.
Warning: Unable to load '/usr/share/zoneinfo/zone1970.tab' as time zone. Skipping it.
2020-03-08T03:07:16.164323074Z 
2020-03-08 03:07:16+00:00 [Note] [Entrypoint]: Stopping temporary server
2020-03-08T03:07:16.187968Z 10 [System] [MY-013172] [Server] Received SHUTDOWN from user root. Shutting down mysqld (Version: 8.0.19).
2020-03-08T03:07:18.711573Z 0 [System] [MY-010910] [Server] /usr/sbin/mysqld: Shutdown complete (mysqld 8.0.19)  MySQL Community Server - GPL.
2020-03-08 03:07:19+00:00 [Note] [Entrypoint]: Temporary server stopped
2020-03-08T03:07:19.192362850Z 
2020-03-08 03:07:19+00:00 [Note] [Entrypoint]: MySQL init process done. Ready for start up.
2020-03-08T03:07:19.193705708Z 
2020-03-08T03:07:19.654769Z 0 [Warning] [MY-011070] [Server] 'Disabling symbolic links using --skip-symbolic-links (or equivalent) is the default. Consider not using this option as it' is deprecated and will be removed in a future release.
2020-03-08T03:07:19.654951Z 0 [System] [MY-010116] [Server] /usr/sbin/mysqld (mysqld 8.0.19) starting as process 1
2020-03-08T03:07:22.632563Z 0 [Warning] [MY-010068] [Server] CA certificate ca.pem is self signed.
2020-03-08T03:07:22.694268Z 0 [Warning] [MY-011810] [Server] Insecure configuration for --pid-file: Location '/var/run/mysqld' in the path is accessible to all OS users. Consider choosing a different directory.
2020-03-08T03:07:22.746884Z 0 [System] [MY-010931] [Server] /usr/sbin/mysqld: ready for connections. Version: '8.0.19'  socket: '/var/run/mysqld/mysqld.sock'  port: 3306  MySQL Community Server - GPL.
2020-03-08T03:07:22.943244Z 0 [System] [MY-011323] [Server] X Plugin ready for connections. Socket: '/var/run/mysqld/mysqlx.sock' bind-address: '::' port: 33060




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 5/31/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 31  32  33  34  35  36  37  38  39  40  41  42  43  44  [45]  ...
NoWriterDateCnt.TitleFile(s)
12513정성태1/28/20218927오류 유형: 698. electronize - User Profile 디렉터리에 공백 문자가 있는 경우 빌드가 실패하는 문제 [1]
12512정성태1/28/20218692오류 유형: 697. The program can't start because VCRUNTIME140.dll is missing from your computer. Try reinstalling the program to fix this problem.
12511정성태1/27/20218438Windows: 187. Windows - 도스 시절의 8.3 경로를 알아내는 방법
12510정성태1/27/20218814.NET Framework: 1020. .NET Core Kestrel 호스팅 - Razor 지원 추가 [1]파일 다운로드1
12509정성태1/27/20219740개발 환경 구성: 524. Jupyter Notebook에서 C#(F#, PowerShell) 언어 사용을 위한 환경 구성 [3]
12508정성태1/27/20218318개발 환경 구성: 523. Jupyter Notebook - Slide 플레이 버튼이 없는 경우
12507정성태1/26/20218446VS.NET IDE: 157. Visual Studio - Syntax Visualizer 메뉴가 없는 경우
12506정성태1/25/202111761.NET Framework: 1019. Microsoft.Tye 기본 사용법 소개 [1]
12505정성태1/23/20219445.NET Framework: 1018. .NET Core Kestrel 호스팅 - Web API 추가 [1]파일 다운로드1
12504정성태1/23/202110550.NET Framework: 1017. .NET 5에서의 네트워크 라이브러리 개선 (2) - HTTP/2, HTTP/3 관련 [1]
12503정성태1/21/20218892오류 유형: 696. C# - HttpClient: Requesting HTTP version 2.0 with version policy RequestVersionExact while HTTP/2 is not enabled.
12502정성태1/21/20219678.NET Framework: 1016. .NET Core HttpClient의 HTTP/2 지원파일 다운로드1
12501정성태1/21/20218724.NET Framework: 1015. .NET 5부터 HTTP/1.1, 2.0 선택을 위한 HttpVersionPolicy 동작 방식파일 다운로드1
12500정성태1/21/20219291.NET Framework: 1014. ASP.NET Core(Kestrel)의 HTTP/2 지원 여부파일 다운로드1
12499정성태1/20/202110480.NET Framework: 1013. .NET Core Kestrel 호스팅 - 포트 변경, non-localhost 접속 지원 및 https 등의 설정 변경 [1]파일 다운로드1
12498정성태1/20/20219457.NET Framework: 1012. .NET Core Kestrel 호스팅 - 비주얼 스튜디오의 Kestrel/IIS Express 프로파일 설정
12497정성태1/20/202110404.NET Framework: 1011. C# - OWIN Web API 예제 프로젝트 [1]파일 다운로드2
12496정성태1/19/20219259.NET Framework: 1010. .NET Core 콘솔 프로젝트에서 Kestrel 호스팅 방법 [1]
12495정성태1/19/202111259웹: 40. IIS의 HTTP/2 지원 여부 - h2, h2c [1]
12494정성태1/19/202110552개발 환경 구성: 522. WSL2 인스턴스와 호스트 측의 Hyper-V에 운영 중인 VM과 네트워크 연결을 하는 방법 [2]
12493정성태1/18/20218847.NET Framework: 1009. .NET 5에서의 네트워크 라이브러리 개선 (1) - HTTP 관련 [1]파일 다운로드1
12492정성태1/17/20218260오류 유형: 695. ASP.NET 0x80131620 Failed to bind to address
12491정성태1/16/20219924.NET Framework: 1008. 배열을 반환하는 C# COM 개체의 메서드를 C++에서 사용 시 메모리 누수 현상 [1]파일 다운로드1
12490정성태1/15/20219449.NET Framework: 1007. C# - foreach에서 열거 변수의 타입을 var로 쓰면 object로 추론하는 문제 [1]파일 다운로드1
12489정성태1/13/202110374.NET Framework: 1006. C# - DB에 저장한 텍스트의 (이모티콘을 비롯해) 유니코드 문자가 '?'로 보인다면? [1]
12488정성태1/13/202110658.NET Framework: 1005. C# - string 타입은 shallow copy일까요? deep copy일까요? [2]파일 다운로드1
... 31  32  33  34  35  36  37  38  39  40  41  42  43  44  [45]  ...