Best way to introduce SCA deployments to ops DBAs?
PeterDaniels
Posts: 89 Bronze 3
I have a license for the full SQL Toolbelt (heaven), but none of our ops DBAs currently have licenses. We also do not have a CI/CD technology in place. Our current process has devs delivering a set of "Apply" and "Rollback" SQL scripts in source control to "hand-off" to them for UAT, preprod, Load Test, and prod environments. I'd like to discuss the best options for easing them into receiving deployment artifacts based on SCA projects.
Worst case is I send them a set of migration scripts from the SA project.
Next up the ladder is using one DB (probably prod) to generate release artifacts, and hand off the TargetedDeploymentScript.sql, massaged so that it can run on multiple servers and in different DBs. They can then "approve" the script and exec in SSMS in sqlcmd mode.
I'm not sure they would work well with a different set of release scripts for each target DB, but we could explore that.
The previous possibilities at least would track the migrations in the __MigrationLog. However, we would not get the benefits of snapshot that would give us drift and change reports, which is a huge perk.
Considering my licensing, what is the best way to hand them artifacts that will give us the benefits of snapshots, changes.html, drift.html, etc? I imagine it's PowerShell driven, and I have my own deployment PS scripts based on the SCA cdmlets, but I'm not sure how that works with our licensing to hand off to the ops DBAs. What are my best options here?
TIA,
-Peter
Worst case is I send them a set of migration scripts from the SA project.
Next up the ladder is using one DB (probably prod) to generate release artifacts, and hand off the TargetedDeploymentScript.sql, massaged so that it can run on multiple servers and in different DBs. They can then "approve" the script and exec in SSMS in sqlcmd mode.
I'm not sure they would work well with a different set of release scripts for each target DB, but we could explore that.
The previous possibilities at least would track the migrations in the __MigrationLog. However, we would not get the benefits of snapshot that would give us drift and change reports, which is a huge perk.
Considering my licensing, what is the best way to hand them artifacts that will give us the benefits of snapshots, changes.html, drift.html, etc? I imagine it's PowerShell driven, and I have my own deployment PS scripts based on the SCA cdmlets, but I'm not sure how that works with our licensing to hand off to the ops DBAs. What are my best options here?
TIA,
-Peter
Best Answers
-
way0utwest Posts: 313 Rose Gold 1For me I'd start with a PoC. Changing your existing process and altering what works is hard. It's scary, and you might break somethign.
What I'd do is create a new db in dev and a new one in prod (and QA/test/staging/etc). Put in a single table in each, so they're synced. Now, add a proc in dev, check into VCS. Set up CI/CD, and give the DBAs control over the release. Let them see what moves as you practice some small changes. Once you work out the best process for your group, with flow, timing, notifications, permissions, etc., you can talk about moving a prod db over.
Editor, SQLServerCentral -
PeterDaniels Posts: 89 Bronze 3Follow up:
Initial prod deployment was a hack - ssms generated ddl and dml scripts. But,I did include the __MigrationLog table and data.
Once I cleared up my SCA deployment issues, I have been able to pass on the New-DatabaseReleaseArtifact and Export-DatabaseReleaseArtifact generated TargetedReleaseScript.sql, with the server name check removed, to the ops DBAs. They have been willing to execute that manually in SSMS in SQLCMD mode. This is working as an intermediate process until I can socialize deployment via ci/cd tech.
Answers
Edit: I've been using a combination of unchecking "mark first folder as baseline" + adding <SkipBaselineCheck>True</SkipBaselineCheck> to get New-DatabaseReleaseArtifact to include the whole set of migrations to deploy correctly to a newly created DB. Otherwise, it errors. The original "target" db used during project creation to injury the baseline script had a number of initial schema objects.
I'm not 100% sure how the <skipbaselinecheck> affects this, so let me ask someone else
Other option was to remove that user, and SCA saw the target as empty. Since I don't know exactly how SCA determines l "empty", I'm keeping the skip property in place for now.
In other news, I ended up just manually scripting the ddl and dml to get the project delivered to the ops DBAs, including the road in the __migrationLog table. Hoping I can return to SCA based deployment artifacts again.
The second deployment was the addition of a single new migration in a New-DatabaseReleaseArtifact generated TargetedDeploymentScript.sql. I manually modified it to comment out the target sever check, so they would have one script (currently a requirement) for all of their servers. They successfully ran that in uat and load test servers, so we're at least gaining the benefit of SCA generated deployment scripts and tracking in the __migrationLog table.
Concurrently, I've had some meetings to introduce the idea of using PowerShell to deploy using the Use-DatabaseReleaseArtifact cmdlet. That would give us the added benefit of snapshot, drift check, etc. as an intermediate step.
I've also showed then a taste of my POC using SCA, bamboo, and Octopus deploy, but my sense is we're months (or longer) away from being able to get buy-in for that move.
Thank you for your help, Steve. Honored to have a celebrity work with me in the forums.
-Peter