Flyway migrations in lein clojure

16 July, 2017.
Under: tech clojure db

Leiningen is the easiest way to start with clojure project automation. The project under discussion is a webservices written in clojure with compojure-api and ring middleware.

When it came to Database migrations, I didn't find anything straightforward amongst the lein plugins. So, decided to use flyway. I have worked with flyway in the past with Java applications. But, this is the first time with clojure, leiningen combination.

Migration utility in clojure

Here is the small migration helper written in Clojure

Running migration during deployment

I'm using lein-ring plugin, this provided an option to execute function before the handler starts. So, I wired app.migrate to the init block of the handler.

This helps to run migration everytime before the application deploys. Ofcourse, flyway will take care of what migrations need to run based on the migration version.

Running migrations for local development

The above method works perfectly for the application deployment scenarios. However, in local it will be better to execute​ ​migration and clean databases as and when required, rather than re-deploying the application. lein-exec plugin offers​ ​a way to create and execute clojure code from project.clj files. With the above-mentioned migration present, all ​I​​ ha​ve to do is to create some aliases as shown below.

            :aliases { 
                "db-clean"   ["exec" "-ep" "(use 'deal-picker.migration) (clean)"]
                "db-migrate" ["exec" "-ep" "(use 'deal-picker.migration) (migrate)"]
                "db-info"    ["exec" "-ep" "(use 'deal-picker.migration) (info)"]
                "db-reset"   ["exec" "-ep" "(use 'deal-picker.migration) (reset)"]
            }
        

Share Tweet