Я написал инструмент для обновления нескольких баз данных в рамках нашего конвейера DEVOPS CI/CD. Этот инструмент работает без проблем.
Мы переносим хост-платформы для нашего продукта SaaS, и в рамках этого я хочу изменить режим восстановления наших баз данных MS SQL. При этом менять режим восстановления на старой платформе не хочется.
Режим восстановления в файлах DACPAC установлен на SIMPLE. На новой целевой платформе я хочу, чтобы она была ПОЛНОЙ.
Насколько я понимаю, я смогу сделать это, установив:
< blockquote>
ScriptDatabaseOptions = false
Этот параметр игнорируется во время развертывания. Если я установлю для целевой базы данных режим ПОЛНОГО восстановления в Management Studio, после развертывания DACPAC с ScriptDatabaseOptions = false, режим восстановления вернется к ПРОСТОМУ.
Я знаю, что могу взломать DACPAC и изменить свойство RecoveryMode как часть конвейера DEVOPS, но это будет затруднительно, поскольку у нас много конвейеров и этапов.
Как заставить развертывание правильно игнорировать режим восстановления? ?
using Microsoft.Data.SqlClient;
using Microsoft.SqlServer.Dac;
public void ProcessDacpac(string dacpacFile)
{
foreach (var sqlConnectionString in sqlConnectionStrings)
{
Logger.LogToFile($"Start DacPackage Deploy for: {sqlConnectionString.Key}",Logger.LogCondition.Verbose);
//check if server and database is online
Logger.LogToFile($"Testing Connection For: {sqlConnectionString.Key}",Logger.LogCondition.Verbose);
if (!IsServerAndDatabaseOnline(sqlConnectionString.Value))
{
Logger.LogToFile($"Connection Failed: {sqlConnectionString.Key}", Logger.LogCondition.Critical);
continue;
}
else
{
Logger.LogToFile($"Testing Connection For: {sqlConnectionString.Key} Success", Logger.LogCondition.Verbose);
}
var services = new Microsoft.SqlServer.Dac.DacServices(sqlConnectionString.Value);
services.Message += (object sender, Microsoft.SqlServer.Dac.DacMessageEventArgs eventArgs) => Logger.LogToFile(eventArgs.Message.Message, Logger.LogCondition.Verbose);
var dacpac = DacPackage.Load(dacpacFile);
//publish options
var dacDeployOptions = new DacDeployOptions()
{
ScriptDatabaseOptions = false, //
Подробнее здесь: https://stackoverflow.com/questions/791 ... deployment
Параметр DacDeploy ScriptDatabaseOptions игнорируется во время развертывания. ⇐ C#
Место общения программистов C#
1729682301
Anonymous
Я написал инструмент для обновления нескольких баз данных в рамках нашего конвейера DEVOPS CI/CD. Этот инструмент работает без проблем.
Мы переносим хост-платформы для нашего продукта SaaS, и в рамках этого я хочу изменить режим восстановления наших баз данных MS SQL. При этом менять режим восстановления на старой платформе не хочется.
Режим восстановления в файлах DACPAC установлен на SIMPLE. На новой целевой платформе я хочу, чтобы она была ПОЛНОЙ.
Насколько я понимаю, я смогу сделать это, установив:
< blockquote>
ScriptDatabaseOptions = false
Этот параметр игнорируется во время развертывания. Если я установлю для целевой базы данных режим ПОЛНОГО восстановления в Management Studio, после развертывания DACPAC с ScriptDatabaseOptions = false, режим восстановления вернется к ПРОСТОМУ.
Я знаю, что могу взломать DACPAC и изменить свойство RecoveryMode как часть конвейера DEVOPS, но это будет затруднительно, поскольку у нас много конвейеров и этапов.
Как заставить развертывание правильно игнорировать режим восстановления? ?
using Microsoft.Data.SqlClient;
using Microsoft.SqlServer.Dac;
public void ProcessDacpac(string dacpacFile)
{
foreach (var sqlConnectionString in sqlConnectionStrings)
{
Logger.LogToFile($"Start DacPackage Deploy for: {sqlConnectionString.Key}",Logger.LogCondition.Verbose);
//check if server and database is online
Logger.LogToFile($"Testing Connection For: {sqlConnectionString.Key}",Logger.LogCondition.Verbose);
if (!IsServerAndDatabaseOnline(sqlConnectionString.Value))
{
Logger.LogToFile($"Connection Failed: {sqlConnectionString.Key}", Logger.LogCondition.Critical);
continue;
}
else
{
Logger.LogToFile($"Testing Connection For: {sqlConnectionString.Key} Success", Logger.LogCondition.Verbose);
}
var services = new Microsoft.SqlServer.Dac.DacServices(sqlConnectionString.Value);
services.Message += (object sender, Microsoft.SqlServer.Dac.DacMessageEventArgs eventArgs) => Logger.LogToFile(eventArgs.Message.Message, Logger.LogCondition.Verbose);
var dacpac = DacPackage.Load(dacpacFile);
//publish options
var dacDeployOptions = new DacDeployOptions()
{
ScriptDatabaseOptions = false, //
Подробнее здесь: [url]https://stackoverflow.com/questions/79117573/dacdeploy-scriptdatabaseoptions-option-is-ignored-during-deployment[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия