Aracılığıyla paylaş


Spring Data R2DBC'i Azure SQL Veritabanı ile kullanma

Bu makalede, r2dbc-mssql GitHub deposundan Microsoft SQL Server için R2DBC uygulamasını kullanarak bilgileri Azure SQL Veritabanı depolamak ve almak için Spring Data R2DBC kullanan örnek bir uygulama oluşturma gösterilmektedir.

R2DBC, geleneksel ilişkisel veritabanları için reaktif API’ler sunar. Bunu Spring WebFlux ile birlikte kullanarak engelleyici olmayan API'ler kullanan tam reaktif Spring Boot uygulamaları oluşturabilirsiniz. Klasik "bağlantı başına bir iş parçacığı" yaklaşımından daha iyi ölçeklenebilirlik sağlar.

Önkoşullar

Örnek uygulamaya bakın

Bu makalede örnek bir uygulama kodlayacaksınız. Daha hızlı gitmek istiyorsanız, bu uygulama zaten kodlanmış ve adresinde https://github.com/Azure-Samples/quickstart-spring-data-r2dbc-sql-serverkullanılabilir.

Çalışma ortamını hazırlama

İlk olarak, aşağıdaki komutları kullanarak bazı ortam değişkenleri ayarlayalım:

export AZ_RESOURCE_GROUP=database-workshop
export AZ_DATABASE_NAME=<YOUR_DATABASE_NAME>
export AZ_LOCATION=<YOUR_AZURE_REGION>
export AZ_SQL_SERVER_ADMIN_USERNAME=spring
export AZ_SQL_SERVER_ADMIN_PASSWORD=<YOUR_AZURE_SQL_ADMIN_PASSWORD>
export AZ_SQL_SERVER_NON_ADMIN_USERNAME=nonspring
export AZ_SQL_SERVER_NON_ADMIN_PASSWORD=<YOUR_AZURE_SQL_NON_ADMIN_PASSWORD>
export AZ_LOCAL_IP_ADDRESS=<YOUR_LOCAL_IP_ADDRESS>

Yer tutucuları, bu makale boyunca kullanılan aşağıdaki değerlerle değiştirin:

  • <YOUR_DATABASE_NAME>: azure genelinde benzersiz olması gereken Azure SQL Veritabanı sunucunuzun adı.
  • <YOUR_AZURE_REGION>: Kullanacağınız Azure bölgesi. Varsayılan olarak eastus kullanabilirsiniz ancak bölgeyi, yaşadığınız yere yakın bir yerde yapılandırmanızı öneririz. kullanarak az account list-locationskullanılabilir bölgelerin tam listesini görebilirsiniz.
  • <AZ_SQL_SERVER_ADMIN_PASSWORD>ve <AZ_SQL_SERVER_NON_ADMIN_PASSWORD>: en az sekiz karakterden oluşan Azure SQL Veritabanı sunucunuzun parolası. Karakterler şu üç kategoriden olmalıdır: İngilizce büyük harfler, İngilizce küçük harfler, sayılar (0-9) ve alfasayısal olmayan karakterler (!, $, #, %, vb.).
  • <YOUR_LOCAL_IP_ADDRESS>: Spring Boot uygulamanızı çalıştırabileceğiniz yerel bilgisayarınızın IP adresi. Bunu bulmanın kullanışlı yollarından biri whatismyip.akamai.com açmaktır.

Not

Microsoft, kullanılabilir en güvenli kimlik doğrulama akışının kullanılmasını önerir. Veritabanları, önbellekler, mesajlaşma veya yapay zeka hizmetleri gibi bu yordamda açıklanan kimlik doğrulama akışı, uygulamaya çok yüksek düzeyde güven gerektirir ve diğer akışlarda mevcut olmayan riskler taşır. Bu akışı yalnızca parolasız veya anahtarsız bağlantılar için yönetilen kimlikler gibi daha güvenli seçenekler uygun olmadığında kullanın. Yerel makine işlemleri için parolasız veya anahtarsız bağlantılar için kullanıcı kimliklerini tercih edin.

Ardından, aşağıdaki komutu kullanarak bir kaynak grubu oluşturun:

az group create \
    --name $AZ_RESOURCE_GROUP \
    --location $AZ_LOCATION \
    --output tsv

Azure SQL Veritabanı örneği oluşturma

Ardından, aşağıdaki komutu çalıştırarak yönetilen Azure SQL Veritabanı sunucu örneği oluşturun.

Not

MS SQL parolasının belirli ölçütleri karşılaması gerekir ve kurulum uyumlu olmayan bir parolayla başarısız olur. Daha fazla bilgi için bkz . Parola İlkesi.

az sql server create \
    --resource-group $AZ_RESOURCE_GROUP \
    --name $AZ_DATABASE_NAME \
    --location $AZ_LOCATION \
    --admin-user $AZ_SQL_SERVER_ADMIN_USERNAME \
    --admin-password $AZ_SQL_SERVER_ADMIN_PASSWORD \
    --output tsv

Azure SQL Veritabanı sunucunuz için güvenlik duvarı kuralı yapılandırma

Azure SQL Veritabanı örnekleri varsayılan olarak güvenlidir. Gelen bağlantılara izin vermeyen bir güvenlik duvarı vardır. Veritabanınızı kullanabilmek için yerel IP adresinin veritabanı sunucusuna erişmesine izin veren bir güvenlik duvarı kuralı eklemeniz gerekir.

Bu makalenin başında yerel IP adresinizi yapılandırdığınızdan, aşağıdaki komutu çalıştırarak sunucunun güvenlik duvarını açabilirsiniz:

az sql server firewall-rule create \
    --resource-group $AZ_RESOURCE_GROUP \
    --name $AZ_DATABASE_NAME-database-allow-local-ip \
    --server $AZ_DATABASE_NAME \
    --start-ip-address $AZ_LOCAL_IP_ADDRESS \
    --end-ip-address $AZ_LOCAL_IP_ADDRESS \
    --output tsv

Bir Windows bilgisayarda Linux için Windows Alt Sistemi 'den (WSL) Azure SQL Veritabanı sunucunuza bağlanıyorsanız, WSL ana bilgisayar kimliğini güvenlik duvarınıza eklemeniz gerekir.

WSL'de aşağıdaki komutu çalıştırarak konak makinenizin IP adresini alın:

cat /etc/resolv.conf

teriminden nameserversonra IP adresini kopyalayın ve WSL IP Adresi için bir ortam değişkeni ayarlamak üzere aşağıdaki komutu kullanın:

export AZ_WSL_IP_ADDRESS=<the-copied-IP-address>

Ardından aşağıdaki komutu kullanarak sunucunun güvenlik duvarını WSL tabanlı uygulamanızda açın:


az sql server firewall-rule create \
    --resource-group $AZ_RESOURCE_GROUP \
    --name $AZ_DATABASE_NAME-database-allow-local-ip-wsl \
    --server $AZ_DATABASE_NAME \
    --start-ip-address $AZ_WSL_IP_ADDRESS \
    --end-ip-address $AZ_WSL_IP_ADDRESS \
    --output tsv

Azure SQL veritabanı yapılandırma

Daha önce oluşturduğunuz Azure SQL Veritabanı sunucusu boş. Spring Boot uygulamasıyla birlikte kullanabileceğiniz bir veritabanı içermez. Aşağıdaki komutu çalıştırarak adlı demo yeni bir veritabanı oluşturun:

az sql db create \
    --resource-group $AZ_RESOURCE_GROUP \
    --name demo \
    --server $AZ_DATABASE_NAME \
    --output tsv

Sql veritabanı yönetici olmayan kullanıcı oluşturma ve izin verme

Bu adım yönetici olmayan bir kullanıcı oluşturur ve veritabanındaki demo tüm izinleri ona verir.

Yönetici olmayan kullanıcı oluşturmak için create_user.sql adlı bir SQL betiği oluşturun. Aşağıdaki içeriği ekleyin ve yerel olarak kaydedin:

Not

Microsoft, kullanılabilir en güvenli kimlik doğrulama akışının kullanılmasını önerir. Veritabanları, önbellekler, mesajlaşma veya yapay zeka hizmetleri gibi bu yordamda açıklanan kimlik doğrulama akışı, uygulamaya çok yüksek düzeyde güven gerektirir ve diğer akışlarda mevcut olmayan riskler taşır. Bu akışı yalnızca parolasız veya anahtarsız bağlantılar için yönetilen kimlikler gibi daha güvenli seçenekler uygun olmadığında kullanın. Yerel makine işlemleri için parolasız veya anahtarsız bağlantılar için kullanıcı kimliklerini tercih edin.

cat << EOF > create_user.sql
USE demo;
GO
CREATE USER $AZ_SQL_SERVER_NON_ADMIN_USERNAME WITH PASSWORD='$AZ_SQL_SERVER_NON_ADMIN_PASSWORD'
GO
GRANT CONTROL ON DATABASE::demo TO $AZ_SQL_SERVER_NON_ADMIN_USERNAME;
GO
EOF

Ardından, yönetici olmayan kullanıcıyı oluşturmak üzere SQL betiğini çalıştırmak için aşağıdaki komutu kullanın:

sqlcmd -S $AZ_DATABASE_NAME.database.windows.net,1433  -d demo -U $AZ_SQL_SERVER_ADMIN_USERNAME -P $AZ_SQL_SERVER_ADMIN_PASSWORD  -i create_user.sql

Not

SQL veritabanı kullanıcıları oluşturma hakkında daha fazla bilgi için bkz . CREATE USER (Transact-SQL).


Reaktif bir Spring Boot uygulaması oluşturma

Reaktif bir Spring Boot uygulaması oluşturmak için Spring Initializr kullanacağız. Oluşturacağımız uygulama aşağıdakileri kullanır:

  • Spring Boot 2.7.11.
  • Aşağıdaki bağımlılıklar: Spring Reactive Web (Spring WebFlux olarak da bilinir) ve Spring Data R2DBC.

Spring Initializr’ı kullanarak uygulama oluşturma

Aşağıdaki komutu çalıştırarak komut satırında uygulamayı oluşturun:

curl https://start.spring.io/starter.tgz -d dependencies=webflux,data-r2dbc -d baseDir=azure-database-workshop -d bootVersion=2.7.11 -d javaVersion=17 | tar -xzvf -

Reaktif Azure SQL Veritabanı sürücü uygulamasını ekleme

r2dbc-mssql GitHub deposundan reaktif Azure SQL Veritabanı sürücüsünü eklemek için oluşturulan projenin pom.xml dosyasını açın.

Bağımlılık sonrasında spring-boot-starter-webflux aşağıdaki metni ekleyin:

<dependency>
    <groupId>io.r2dbc</groupId>
    <artifactId>r2dbc-mssql</artifactId>
    <scope>runtime</scope>
</dependency>

Spring Boot'ı Azure SQL Veritabanı kullanacak şekilde yapılandırma

src/main/resources/application.properties dosyasını açın ve aşağıdaki metni ekleyin:

logging.level.org.springframework.data.r2dbc=DEBUG

spring.r2dbc.url=r2dbc:pool:mssql://$AZ_DATABASE_NAME.database.windows.net:1433/demo
spring.r2dbc.username=nonspring@$AZ_DATABASE_NAME
spring.r2dbc.password=$AZ_SQL_SERVER_NON_ADMIN_PASSWORD

İki $AZ_DATABASE_NAME değişkeni ve değişkenini $AZ_SQL_SERVER_NON_ADMIN_PASSWORD bu makalenin başında yapılandırdığınız değerlerle değiştirin.

Not

Daha iyi performans için özelliği r2dbc-pool spring.r2dbc.url kullanarak bir bağlantı havuzu kullanacak şekilde yapılandırılır.

Artık sağlanan Maven sarmalayıcısını kullanarak uygulamanızı şu şekilde başlatabilmeniz gerekir:

./mvnw spring-boot:run

İlk kez çalışan bir uygulamanın ekran görüntüsü aşağıda verilmiştir:

Çalışan uygulamanın ekran görüntüsü.

Veritabanı şemasını oluşturma

Ana DemoApplication sınıfın içinde, aşağıdaki kodu kullanarak veritabanı şeması oluşturacak yeni bir Spring çekirdeği yapılandırın:

package com.example.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean;
import org.springframework.core.io.ClassPathResource;
import org.springframework.data.r2dbc.connectionfactory.init.ConnectionFactoryInitializer;
import org.springframework.data.r2dbc.connectionfactory.init.ResourceDatabasePopulator;

import io.r2dbc.spi.ConnectionFactory;

@SpringBootApplication
public class DemoApplication {

    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }

    @Bean
    public ConnectionFactoryInitializer initializer(ConnectionFactory connectionFactory) {
        ConnectionFactoryInitializer initializer = new ConnectionFactoryInitializer();
        initializer.setConnectionFactory(connectionFactory);
        ResourceDatabasePopulator populator = new ResourceDatabasePopulator(new ClassPathResource("schema.sql"));
        initializer.setDatabasePopulator(populator);
        return initializer;
    }
}

