Azure Database for PostgreSQL에서 Spring Data JDBC 사용
이 자습서에서는 Spring Data JDBC를 사용하여 Azure Database for PostgreSQL 데이터베이스에 데이터를 저장하는 방법을 보여 줍니다.
JDBC 는 기존 관계형 데이터베이스에 연결하는 표준 Java API입니다.
이 자습서에는 Microsoft Entra 인증 및 PostgreSQL 인증이라는 두 가지 인증 방법이 포함되어 있습니다. 암호 없음 탭에는 Microsoft Entra 인증이 표시되고 암호 탭에는 PostgreSQL 인증이 표시됩니다.
Microsoft Entra 인증은 Microsoft Entra ID에 정의된 ID를 사용하여 Azure Database for PostgreSQL에 연결하기 위한 메커니즘입니다. Microsoft Entra 인증을 사용하면 중앙 위치에서 데이터베이스 사용자 ID 및 기타 Microsoft 서비스를 관리할 수 있으므로 권한 관리가 간소화됩니다.
PostgreSQL 인증은 PostgreSQL에 저장된 계정을 사용합니다. 암호를 계정의 자격 증명으로 사용하도록 선택한 경우 이러한 자격 증명은 user
테이블에 저장됩니다. 이러한 암호는 PostgreSQL에 저장되기 때문에 암호 회전을 직접 관리해야 합니다.
필수 조건
Azure 구독 - 체험 구독 만들기
JDK(Java Development Kit), 버전 8 이상.
Spring Boot 애플리케이션이 없는 경우 Spring Initializr를 사용하여 Maven 프로젝트를 만듭니다. Maven 프로젝트를 선택하고 종속성 아래에서 Spring Web, Spring Data JDBC 및 PostgreSQL 드라이버 종속성을 추가한 다음 Java 버전 8 이상을 선택합니다.
- 없는 경우 Azure Database for PostgreSQL 유연한 서버 인스턴스와 이름이 지정된
postgresqlflexibletest
demo
데이터베이스를 만듭니다. 지침은 빠른 시작: Azure Portal에서 Azure Database for PostgreSQL - 유연한 서버 만들기를 참조하세요.
샘플 애플리케이션 참조
이 자습서에서는 샘플 애플리케이션을 코딩합니다. 더 빠르게 이동하려는 경우 이 애플리케이션은 이미 코딩되어 있습니다 https://github.com/Azure-Samples/quickstart-spring-data-jdbc-postgresql.
PostgreSQL 서버에 대한 방화벽 규칙 구성
Azure Database for PostgreSQL 인스턴스는 기본적으로 보호됩니다. 들어오는 연결을 허용하지 않는 방화벽이 있습니다.
데이터베이스를 사용하려면 서버의 방화벽을 열어 로컬 IP 주소가 데이터베이스 서버에 액세스할 수 있도록 합니다. 자세한 내용은 Azure Database for PostgreSQL - 유연한 서버의 방화벽 규칙을 참조 하세요.
Windows 컴퓨터의 WSL(Linux용 Windows 하위 시스템)에서 PostgreSQL 서버에 연결하는 경우 방화벽에 WSL 호스트 ID를 추가해야 합니다.
PostgreSQL 비관리 사용자 만들기 및 권한 부여
그런 다음 관리 사용자가 아닌 사용자를 만들고 데이터베이스에 대한 모든 권한을 부여합니다.
다음 방법을 사용하여 암호 없는 연결을 사용하는 관리자가 아닌 사용자를 만들 수 있습니다.
다음 명령을 사용하여 Azure CLI에 대한 Service Connector 암호 없는 확장을 설치합니다.
az extension add --name serviceconnector-passwordless --upgrade
다음 명령을 사용하여 관리자가 아닌 Microsoft Entra 사용자를 만듭니다.
az connection create postgres-flexible \ --resource-group <your_resource_group_name> \ --connection postgres_conn \ --target-resource-group <your_resource_group_name> \ --server postgresqlflexibletest \ --database demo \ --user-account \ --query authInfo.userName \ --output tsv
명령이 완료되면 콘솔 출력의 사용자 이름을 기록해 둡니다.
Azure Database for PostgreSQL에서 데이터 저장
이제 Azure Database for PostgreSQL 유연한 서버 인스턴스가 있으므로 Spring Cloud Azure를 사용하여 데이터를 저장할 수 있습니다.
Spring Cloud Azure Starter JDBC PostgreSQL 모듈을 설치하려면 pom.xml 파일에 다음 종속성을 추가합니다.
Spring Cloud AZURE BOM(청구서)
<dependencyManagement> <dependencies> <dependency> <groupId>com.azure.spring</groupId> <artifactId>spring-cloud-azure-dependencies</artifactId> <version>5.19.0</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>
참고 항목
Spring Boot 2.x를 사용하는 경우 버전을 .로 설정
spring-cloud-azure-dependencies
해야 합니다4.19.0
. 이 BOM(청구서)은 pom.xml 파일의 섹션에서 구성<dependencyManagement>
해야 합니다. 이렇게 하면 모든 Spring Cloud Azure 종속성이 동일한 버전을 사용합니다. 이 BOM에 사용되는 버전에 대한 자세한 내용은 어떤 버전의 Spring Cloud Azure를 사용해야 하는지를 참조하세요.Spring Cloud Azure Starter JDBC PostgreSQL 아티팩트:
<dependency> <groupId>com.azure.spring</groupId> <artifactId>spring-cloud-azure-starter-jdbc-postgresql</artifactId> </dependency>
참고 항목
버전 4.5.0
이후 암호 없는 연결이 지원되었습니다.
Azure Database for PostgreSQL을 사용하도록 Spring Boot 구성
Spring Data JDBC를 사용하여 Azure Database for PostgreSQL의 데이터를 저장하려면 다음 단계에 따라 애플리케이션을 구성합니다.
application.properties 구성 파일에 다음 속성을 추가하여 Azure Database for PostgreSQL 자격 증명을 구성합니다.
logging.level.org.springframework.jdbc.core=DEBUG spring.datasource.url=jdbc:postgresql://postgresqlflexibletest.postgres.database.azure.com:5432/demo?sslmode=require spring.datasource.username=<your_postgresql_ad_non_admin_username> spring.datasource.azure.passwordless-enabled=true spring.sql.init.mode=always
Warning
구성 속성
spring.sql.init.mode=always
은 Spring Boot가 서버가 시작될 때마다 다음에 만들 schema.sql 파일을 사용하여 데이터베이스 스키마를 자동으로 생성한다는 것을 의미합니다. 이 기능은 테스트에 적합하지만 다시 시작할 때마다 데이터가 삭제되므로 프로덕션 환경에서는 사용하지 않아야 합니다.
- 없는 경우 이름이 지정된
postgresqlsingletest
Azure Database for PostgreSQL 단일 서버 인스턴스와 이름이 지정된demo
데이터베이스를 만듭니다. 지침은 빠른 시작: Azure Portal을 사용하여 Azure Database for PostgreSQL 서버 만들기를 참조하세요.
샘플 애플리케이션 참조
이 문서에서는 샘플 애플리케이션을 코딩합니다. 더 빠르게 이동하려는 경우 이 애플리케이션은 이미 코딩되어 있습니다 https://github.com/Azure-Samples/quickstart-spring-data-jdbc-postgresql.
PostgreSQL 서버에 대한 방화벽 규칙 구성
Azure Database for PostgreSQL 인스턴스는 기본적으로 보호됩니다. 들어오는 연결을 허용하지 않는 방화벽이 있습니다.
데이터베이스를 사용하려면 서버의 방화벽을 열어 로컬 IP 주소가 데이터베이스 서버에 액세스할 수 있도록 합니다. 자세한 내용은 Azure Portal을 사용하여 Azure Database for PostgreSQL - 단일 서버에 대한 방화벽 규칙 만들기 및 관리를 참조하세요.
Windows 컴퓨터의 WSL(Linux용 Windows 하위 시스템)에서 PostgreSQL 서버에 연결하는 경우 방화벽에 WSL 호스트 ID를 추가해야 합니다.
PostgreSQL 비관리 사용자 만들기 및 권한 부여
그런 다음 관리 사용자가 아닌 사용자를 만들고 데이터베이스에 대한 모든 권한을 부여합니다.
다음 방법을 사용하여 암호 없는 연결을 사용하는 관리자가 아닌 사용자를 만들 수 있습니다.
다음 명령을 사용하여 Azure CLI에 대한 Service Connector 암호 없는 확장을 설치합니다.
az extension add --name serviceconnector-passwordless --upgrade
다음 명령을 사용하여 관리자가 아닌 Microsoft Entra 사용자를 만듭니다.
az connection create postgres \ --resource-group <your_resource_group_name> \ --connection postgres_conn \ --target-resource-group <your_resource_group_name> \ --server postgresqlsingletest \ --database demo \ --user-account \ --query authInfo.userName \ --output tsv
명령이 완료되면 콘솔 출력의 사용자 이름을 기록해 둡니다.
Azure Database for PostgreSQL에서 데이터 저장
이제 Azure Database for PostgreSQL 단일 서버 인스턴스가 있으므로 Spring Cloud Azure를 사용하여 데이터를 저장할 수 있습니다.
Spring Cloud Azure Starter JDBC PostgreSQL 모듈을 설치하려면 pom.xml 파일에 다음 종속성을 추가합니다.
Spring Cloud AZURE BOM(청구서)
<dependencyManagement> <dependencies> <dependency> <groupId>com.azure.spring</groupId> <artifactId>spring-cloud-azure-dependencies</artifactId> <version>5.19.0</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>
참고 항목
Spring Boot 2.x를 사용하는 경우 버전을 .로 설정
spring-cloud-azure-dependencies
해야 합니다4.19.0
. 이 BOM(청구서)은 pom.xml 파일의 섹션에서 구성<dependencyManagement>
해야 합니다. 이렇게 하면 모든 Spring Cloud Azure 종속성이 동일한 버전을 사용합니다. 이 BOM에 사용되는 버전에 대한 자세한 내용은 어떤 버전의 Spring Cloud Azure를 사용해야 하는지를 참조하세요.Spring Cloud Azure Starter JDBC PostgreSQL 아티팩트:
<dependency> <groupId>com.azure.spring</groupId> <artifactId>spring-cloud-azure-starter-jdbc-postgresql</artifactId> </dependency>
참고 항목
버전 4.5.0
이후 암호 없는 연결이 지원되었습니다.
Azure Database for PostgreSQL을 사용하도록 Spring Boot 구성
Spring Data JDBC를 사용하여 Azure Database for PostgreSQL의 데이터를 저장하려면 다음 단계에 따라 애플리케이션을 구성합니다.
application.properties 구성 파일에 다음 속성을 추가하여 Azure Database for PostgreSQL 자격 증명을 구성합니다.
logging.level.org.springframework.jdbc.core=DEBUG spring.datasource.url=jdbc:postgresql://postgresqlsingletest.postgres.database.azure.com:5432/demo?sslmode=require spring.datasource.username=<your_postgresql_ad_non_admin_username>@postgresqlsingletest spring.datasource.azure.passwordless-enabled=true spring.sql.init.mode=always
Warning
구성 속성
spring.sql.init.mode=always
은 Spring Boot가 서버가 시작될 때마다 다음에 만들 schema.sql 파일을 사용하여 데이터베이스 스키마를 자동으로 생성한다는 것을 의미합니다. 이 기능은 테스트에 적합하지만 다시 시작할 때마다 데이터가 삭제되므로 프로덕션 환경에서는 사용하지 않아야 합니다.
src/main/resources/schema.sql 구성 파일을 만들어 데이터베이스 스키마를 구성한 다음, 다음 내용을 추가합니다.
DROP TABLE IF EXISTS todo; CREATE TABLE todo (id SERIAL PRIMARY KEY, description VARCHAR(255), details VARCHAR(4096), done BOOLEAN);
새
Todo
Java 클래스를 만듭니다. 이 클래스는 Spring Boot에서todo
자동으로 만들어지는 테이블에 매핑된 도메인 모델입니다. 다음 코드는 해당 및setters
메서드를getters
무시합니다.import org.springframework.data.annotation.Id; public class Todo { public Todo() { } public Todo(String description, String details, boolean done) { this.description = description; this.details = details; this.done = done; } @Id private Long id; private String description; private String details; private boolean done; }
시작 클래스 파일을 편집하여 다음 콘텐츠를 표시합니다.
import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.boot.context.event.ApplicationReadyEvent; import org.springframework.context.ApplicationListener; import org.springframework.context.annotation.Bean; import org.springframework.data.repository.CrudRepository; import java.util.stream.Stream; @SpringBootApplication public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } @Bean ApplicationListener<ApplicationReadyEvent> basicsApplicationListener(TodoRepository repository) { return event->repository .saveAll(Stream.of("A", "B", "C").map(name->new Todo("configuration", "congratulations, you have set up correctly!", true)).toList()) .forEach(System.out::println); } } interface TodoRepository extends CrudRepository<Todo, Long> { }
팁
이 자습서에서는 구성 또는 코드에 인증 작업이 없습니다. 그러나 Azure 서비스에 연결하려면 인증이 필요합니다. 인증을 완료하려면 Azure ID를 사용해야 합니다. Spring Cloud Azure는 코드 변경 없이 자격 증명을 가져오는 데 도움이 되는 Azure ID 라이브러리를 사용합니다
DefaultAzureCredential
.DefaultAzureCredential
은 여러 인증 방법을 지원하고 런타임에 사용할 방법을 결정합니다. 이 방법을 사용하면 앱이 환경별 코드를 구현하지 않고도 다양한 환경(예: 로컬 및 프로덕션 환경)에서 다양한 인증 방법을 사용할 수 있습니다. 자세한 내용은 DefaultAzureCredential을 참조 하세요.로컬 개발 환경에서 인증을 완료하려면 Azure CLI, Visual Studio Code, PowerShell 또는 기타 방법을 사용할 수 있습니다. 자세한 내용은 Java 개발 환경에서 Azure 인증을 참조 하세요. Azure 호스팅 환경에서 인증을 완료하려면 사용자 할당 관리 ID를 사용하는 것이 좋습니다. 자세한 내용은 Azure 리소스에 대한 관리 ID란?을 참조하세요.
애플리케이션을 시작합니다. 애플리케이션은 데이터베이스에 데이터를 저장합니다. 다음 예제와 유사한 로그가 표시됩니다.
2023-02-01 10:22:36.701 DEBUG 7948 --- [main] o.s.jdbc.core.JdbcTemplate : Executing prepared SQL statement [INSERT INTO todo (description, details, done) VALUES (?, ?, ?)] com.example.demo.Todo@4bdb04c8
Azure Spring Apps에 배포
이제 Spring Boot 애플리케이션을 로컬로 실행했으므로 이제 프로덕션으로 이동해야 합니다. Azure Spring Apps 를 사용하면 코드를 변경하지 않고도 Spring Boot 애플리케이션을 Azure에 쉽게 배포할 수 있습니다. 이 서비스는 개발자가 코드에 집중할 수 있도록 Spring 애플리케이션의 인프라를 관리합니다. Azure Spring Apps는 포괄적인 모니터링 및 진단, 구성 관리, 서비스 검색, CI/CD 통합, 파란색-녹색 배포 등을 사용하여 수명 주기 관리를 제공합니다. Azure Spring Apps에 애플리케이션을 배포하려면 Azure Spring Apps에 첫 번째 애플리케이션 배포를 참조하세요.