Spring Framework

[SpringBoot] MySQL/Maria 연결하기

헤르메스의날개 2024. 8. 21. 10:53
728x90

MySqlRunner.zip
0.09MB

IDE : IntelliJ

JDK : OpenJDK 11

Framework : Spring Boot 2.5.2

Database : MySql 최신버전 ( Oracle 에 라이센스비를 지급해야 하고, 소스공개의 의무가 존재함 )

              Maria 최신버전 ( 소스공개의 의무가 존재함 )


Docker 설치

https://hermeslog.tistory.com/497?category=302346 

 

[Docker] Docker의 설치

Docker의 설치 참조 : docs.microsoft.com/ko-kr/windows/wsl/tutorials/wsl-containers Linux 용 Windows 하위 시스템에서 Docker 컨테이너 사용 시작 Linux 용 Windows 하위 시스템에서 Docker 컨테이너를 설정..

hermeslog.tistory.com

Docker에 MySQL 설치

? docker에 mysql 이미지 설치
$>docker pull mysql 

? Docker 컨테이너 생성
? -d : 백그라운드 실행
? -p 포트 포딩 3306 번 포트로 들어온 내용은 3306 번 포트로 포딩을 해주겟다는 내용
? -e 환경변수 설정 MYSQL_ROOT_PASSWORD= 내용을 password로 설정
? --name Container 이름을 설정해줍니다.
? --restart=always Docker 실행 시 같이 실행됨.
? docker exec -> run a command on an existing/running container
? docker run -> create a new container from an image, and run the command there
? local에 데이터 저장 : -v c:\Temp\data\mariadb:/var/lib/mysql
$>docker run -d -p 3306:3306 --name mysql_boot -e MYSQL_ROOT_PASSWORD=1 -e MYSQL_DATABASE=springboot -e MYSQL_USER=hermeswing -e MYSQL_PASSWORD=pass -v c:\Temp\data\mysql:/var/lib/mysql -d mysql

? 생성된 Docker 컨테이너 확인
$>docker ps -a

? Docker 컨테이너 실행
$>docker exec -it mysql_boot bash

? MySQL 접속 password : 1
$>mysql -u root -p

? MySQL version 확인
mysql> select version();

? Docker 컨테이너 멈춤
$>docker stop mysql_boot

? Docker 컨테이너 삭제
$>docker rm mysql_boot

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.5.2</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.mysql</groupId>
    <artifactId>MySqlRunner</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>MySqlRunner</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>11</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>
package com.mysql.mysqlrunner.runner;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Component;

import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.Statement;

@Component
public class MySQLRunner implements ApplicationRunner {
    @Autowired
    DataSource dataSource;

    @Autowired
    JdbcTemplate jdbcTemplate;

    @Override
    public void run( ApplicationArguments args ) {
        try {
            Connection connection = dataSource.getConnection();
            System.out.println( connection.getMetaData().getClass() );
            System.out.println( connection.getMetaData().getURL() );
            System.out.println( connection.getMetaData().getUserName() );

            Statement statement = connection.createStatement();
            String sql = "CREATE TABLE USER(ID INTEGER NOT NULL, NAME VARCHAR(255), PRIMARY KEY(ID))";
            statement.executeUpdate( sql );

            jdbcTemplate.execute( "INSERT INTO USER VALUES (1, 'hermeswing')" );

        } catch( Exception e ) {
            e.printStackTrace();
        }
    }
}
server.port=9090

spring.datasource.hikari.maximum-pool-size=4

spring.datasource.url=jdbc:mysql://localhost:3306/springboot?allowPublicKeyRetrieval=true
spring.datasource.username=hermeswing
spring.datasource.password=pass

MySQLRunner 실행결과

더보기

  .   ____          _            __ _ _
 /\\ / ___'_ __ _ _(_)_ __  __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
 \\/  ___)| |_)| | | | | || (_| |  ) ) ) )
  '  |____| .__|_| |_|_| |_\__, | / / / /
 =========|_|==============|___/=/_/_/_/
 :: Spring Boot ::                (v2.5.2)

