Поставщик EF Core для Azure Cosmos DB
Предупреждение
Обширная работа прошла в поставщике Azure Cosmos DB в версии 9.0. Для улучшения поставщика необходимо вносить ряд критически важных изменений; Если вы обновляете существующее приложение, внимательно ознакомьтесь с разделом критических изменений.
Этот поставщик базы данных позволяет использовать Entity Framework Core с Azure Cosmos DB. Работы над этим поставщиком ведутся в рамках проекта Entity Framework Core.
Перед чтением этого раздела мы настоятельно рекомендуем ознакомиться с документацией по Azure Cosmos DB.
Примечание.
Этот поставщик работает только с Azure Cosmos DB для NoSQL.
Установка
Установите пакет NuGet Microsoft.EntityFrameworkCore.Cosmos.
dotnet add package Microsoft.EntityFrameworkCore.Cosmos
Начало работы
Совет
Вы можете скачать используемый в этой статье пример из репозитория GitHub.
Как и для других поставщиков, сначала нужно вызвать UseCosmos.
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
=> optionsBuilder.UseCosmos(
"https://localhost:8081",
"C2y6yDjf5/R+ob0N8A7Cgv30VRDJIWEHLM+4QDU5DE2nQ9nDuVTqobD4b8mGGyPMbIZnqyMsEcaGQy67XIw/Jw==",
databaseName: "OrdersDB");
Предупреждение
Для простоты конечная точка и ключ здесь заданы в коде, но в рабочем приложении необходимо обеспечить их безопасное хранение. Сведения о подключении и проверке подлинности различных способов подключения к Azure Cosmos DB.
В этом примере Order
представляет собой простую сущность, ссылающуюся на StreetAddress
зависимого типа.
public class Order
{
public int Id { get; set; }
public int? TrackingNumber { get; set; }
public string PartitionKey { get; set; }
public StreetAddress ShippingAddress { get; set; }
}
public class StreetAddress
{
public string Street { get; set; }
public string City { get; set; }
}
Сохранение данных и запрос на их получение выполняется, как обычно в EF:
using (var context = new OrderContext())
{
await context.Database.EnsureDeletedAsync();
await context.Database.EnsureCreatedAsync();
context.Add(
new Order
{
Id = 1, ShippingAddress = new StreetAddress { City = "London", Street = "221 B Baker St" }, PartitionKey = "1"
});
await context.SaveChangesAsync();
}
using (var context = new OrderContext())
{
var order = await context.Orders.FirstAsync();
Console.WriteLine($"First order will ship to: {order.ShippingAddress.Street}, {order.ShippingAddress.City}");
Console.WriteLine();
}
Внимание
Путем вызова EnsureCreatedAsync вы создадите требуемые контейнеры и вставите начальные данные, если они есть в модели. Но EnsureCreatedAsync
следует вызывать только во время развертывания, а не в рабочем режиме, так как это может вызвать проблемы с производительностью.
Пакет SDK Azure Cosmos DB не поддерживает RBAC для операций плоскости управления в Azure Cosmos DB. Используйте API управления Azure вместо EnsureCreatedAsync с RBAC.
Подключение и проверка подлинности
Поставщик Azure Cosmos DB для EF Core имеет несколько перегрузок метода UseCosmos . Эти перегрузки поддерживают различные способы подключения к базе данных и различные способы обеспечения безопасности подключения.
Внимание
Обязательно понять безопасный доступ к данным в Azure Cosmos DB, чтобы понять последствия безопасности и рекомендации по использованию каждой перегрузки UseCosmos
метода.
Как правило, RBAC с учетными данными токена — это рекомендуемый механизм управления доступом.
Механизм подключения | Перегрузка UseCosmos | Дополнительные сведения |
---|---|---|
Конечная точка и ключ учетной записи | UseCosmos<DbContext>(accountEndpoint, accountKey, databaseName) |
Первичные/вторичные ключи |
Конечная точка и маркер учетной записи | UseCosmos<DbContext>(accountEndpoint, tokenCredential, databaseName) |
RBAC и маркеры ресурсов |
Connection string | UseCosmos<DbContext>(connectionString, databaseName) |
Работа с ключами учетной записи и строка подключения |
Параметры Azure Cosmos DB
Также можно настроить поставщик Azure Cosmos DB с одним строка подключения и указать другие параметры настройки подключения:
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
=> optionsBuilder.UseCosmos(
"AccountEndpoint=https://localhost:8081/;AccountKey=C2y6yDjf5/R+ob0N8A7Cgv30VRDJIWEHLM+4QDU5DE2nQ9nDuVTqobD4b8mGGyPMbIZnqyMsEcaGQy67XIw/Jw==",
databaseName: "OptionsDB",
options =>
{
options.ConnectionMode(ConnectionMode.Gateway);
options.WebProxy(new WebProxy());
options.LimitToEndpoint();
options.Region(Regions.AustraliaCentral);
options.GatewayModeMaxConnectionLimit(32);
options.MaxRequestsPerTcpConnection(8);
options.MaxTcpConnectionsPerEndpoint(16);
options.IdleTcpConnectionTimeout(TimeSpan.FromMinutes(1));
options.OpenTcpConnectionTimeout(TimeSpan.FromMinutes(1));
options.RequestTimeout(TimeSpan.FromMinutes(1));
});
Приведенный выше код показывает некоторые возможные параметры. Они не предназначены для одновременного использования. Подробное описание каждого из указанных выше параметров см. в документации по параметрам Azure Cosmos DB.