Mic*_*lle 3 deployment powershell octopus-deploy dacpac
我在TeamCity上使用Octopus将数据库部署到我们的生产环境,但它一直出错.
这是Deploy.ps1代码:
$dbName = $OctopusParameters['DBName']
$dbUser = $OctopusParameters['AdminDBUsername']
$dbPassword = $OctopusParameters['AdminDBPassword']
$dbSource = $OctopusParameters['DBDataSource']
# Set params
if (! $dbName)
{
Write-Host "Missing required variable dbName" -ForegroundColor Yellow
exit 1
}
if (! $dbUser)
{
Write-Host "Missing required variable dbUser" -ForegroundColor Yellow
exit 1
}
if (! $dbPassword)
{
Write-Host "Missing required variable dbPassword" -ForegroundColor Yellow
exit 1
}
if (! $dbSource)
{
Write-Host "Missing required variable dbSource" -ForegroundColor Yellow
exit 1
}
# Add the DLL
# For 64-bit machines
Add-Type -path ((Get-Item -Path ".\" -Verbose).FullName + "\bin\Microsoft.SqlServer.TransactSql.ScriptDom.dll")
Add-Type -path ((Get-Item -Path ".\" -Verbose).FullName + "\bin\Microsoft.SqlServer.Dac.dll")
# Create the connection string
$d = New-Object Microsoft.SqlServer.Dac.DacServices ("data source=" + $dbSource + ";User Id = " + $dbUser + ";pwd=" + $dbPassword)
#Load the dacpac
$dacpac = ((Get-Item -Path ".\" -Verbose).FullName + "\DeployScripts\Database.dacpac")
$dacpacoptions = ((Get-Item -Path ".\" -Verbose).FullName + "\DeployScripts\publish.xml")
#Load dacpac from file & deploy to database
$dp = [Microsoft.SqlServer.Dac.DacPackage]::Load($dacpac)
#Read a publish profile XML to get the deployment options
$dacProfile = [Microsoft.SqlServer.Dac.DacProfile]::Load($dacpacoptions)
# Deploy the dacpac
$d.Deploy($dp, $dbName, $TRUE, $dacProfile.DeployOptions)
Run Code Online (Sandbox Code Playgroud)
如果重要,这是发布配置文件:
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="12.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup>
<IncludeCompositeObjects>True</IncludeCompositeObjects>
<TargetDatabaseName>MyDatabase</TargetDatabaseName>
<DeployScriptFileName>MyDatabase.sql</DeployScriptFileName>
<ProfileVersionNumber>1</ProfileVersionNumber>
<BlockWhenDriftDetected>True</BlockWhenDriftDetected>
<RegisterDataTierApplication>True</RegisterDataTierApplication>
</PropertyGroup>
</Project>
Run Code Online (Sandbox Code Playgroud)
以下是我得到的错误:
使用"4"参数调用"Deploy"的异常:
"部署计划生成期间发生错误.部署无法继续."
在Deploy.ps1:60 char:2
$ d.Deploy($ dp,$ dbName,$ TRUE,$ dacProfile.DeployOptions)
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~
CategoryInfo:NotSpecified:(:) [],ParentContainsErrorRecordException
FullyQualifiedErrorId:DacServicesException
有没有人有什么想法可以导致这个?以及如何解决它?提前致谢!
好的家伙我明白了.这是我做的:
在ps1文件中添加一个try catch块,其中$ d.Deploy被调用如下:
try
{
# Deploy the dacpac
$d.Deploy($dp, $dbName, $TRUE, $dacProfile.DeployOptions)
}
catch
{
Write-Host "LoadException";
$Error | format-list -force
Write-Host $Error[0].Exception.ParentContainsErrorRecordException;
}
Run Code Online (Sandbox Code Playgroud)
这样做告诉我sqlproj文件是针对Sql Server 2014的,但部署的数据库是Sql Server 2012.只需进入sql项目文件的属性并进行更改,使其针对Sql Server 2012,现在可以正常工作!好哇!
| 归档时间: |
|
| 查看次数: |
1880 次 |
| 最近记录: |