Bu Spring fasulyesi schema.sql adlı bir dosya kullandığından src/main/resources klasöründe bu dosyayı oluşturun ve aşağıdaki metni ekleyin:

DROP TABLE IF EXISTS todo;
CREATE TABLE todo (id INT IDENTITY PRIMARY KEY, description VARCHAR(255), details VARCHAR(4096), done BIT);

Çalışan uygulamayı durdurun ve aşağıdaki komutu kullanarak yeniden başlatın. Uygulama artık önceden oluşturduğunuz demo veritabanını kullanır ve bunun içinde bir todo tablosu oluşturur.

./mvnw spring-boot:run

Veritabanı tablosunun oluşturulurken ekran görüntüsü aşağıdadır:

Veritabanı tablosunun oluşturulmasının ekran görüntüsü.

Uygulamayı kodlama

Ardından, Azure SQL Veritabanı sunucunuzda verileri depolamak ve almak için R2DBC'yi kullanacak Java kodunu ekleyin.

Aşağıdaki kodu kullanarak sınıfının yanında DemoApplication yeni Todo bir Java sınıfı oluşturun:

package com.example.demo;

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;

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getDescription() {
        return description;
    }

    public void setDescription(String description) {
        this.description = description;
    }

    public String getDetails() {
        return details;
    }

    public void setDetails(String details) {
        this.details = details;
    }

    public boolean isDone() {
        return done;
    }

    public void setDone(boolean done) {
        this.done = done;
    }
}

