Blog Post

Friday Flyway Tips: Autopilot in 10 minutes

,

The Solutions Engineers at Redgate recently released an Introduction to Redgate Flyway Autopilot course on our Redgate University. They’ve been working on this for quite some time to help people get started with Flyway in their own environment. It’s gotten smooth and slick, so I’m going to set this up in 10 minutes in this post and video, but with a twist. I’m using my schema to show you how easy this is.

I’ve been working with Flyway Desktop for work more and more as we transition from older SSMS plugins to the standalone tool. This series looks at some tips I’ve gotten along the way.

Getting Started

The course walks you through a few things. These include:

  • Getting Git
  • Installing Flyway Desktop
  • Having an Azure DevOps or GitHub account
  • Having a SQL Server or PostgreSQL server (I’ll use SQL Server)

You will also get a Redgate Token and set up a local runner. I won’t detail those steps here, but I will have them in another post. The video will also skip those steps.

Creating a Repository

I’m working in GitHub, but you can do this in Azure DevOps. Others work, but those aren’t in the course. The main thing to do is go to the official Redgate repo at: https://github.com/red-gate/Flyway-AutoPilot-FastTrack

This brings you to this site:

2025-01_0099

From there, don’t clone or fork, but use as a template. This is in the upper right corner.

2025-01_0100

When you click this, you get the Create a new repository page, that looks like this. If you’re familiar with GitHub, this looks like any other repo. Give it a name, which must be unique in your org. I added FWAutopilot as I already have an “Autopilot” repo that is public.

2025-01_0102

You can make this public or private, but just be aware of this from the standpoint of your org, especially if you add internal schemas. You can also set a description.

Once this is created, you’ll see the repo in your org. Here’s my Autopilot repo:

2025-01_0103

This is a copy of the template all set up. Now, on to Flyway Desktop.

Creating a Project

In Flyway Desktop, I’ll click the drop down by Open Project and select Open from Version Control.

2025-01_0110

Here I’ll paste in the URL of my repo. I also check that the folder for the local clone is valid. In my case, I tend to put things in Documents/Git, but you might have your own standard.

2025-01_0136

Once this clones down, you can see a repo in the path above that looks like the online repo. Flyway Desktop will also refresh the schema, which should give you this error.

2025-01_0210

This is because the databases don’t exist. As you can see, I’ve filtered to databases with “auto” in the name and I have nothing.

2025-01_0207

If I use the file | open in SSMS, I can go into the repo and into the Scripts folder, where I see this:

2025-01_0219

I want to open the CreateAutoPilotDatabases.sql script, which looks like what you see below. This creates 5 databases and adds schema objects to one of them. The goal is for Autopilot to use Database DevOps and Flyway to migrate these changes to other databases.

2025-01_0220

Run this, and I see different databases. I’ve refreshed things, and you can see Prod has nothing but Dev has objects.

2025-01_0221

Now that I have a db, let’s refresh Flyway Desktop. Now I see no changes.

2025-01_0222

Note: If you aren’t doing this on your localhost instance, then you can edit the connections to the dev database (and other databases).

Adding Our Own Schema

Don’t start deleting schema objects yet, but you can add your own. I’ll do that. I have a script that contains a schema for baseball data. The beginning is shown below, but I’ll run this in my AutopilotDev database.

2025-01_0223

After I do this, I’ll refresh Flyway Desktop again and I see my tables. This is a partial list as the full list scrolls off the screen.

2025-01_0224

I’ll select all these from the checkbox at the top next to Object Name and then click “Save to project” in the upper right. This writes the CREATE scripts for all objects to the schema model, as you can see below in the update message.

2025-01_0225

The next step (shown at the bottom) is to generate a migration script. I’ll click that.

I get the screen below, which shows me all the changes that have been made to objects. I can select one or more of these to put into a migration script (deployment script). If I don’t select them all, then I will see those I haven’t selected re-appear here and I can add them to a different script. To keep this simple, I’ve selected them all.

2025-01_0226

When I click “Generate script” in the upper right, Flyway will create a script containing all the objects I’ve selected with the appropriate create/alter/drop code inside. Here is  my one large script. You can see the start of the script below. If we scrolled, we’d see the CREATE for all the tables in here.

2025-01_0227

This project is configured to automatically generate an undo script, so below the above part, there is the undo script. Again, this is just the beginning of the script. However, you can see before we drop tables, we need to remove constraints.

2025-01_0228

Once I’m happy, I can click save and this is written as a migration script (and an undo script).

