Featured image of post Create a blog with supabase and nextjs - part 5

Create a blog with supabase and nextjs - part 5

Lets deploy our blog to vercel and supabase using github actions

Create a supabase account

Until now we’ve been using supabase locally with docker. Lets create the necessary accounts so we can deploy our blog to the cloud.

Go to supabase and create an account, and then a project. We won’t go into details about the project creation, you can find more information in the docs.

We have a couple of different ways of doing it, either by using the sql editor and copy pasting the migration file, or by using github actions.

If you created the database manually from the UI, you can just get the migration by running:

1
npx supabase db diff -f first-migration

Create a Github repository

Create a new repository or fork my repository if you haven’t done everything on your side already.

Github actions

Lets go back to the database. What we want to do is deploy the database to supabase when we push to the main branch. We can do that by using github actions.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
## .github/workflows/deploy-migrations.yml
name: Deploy Migrations to Supabase

## targets the main branch - when we push to main, the workflow will run
on:
  push:
    branches:
      - main
  workflow_dispatch:

jobs:
  deploy:
    runs-on: ubuntu-latest

    env:
      SUPABASE_ACCESS_TOKEN: ${{ secrets.SUPABASE_ACCESS_TOKEN }}
      SUPABASE_DB_PASSWORD: ${{ secrets.SUPABASE_DB_PASSWORD }}
      SUPABASE_PROJECT_ID: ${{ vars.SUPABASE_PROJECT_ID }}

    steps:
      - uses: actions/checkout@v3

      - uses: supabase/setup-cli@v1
        with:
          version: latest

      - run: |
          supabase link --project-ref $SUPABASE_PROJECT_ID
          supabase db push          

We need to create a folder called .github/workflows and create a file called deploy-migrations.yml with the content above.

In github (Settings > Secrets and variables > Actions), we also need to create the following secrets:

  • SUPABASE_ACCESS_TOKEN
  • SUPABASE_DB_PASSWORD

And the following variable:

  • SUPABASE_PROJECT_ID

You can find the values in the supabase dashboard.

Environment variables and secrets in github

Deploying the blog

First we need to create a vercel account and link it to our github account. Once that’s done, just create a new project.

Once again setup the supabase environment variables in the vercel dashboard. Those values are for Next.js this time.

Environment variables in vercel

And that’s it, we’re done. You can now go to your project and commit/push to the main branch to deploy the database and the blog.