2021-07-18 13:38:50.394  INFO 11432 --- [           main] c.m.mysqlrunner.MySqlRunnerApplication   : Starting MySqlRunnerApplication using Java 11 on DESKTOP-HMJ6ST0 with PID 11432 (C:\JetBrains\IdeaProjects\MySqlRunner\target\classes started by hermeswing in C:\JetBrains\IdeaProjects\MySqlRunner)
2021-07-18 13:38:50.404  INFO 11432 --- [           main] c.m.mysqlrunner.MySqlRunnerApplication   : No active profile set, falling back to default profiles: default
2021-07-18 13:38:51.840  INFO 11432 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat initialized with port(s): 9090 (http)
2021-07-18 13:38:51.851  INFO 11432 --- [           main] o.apache.catalina.core.StandardService   : Starting service [Tomcat]
2021-07-18 13:38:51.851  INFO 11432 --- [           main] org.apache.catalina.core.StandardEngine  : Starting Servlet engine: [Apache Tomcat/9.0.48]
2021-07-18 13:38:51.951  INFO 11432 --- [           main] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
2021-07-18 13:38:51.951  INFO 11432 --- [           main] w.s.c.ServletWebServerApplicationContext : Root WebApplicationContext: initialization completed in 1447 ms
2021-07-18 13:38:52.385  INFO 11432 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 9090 (http) with context path ''
2021-07-18 13:38:52.397  INFO 11432 --- [           main] c.m.mysqlrunner.MySqlRunnerApplication   : Started MySqlRunnerApplication in 2.765 seconds (JVM running for 5.276)
2021-07-18 13:38:52.400  INFO 11432 --- [           main] com.zaxxer.hikari.HikariDataSource       : HikariPool-1 - Starting...
2021-07-18 13:38:52.681  INFO 11432 --- [           main] com.zaxxer.hikari.HikariDataSource       : HikariPool-1 - Start completed.
class com.zaxxer.hikari.pool.HikariProxyDatabaseMetaData
jdbc:mysql://localhost:3306/springboot?allowPublicKeyRetrieval=true
hermeswing@172.17.0.1


MySQL 접속 및 데이터 확인

더보기

root@faf646b731a5:/# mysql -u root -p
Enter password:
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 15
Server version: 8.0.25 MySQL Community Server - GPL

Copyright (c) 2000, 2021, 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 database;
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'database' at line 1
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| springboot         |
| sys                |
+--------------------+
5 rows in set (0.00 sec)

mysql> use springboot
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> show tables;
+----------------------+
| Tables_in_springboot |
+----------------------+
| USER                 |
+----------------------+
1 row in set (0.00 sec)

mysql> drop table USER;
Query OK, 0 rows affected (0.08 sec)


Docker에 Maria 설치

? docker에 mariadb 이미지 설치
$>docker pull mariadb 

? Docker 컨테이너 생성
? --restart=always Docker 실행 시 같이 실행됨.
? Data backup : -v c:\Temp\data\mariadb:/var/lib/mysql 
$>docker run -d -p 3306:3306 --name maria_boot -e MYSQL_ROOT_PASSWORD=1 -e MYSQL_DATABASE=springboot -e MYSQL_USER=hermeswing -e MYSQL_PASSWORD=pass -v c:\Temp\data\mariadb:/var/lib/mysql -d mariadb

? 생성된 Docker 컨테이너 확인
$>docker ps -a

? Docker 컨테이너 실행
$>docker exec -it maria_boot bash

? Maria DB 접속
? password : 1
$>mariadb -u root -p

? Maria DB 버전 확인
MariaDB [(none)]> select version();

? Docker 컨테이너 멈춤
$>docker stop maria_boot

? Docker 컨테이너 삭제
$>docker rm maria_boot

MySQL 처럼 allowPublicKeyRetrieval=true 를 붙이지 않아도 됩니다.

server.port=9090

spring.datasource.hikari.maximum-pool-size=4

spring.datasource.url=jdbc:mysql://localhost:3306/springboot
spring.datasource.username=hermeswing
spring.datasource.password=pass

위의 코드를 실행해도 그대로 실행됩니다.

더보기

root@6d01bc3192d4:/# mysql -u root -p
Enter password:
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 13
Server version: 10.6.3-MariaDB-1:10.6.3+maria~focal mariadb.org binary distribution

Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.

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

MariaDB [(none)]> use springboot
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
MariaDB [springboot]> show tables;
+----------------------+
| Tables_in_springboot |
+----------------------+
| USER                 |
+----------------------+
1 row in set (0.000 sec)

MariaDB [springboot]> quit
Bye

MariaDB [springboot]>


https://downloads.mariadb.com/Connectors/java

 

Connectors/java/ - MariaDB

 

downloads.mariadb.com


정기백업을 위한 Windows Command  ( 관리자 계정으로 실행 해야 합니다. )

