- Published on
Deploy frontend application (React) to Vercel using Github Action - Part 1
- Authors
- Name
- Nguyễn Tạ Minh Trung
What is Vercel ?
Vercel is a developer cloud platform for frontend frameworks and static sites.
It provides automatic deployments, serverless functions, edge caching, and an easy-to-use CI/CD workflow. Vercel supports instant rollbacks, custom domains, and performance optimizations, making it ideal for hosting React, Next.js, and other frontend applications.
For advanced usecase, you may have an additional build step need to be run when pushing the code to github. Instead of levarage Vercel automatic trigger the deployment, you can use Vercel with GitHub Actions as your CD/CD provider to deploy your React app.
Prerequisites
Before deploying your React app to Vercel, please ensure you have:
- A Github repository with your React project
- A Vercel account
-
Node.js
andYarn
installed (as you are usingYarn
)
Get started
1. Setup a Vercel Project
Login to Vercel: Go to Vercel and sign in with Github
- Import Your Repository: Click Add new the choose Project
- An Import Git Repository page will be appear. For now, you just need to choose your React project and click Import. You will need do one more thing to deploy your React app at the first time.
- After that, New Project page with Github React information will show. Then, final step is click Deploy
- Congrats! Your first deployment is ready now. Let's go to Dashboard page to see it
2. Get Vercel API Credentials
2.1. Get Vercel Token
This will be important step. You will need to get Vercel Token, Vercel Org ID and Vercel Project ID for usage later.
In order to get Vercel Token, let's visit the My Account page by click Account Settings, then, choose the Token item in left menu. At here, you have to enter the TOKEN_NAME, SCOPE and EXPIRATION.
Don't forget to store your new token to other place, because it just show at the first time.
2.2. Get Vercel Org ID
Then, let's go to Dashboard -> Settings. Your Vercel Org ID is your Team ID.
2.3. Get Vercel Project ID
Finally, let's get Vercel Project ID by access to your project -> Settings. The Project ID will be located here.
Alternative
We also retrieve the Vercel Org ID and Vercel Project ID by the below steps:
- Install Vercel CLI and login to Vercel via command:
[shell]
vercel login
- Inside your repository, link your repo with Vercel project:
vercel link
A folder .vercel
will be generated in root directory, then, get your Vercel Org ID and Vercel Project ID in project.json
file.
Yah, you're done this step!
3. Configure GitHub Secrets
With Vercel Token, Vercel Org ID and Vercel Project ID from the above, we will have to configure them within GitHub Secrets
- Go to your GitHub repository
- Navigate to Settings -> Secrets and variables -> Actions.
- Add the following secrets:
- VERCEL_TOKEN (your Vercel access token).
- VERCEL_ORG_ID (your Vercel Org ID).
- Vercel_PROJECT_ID (Your Vercel Project ID).
4. Set Up GitHub Actions Workflow
Go to your repository, let's create a workflow file inside .github/workflows/deploy-preview.yaml
Following the code snippet below to deploy the Preview environment:
name: Vercel Preview Deployment
env:
VERCEL_ORG_ID: ${{ secrets.VERCEL_ORG_ID }}
VERCEL_PROJECT_ID: ${{ secrets.VERCEL_PROJECT_ID }}
on:
push:
branches-ignore:
- master
jobs:
Deploy-Preview:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Install Vercel CLI
run: npm install --global vercel@latest
- name: Pull Vercel Environment Information
run: vercel pull --yes --environment=preview --token=${{ secrets.VERCEL_TOKEN }}
- name: Build Project Artifacts
run: vercel build --token=${{ secrets.VERCEL_TOKEN }}
- name: Deploy Project Artifacts to Vercel
run: vercel deploy --prebuilt --token=${{ secrets.VERCEL_TOKEN }}
deploy-preview.yaml
, GitHub Actions will automatic trigger the build and deploy to the Preview environment data:image/s3,"s3://crabby-images/f8efc/f8efcaba05314b4e13148b1f05a56d80349eabf9" alt="Github Secrets"
Almost done! Let's do the same for Production environments with a separate Action by Deploy-Production.yaml
:
name: Vercel Production Deployment
env:
VERCEL_ORG_ID: ${{ secrets.VERCEL_ORG_ID }}
VERCEL_PROJECT_ID: ${{ secrets.VERCEL_PROJECT_ID }}
on:
push:
branches:
- master
jobs:
Deploy-Production:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Install Vercel CLI
run: npm install --global vercel@latest
- name: Pull Vercel Environment Information
run: vercel pull --yes --environment=production --token=${{ secrets.VERCEL_TOKEN }}
- name: Build Project Artifacts
run: vercel build --prod --token=${{ secrets.VERCEL_TOKEN }}
- name: Deploy Project Artifacts to Vercel
run: vercel deploy --prebuilt --prod --token=${{ secrets.VERCEL_TOKEN }}
5. Deploying Your Vercel Application with GitHub Actions
Once you have a push
action to git feature branches, GitHub Actions will trigger Deploy-Preview
action to build and deploy your changes to Preview
environments.
If the changes has been merged into the master
branch, the Deploy-Production
action will be triggered and move the new changes to Production
environment.
Now, your Vercel application is now configured with GitHub Actions. It's time to test out Github Workflow.