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
Azure aboneliği - ücretsiz bir abonelik oluşturun.
Java Development Kit (JDK), sürüm 8 veya üzeri.
cURL veya işlevselliği test etmek için benzer bir HTTP yardımcı programı.
Ö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 olarakeastus
kullanabilirsiniz ancak bölgeyi, yaşadığınız yere yakın bir yerde yapılandırmanızı öneririz. kullanarakaz account list-locations
kullanı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 nameserver
sonra 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:
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:
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:
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.