illustration for Containerize Full-Stack JavaScript Applications with Docker

Containerize Full-Stack JavaScript Applications with Docker


Joel Lord
1h 24m closed-captioning
18 lessons
Star icon$$$
Star icon$$$
Star icon$$$
Star icon$$$
Star icon$$$
people completed
Published 3 years ago
Updated 3 years ago

While "It works on my computer" might give you an excuse to close a bug ticket in the backlog, it doesn't really work when you're working on a team.

You need to ensure that your application can run regardless of what hardware your teammates are running or libraries they have installed.

Docker solves this problem by collecting everything your application needs to run into a container.

Containers aren't just for source code. They can hold configuration, scripts, and even their own filesystem. It's similar to a Virtual Machine, without having to bring a full operating system along for the ride.

Because containers run in isolation, there is some configuration involved to allow for files to be saved and containers to communicate with one another.

One of the most useful ways to get your head around Docker is to see it in action.

Follow along with Joel Lord as he works through the process of preparing an application to run in separate containers for the frontend and backend of an application that searches for gifs and re-encodes them with a caption supplied by the user.

You'll see how to configure the separate containers to communicate with one another, work with environment variables, and persist data to your local machine. Along the way, you'll pick up some tips on useful commands and bash scripting. Finally, you'll learn how to use Docker Compose to make it easy to run multiple containers simultaneously.

What you'll learn:

  • Running existing Docker containers
  • Creating Docker containers for an existing application
  • Passing environment variables
  • Executing bash scripts as part of container building
  • Configure networking between containers
  • Setting up volumes for persisting data
  • Publishing containers to a public registry

Course Content

1h 24m • 18 lessons

    You might also like these resources:

    illustration for WTF is Kubernetes (K8s)
    Chris Biscardi・12m・Video

    Kubernetes is an API to a computer. Multiple computers actually. Here we'll talk about what K8s is, how you can choose between the plethora of K8s related hosting options, and what the process looks like for getting some containers running.

    illustration for Build a Twelve-Factor Node.js App with Docker
    Mark Shust・30m・Course

    Take a simple Node.js app that connects to a MongoDB database and uses an Express web server, and learn how to setup a full software development deployment process as well as how to properly “Dockerize” the app.

    illustration for Set up Hasura GraphQL engine with YugabyteDB distributed SQL
    Vladimir Novick・2m・Video

    In this lesson we will see how you can run Hasura GraphQL engine on top of YugabyteDB Distributed SQL

    YugabyteDB is an open source, high-performance distributed SQL database for powering global, internet-scale applications.YugabyteDB is also a cloud-native database, so it can be deployed across both public and private clouds, including Kubernetes environments. In regards to serving as a backend for microservices, YugabyteDB brings together three must-haves: a PostgreSQL-compatible SQL API, low-latency read performance, and globally distributed write scalability. YugabyteDB with its global data distribution brings data close to users for multi-region and multi-cloud deployments.