2025-01_0229

I can click Verify, which essentially runs these scripts against my shadow database, but I don’t do that if I haven’t altered the scripts. You can if you want.

Now that we’ve made some changes, let’s commit those. On the right side of Flyway Desktop is the VCS blade. You can see I have 28 changes in my repo.

2025-01_0230

If I click the “28”, this opens to the commit tab. I can also click the arrow at the top and select the commit tab. In here, I see my changes and I can include all of them or some of them and write a commit message.

2025-01_0231

I’ve selected them all and written a message, so I’ll click the drop down by commit and select the combined Commit and Push.

2025-01_0232

If I check my repo, I see this commit included. You can see this altered the schema-model and migrations folders.

2025-01_0233

Now we need to keep this Database DevOps flow going and deploy our code.

Setting Up Runners

If I check the Actions tab in my repo, I see there are two workflows configured. They are the same, but one works for Windows and one for Linux. I don’t have any runs yet and I haven’t configured a runner.

2025-01_0234

If I go to Settings in my repo and the Actions | Runners area, I’ll see this. The runners are the agents that execute your code. In this case, I need to setup a new one. I’ll detail that in another post.

2025-01_0235

Once I have a runner set up, I should see something like this:

2025-01_0251

Adding Secrets

Flyway is a licensed product, so I need to tell the runner that it is licensed to use the product. If you don’t have a license, this system can get you a 28-day trial, but if you have one, you can just use that.

If you go to the token section of the Redgate portal, you should see something like this:

2025-01_0242_thumb1

If you click New Token, you get a new token.

Note: I’ve deleted this token, so this code doesn’t work.

2025-01_0243_thumb1

Don’t close this, but open a new browser tab for your repo. Go to the Secrets | Actions section under Settings. You should see this. Click New repository secret.

2025-01_0244_thumb

The documentation notes you need to add two secrets: FLYWAY_TOKEN and FLYWAY_EMAIL. These are essentially secret variables picked up by the automation. When I click new, I add the email like this.

2025-01_0245_thumb1

I added the token in the same way, pasting in the token from the portal. When I finished, I see two secrets.

2025-01_0246_thumb1

Run the Automation

Check your production database (and the test one). There should be no objects, which is what we saw above.

Now, go to the Actions section of your repo. Click the Windows workflow on the left (or Linux if you used that).

2025-01_0247_thumb1

Now on the right, click Run workflow, and then Run again in the pop up.

2025-01_0248_thumb1

In a minute, your web page should show this running with a yellow circle before the name.

2025-01_0249_thumb1

Your CLI window should look like this as well, with a job running.

2025-01_0250_thumb1

If you click then name of the run on the web page, you should then see the three tasks. Here my build completed before I could get the screenshot, but yours likely has the yellow on the build database.

2025-01_0251_thumb1

If I click any of the tasks, I’ll see the logging as they run. In this shot below, I’ve clicked the running prod deploy, as that was running when I was ready for the screen shot.

2025-01_0252_thumb1

The output scrolls along and can be hart to follow, but after any of these are complete, you can click on them and see the task outline. Each of these items below can be expanded by clicking on the angle bracket. You can see I’ve expanded the Migrate Test DB task.

2025-01_0254_thumb1

However, most of the time we assume we have a repeatable, reliable execution of our migration, so we don’t care. The proof is in checking the databases.

Here is my refreshed AutoPilotTest database.

2025-01_0255_thumb1

and here is the AutopilotProd database.

2025-01_0256_thumb1

I moved code from dev –> VCS –> test –> prod without executing it anywhere past Dev. This is the way changes should be made to test them before they hit prod.

We should also have feature branches, PRs, and more, but that’s beyond the 10 minutes to get started. From here, I could easily make other changes in dev and get them deployed by clicking a button in GitHub.

Summary

This process took me ten minutes. To be fair, I’d tested it a few times, but in knowing what things are needed in the docs, it took me ten minutes, which I show in a video below.

Flyway is an incredible way of deploying changes from one database to another, and now includes both migration-based and state-based deployments. You get the flexibility you need to control database changes in your environment. If you’ve never used it, give it a try today. It works for SQL Server, Oracle, PostgreSQL and nearly 50 other platforms.

Video Walkthrough

I’ve got a video of me doing this in 10 minutes.

Original post (opens in new tab)
View comments in original post (opens in new tab)

Rate

You rated this post out of 5. Change rating

Share

Share

Rate

You rated this post out of 5. Change rating