먼저 Docker 의 Maria Database 를 멈춤니다.

@echo off
:: 백업 경로 설정
set BACKUP_DIR=C:\Temp\Docker_Backup
set B_DATE=%DATE:~0,4%%DATE:~5,2%%DATE:~8,2%

:: 백업 폴더가 없으면 생성
if not exist "%BACKUP_DIR%" (
    mkdir "%BACKUP_DIR%"
)

:: Docker 이미지 백업
set IMAGE_NAME=mariadb:latest
set IMAGE_BACKUP_PATH=%BACKUP_DIR%\maria_%B_DATE%.tar

echo Docker 이미지 백업 중: %IMAGE_BACKUP_PATH%
docker save -o %IMAGE_BACKUP_PATH% %IMAGE_NAME%
if %ERRORLEVEL% neq 0 (
    echo Docker 이미지 백업 실패
    exit /b 1
)
echo Docker 이미지 백업 완료: %IMAGE_BACKUP_PATH%

:: Docker 볼륨 백업
set CONTAINER_NAME=maria_boot
set VOLUME_BACKUP_PATH=%BACKUP_DIR%\maria_%B_DATE%_volume.tar

:: 컨테이너에서 볼륨 경로를 찾음
for /f "tokens=*" %%i in ('docker inspect --format "{{ range .Mounts }}{{ .Source }}{{ end }}" %CONTAINER_NAME%') do (
    set VOLUME_PATH=%%i
)

if not defined VOLUME_PATH (
    echo 볼륨 경로를 찾을 수 없습니다.
    exit /b 1
)

echo Docker 볼륨 백업 중: %VOLUME_BACKUP_PATH%
tar -cvf %VOLUME_BACKUP_PATH% -C %VOLUME_PATH% .
if %ERRORLEVEL% neq 0 (
    echo Docker 볼륨 백업 실패
    exit /b 1
)
echo Docker 볼륨 백업 완료: %VOLUME_BACKUP_PATH%

echo 모든 백업이 완료되었습니다.

Maria Container를 생성 후 실행 합니다.

Volume 복원을 위한 Windows Command  ( 관리자 계정으로 실행 해야 합니다. )

@echo off
if "%1"=="" (
    echo ------------------------------------------------------------------------
    echo Maria Database '백업 파일'이 없습니다.
    echo ------------------------------------------------------------------------
    echo 사용의 예
    echo 1. 백업은 관리자 계정으로 실행해야 합니다.
    echo 2. C:\Temp\Docker_Backup\ 폴더에 백업파일이 존재해야 합니다.
    echo    image 파일 : maria_20240824.tar
    echo    volume 파일 : maria_20240824_volume.tar
    echo 3. load-maria.bat maria_20240824

    goto :eof
)

:: Docker Volume 백업 경로 설정
:: Docker Container 명
set CONTAINER_NAME=maria_boot
:: 백업 파일의 위치 폴더
set BACKUP_DIR=C:\Temp\Docker_Backup
:: Volume 파일의 압축이 해제될 폴더
set VOLUME_DATA_PATH=C:\Temp\data\mariadb

if not exist "%BACKUP_DIR%\%1_volume.tar" (
    echo %BACKUP_DIR%\%1_volume.tar 파일이 존재하지 않습니다.
    goto :eof
)

if exist "%VOLUME_DATA_PATH%" (
    echo %VOLUME_DATA_PATH% 폴더를 삭제합니다.
    rmdir /S /Q %VOLUME_DATA_PATH%
    echo %VOLUME_DATA_PATH% 폴더를 생성합니다.
    mkdir %VOLUME_DATA_PATH%
) else (
    echo %VOLUME_DATA_PATH% 폴더를 생성합니다.
    mkdir %VOLUME_DATA_PATH%
)

:: Volume 파일 압축 풀기 
:: Docker Volume 파일명은 파라메터명 + "_volume" 이다.
:: tar xvf C:\Temp\Docker_Backup\maria_20240824_volume.tar -C C:\Temp\data\mariadb
tar xvf %BACKUP_DIR%\%1_volume.tar -C %VOLUME_DATA_PATH%
if %ERRORLEVEL% neq 0 (
    echo Docker 이미지 복원 실패
    exit /b 1
)

echo Docker 볼륨 복원 완료: %VOLUME_DATA_PATH%

echo 모든 복원이 완료되었습니다.

참고 : 백기선님의 스프링 부트 개념과 활용

 

 

 

 

728x90