Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hgschandeepa/nodejs-rest-api-ec2
Auto Deploy Node.js REST API on AWS EC2 | CI/CD Pipeline using GitHub Actions
https://github.com/hgschandeepa/nodejs-rest-api-ec2
aws-ec2 ci-cd github github-actions githubaction-workflow nginx pm2
Last synced: 1 day ago
JSON representation
Auto Deploy Node.js REST API on AWS EC2 | CI/CD Pipeline using GitHub Actions
- Host: GitHub
- URL: https://github.com/hgschandeepa/nodejs-rest-api-ec2
- Owner: HGSChandeepa
- Created: 2024-03-17T12:28:41.000Z (10 months ago)
- Default Branch: main
- Last Pushed: 2024-03-17T15:32:23.000Z (10 months ago)
- Last Synced: 2024-11-12T22:06:09.859Z (2 months ago)
- Topics: aws-ec2, ci-cd, github, github-actions, githubaction-workflow, nginx, pm2
- Language: JavaScript
- Homepage: https://medium.com/@saminchandeepa/auto-deploy-node-js-rest-api-on-aws-ec2-ci-cd-pipeline-using-github-actions-031be66824d1
- Size: 25.4 KB
- Stars: 10
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Node.js REST API Deployment on AWS EC2 with GitHub Actions CI/CD Pipeline
This repository demonstrates a streamlined approach to deploying a Node.js REST API on an AWS EC2 instance using GitHub Actions for continuous integration and continuous deployment (CI/CD).
## Overview
In this project, we utilize GitHub Actions workflows to automate the CI/CD pipeline for deploying changes to our Node.js application on an EC2 instance. The workflow consists of:
- **Continuous Integration (CI):** Automatically building and testing the application on each push to the `main` branch.
- **Continuous Deployment (CD):** Automatically deploying changes to the EC2 instance upon successful completion of CI.## Setup Instructions
Follow these steps to set up the deployment pipeline for your Node.js REST API on AWS EC2:
1. **Create an EC2 Instance:**
- Create a new EC2 instance in your AWS account or use an existing one.
- Generate or use an existing SSH key pair for accessing the instance.2. **Git Repository Setup:**
- Create a new Git repository and push your Node.js code to it.3. **GitHub Actions Setup:**
- Navigate to your repository settings on GitHub and select Actions.
- Add a self-hosted runner and follow the setup instructions.4. **Environment Setup for GitHub Actions:**
- Create a `.env` file with your environment variables and add them as secrets in your GitHub repository settings.5. **CI/CD Workflows:**
- Define CI/CD workflows in the `.github/workflows` directory.
- Customize workflows to suit your project requirements.6. **Environment Setup in EC2 Instance:**
- Install Node.js and Nginx on your EC2 instance.
- Configure Nginx as a reverse proxy for your Node.js application.
- Install PM2 to manage your Node.js process.## Workflow Explanation
- **CI Process:** On each push to the `main` branch, the workflow executes CI tasks such as checking out code, setting up the Node.js environment, installing dependencies, and running tests (if applicable).
- **CD Process:** Upon successful CI, the workflow triggers CD tasks including SSH into the EC2 instance, pulling the latest changes, restarting the Node.js application, and verifying deployment.## Directory Structure
- `src/`: Contains the source code for the Node.js application.
- `.github/workflows/`: Contains CI/CD workflow configuration files.
- `.env`: Stores environment variables for the application.
- `server.js`: Entry point for the Node.js application.
- `package.json`: Dependency configuration for npm.## Usage
1. Clone the repository:
```bash
git clone https://github.com/HGSChandeepa/nodejs-rest-api-EC2
```2. Customize the Node.js application code in the `server.js` file according to your requirements.
3. Push changes to the `main` branch. GitHub Actions will automatically trigger the CI/CD pipeline.
## Contributions
Contributions to improve this CI/CD setup or add additional features are welcome! Feel free to submit pull requests or open issues.
## License
This project is licensed under the [MIT License](LICENSE).