Bu sınıf, önceden oluşturduğunuz todo tablosunda eşlenmiş olan bir etki alanı modelidir.

Bu sınıfı yönetmek için bir depoya ihtiyacınız vardır. Aşağıdaki kodu kullanarak aynı pakette yeni TodoRepository bir arabirim tanımlayın:

package com.example.demo;

import org.springframework.data.repository.reactive.ReactiveCrudRepository;

public interface TodoRepository extends ReactiveCrudRepository<Todo, Long> {
}

Bu depo, Spring Data R2DBC'nin yönettiği reaktif bir depodur.

Verileri depolayıp alabilen bir denetleyici oluşturarak uygulamayı tamamlayın. Aynı pakette bir TodoController sınıfı uygulayın ve aşağıdaki kodu ekleyin:

package com.example.demo;

import org.springframework.http.HttpStatus;
import org.springframework.web.bind.annotation.*;
import reactor.core.publisher.Flux;
import reactor.core.publisher.Mono;

@RestController
@RequestMapping("/")
public class TodoController {

    private final TodoRepository todoRepository;

    public TodoController(TodoRepository todoRepository) {
        this.todoRepository = todoRepository;
    }

    @PostMapping("/")
    @ResponseStatus(HttpStatus.CREATED)
    public Mono<Todo> createTodo(@RequestBody Todo todo) {
        return todoRepository.save(todo);
    }

    @GetMapping("/")
    public Flux<Todo> getTodos() {
        return todoRepository.findAll();
    }
}

Son olarak, uygulamayı durdurun ve aşağıdaki komutu kullanarak yeniden başlatın:

./mvnw spring-boot:run

Uygulamayı test etme

Uygulamayı test etmek için cURL’yi kullanabilirsiniz.

İlk olarak, aşağıdaki komutu kullanarak veritabanında yeni bir “yapılacak” öğesi oluşturun:

curl --header "Content-Type: application/json" \
    --request POST \
    --data '{"description":"configuration","details":"congratulations, you have set up R2DBC correctly!","done": "true"}' \
    http://127.0.0.1:8080

Bu komut, burada gösterildiği gibi oluşturulan öğeyi döndürmelidir:

{"id":1,"description":"configuration","details":"congratulations, you have set up R2DBC correctly!","done":true}

Ardından, aşağıdaki komutla yeni bir cURL isteği kullanarak verileri alın:

curl http://127.0.0.1:8080

Bu komut, burada gösterildiği gibi oluşturduğunuz öğe de dahil olmak üzere "yapılacaklar" öğelerinin listesini döndürür:

[{"id":1,"description":"configuration","details":"congratulations, you have set up R2DBC correctly!","done":true}]

Bu cURL isteklerinin ekran görüntüsü aşağıdadır:

cURL testinin ekran görüntüsü.

Tebrikler! Azure SQL Veritabanı verileri depolamak ve almak için R2DBC kullanan tam olarak reaktif bir Spring Boot uygulaması oluşturdunuz.

Kaynakları temizleme

Bu hızlı başlangıç sırasında kullanılan tüm kaynakları temizlemek için aşağıdaki komutu kullanarak kaynak grubunu silin:

az group delete \
    --name $AZ_RESOURCE_GROUP \
    --yes

Sonraki adımlar

Spring Data uygulamasını Azure Spring Apps'e dağıtma ve yönetilen kimlik kullanma hakkında daha fazla bilgi edinmek için bkz . Öğretici: Azure veritabanına parolasız bağlantıyla Azure Spring Apps'e Spring uygulaması dağıtma.

Spring ve Azure hakkında daha fazlasını öğrenmek için Azure’da Spring belge merkezinde çalışmaya devam edin.

Ayrıca bkz.

Spring Data R2DBC hakkında daha fazla bilgi için Spring'in başvuru belgelerine bakın.

Azure’ı Java ile kullanma hakkında daha fazla bilgi için Java geliştiricileri için Azure ve Azure DevOps ve Java ile çalışma başlıklı makalelere bakın.