Skip to content

Deploying a fullstack Node.js to AWS Elastic Beanstalk

Notifications You must be signed in to change notification settings

ashioyajotham/Udagram-Project

Repository files navigation

Udagram Image Filtering Microservice

Udagram is a simple cloud application developed alongside the Udacity Cloud Engineering Nanodegree. It allows users to register and log into a web client, post photos to the feed, and process photos using an image filtering microservice.

The project is split into three parts:

  1. The Simple Frontend A basic Ionic client web application which consumes the RestAPI Backend. [Covered in the course]
  2. The RestAPI Backend, a Node-Express server which can be deployed to a cloud service. [Covered in the course]
  3. The Image Filtering Microservice, the final project for the course. It is a Node-Express application which runs a simple script to process images. [Your assignment]

Tasks

Setup Node Environment

You'll need to create a new node server. Open a new terminal within the project directory and run:

  1. Initialize a new project: npm i
  2. run the development server with npm run dev

Create a new endpoint in the server.ts file

The starter code has a task for you to complete an endpoint in ./src/server.ts which uses query parameter to download an image from a public URL, filter the image, and return the result.

We've included a few helper functions to handle some of these concepts and we're importing it for you at the top of the ./src/server.ts file.

import {filterImageFromURL, deleteLocalFiles} from './util/util';

Deploying your system

Follow the process described in the course to eb init a new application and eb create a new environment to deploy your image-filter service! Don't forget you can use eb deploy to push changes.

Stand Out (Optional)

Refactor the course RESTapi

If you're feeling up to it, refactor the course RESTapi to make a request to your newly provisioned image server.

Authentication

Prevent requests without valid authentication headers.

!!NOTE if you choose to submit this, make sure to add the token to the postman collection and export the postman collection file to your submission so we can review!

Custom Domain Name

Add your own domain name and have it point to the running services (try adding a subdomain name to point to the processing server)

!NOTE: Domain names are not included in AWS’ free tier and will incur a cost.

Additions

  • Editing the build script to include:
"start": "node ./www/server.js"
  • AWS Elastic Beanstalk automatically starts "app.js" or "index.js". Lack of them may lead to instance failure.

Endpoint

http://udagram-dev-dev.us-west-2.elasticbeanstalk.com/

Troubleshooting and errors

IAM

  • Create a new user with admin privileges and manipulate the other users using AWS CLI

Build Scripts

  • For Windows users, run the script using git bash or change the "cp" command to "copy"
  • For the windows users also, replace '/' with '\\' in the build script otherwise it will raise a syntax error

RDS

  • This project was built on older version of node and you can either update or regress specifically to node 12
  • For issues due to connecting to sequelize, put the sequelize in a try catch block like this
(async () => {
  try {
    await sequelize.addModels(V0MODELS);
    await sequelize.sync();
  } catch (error) {
    console.log(error)
  }