我正在使用以下任务执行迁移。它就像预期的那样工作。
- task: SqlAzureDacpacDeployment@1
displayName: "App DB migration"
inputs:
azureSubscription: $(SrvConn)
AuthenticationType: 'connectionString'
ConnectionString: "Server=tcp:my-server.database.windows.net,1433;Database=my-db;Persist Security Info=False;User=the_user;Password=hash_puppy;MultipleActiveResultSets=False;Encrypt=True;TrustServerCertificate=False;Connection Timeout=30;"
deployType: 'SqlTask'
SqlFile: '$(Pipeline.Workspace)/migration/db_app.sql'
IpDetectionMethod: 'AutoDetect'
出于安全原因,我想将字符串移动到一个更安全的位置,并使用管道变量进行选择(如in this blog, secret value section所讨论的)。在声明了一个名为connstring
的任务并从上面的示例中分配了确切的值之后,我运行了更新后的任务。但是,它会产生一系列错误。
使用ConnectionString: '%CONNSTR%'
、ConnectionString: $(CONSTRDEV)
或ConnectionString: $(env:CONSTRDEV)
。
[error]初始化字符串的格式不符合从索引0开始的规范。请访问www.example.com查看如何排除故障https://aka.ms/sqlazuredeployreadme#troubleshooting
使用ConnectionString: %CONNSTR%
。
在扫描下一个令牌时,查找无法开始任何令牌的字符。
当我执行下面的命令时,值就在那里,在屏幕上清晰可见。
- pwsh: Write-Host ${env:CONSTRDEV}
我看不出我做错了什么。阅读文档给了我不多。从理论上讲,它工作(打印输出确认)。然而,无论如何,迁移的任务都会失败。
1条答案
按热度按时间72qzrwbm1#
它可能是您最初使用的双引号:
在后面的一个中,你使用了单引号:
另外,你应该更改你的密码