Containerize an application

For the rest of this guide, you'll be working with a simple todo list manager that runs on Node.js. If you're not familiar with Node.js, don't worry. This guide doesn't require any prior experience with JavaScript.

Prerequisites

Get the app

Before you can run the application, you need to get the application source code onto your machine.

Build the app's image

To build the image, you'll need to use a Dockerfile. A Dockerfile is simply a text-based file with no file extension that contains a script of instructions. Docker uses this script to build a container image.

    In the getting-started-app directory, the same location as the package.json file, create a file named Dockerfile . You can use the following commands to create a Dockerfile based on your operating system.

Mac / Linux / Windows (Git Bash) Windows (Command Prompt) Windows (PowerShell)

In the terminal, run the following commands. Make sure you're in the getting-started-app directory. Replace /path/to/getting-started-app with the path to your getting-started-app directory.

Create an empty file named Dockerfile .

In the Windows Command Prompt, run the following commands. Make sure you're in the getting-started-app directory. Replace \path\to\getting-started-app with the path to your getting-started-app directory.

Create an empty file named Dockerfile .
 Dockerfile 

In PowerShell, run the following commands. Make sure you're in the getting-started-app directory. Replace \path\to\getting-started-app with the path to your getting-started-app directory.

Create an empty file named Dockerfile . Build the image.

Start an app container

Now that you have an image, you can run the application in a container using the docker run command.

    Run your container using the docker run command and specify the name of the image you just created:

Empty todo list

The -d flag (short for --detach ) runs the container in the background. This means that Docker starts your container and returns you to the terminal prompt. You can verify that a container is running by viewing it in Docker Dashboard under Containers, or by running docker ps in the terminal. The -p flag (short for --publish ) creates a port mapping between the host and the container. The -p flag takes a string value in the format of HOST:CONTAINER , where HOST is the address on the host, and CONTAINER is the port on the container. The command publishes the container's port 3000 to 127.0.0.1:3000 ( localhost:3000 ) on the host. Without the port mapping, you wouldn't be able to access the application from the host.

  • After a few seconds, open your web browser to http://localhost:3000 . You should see your app.
  • Add an item or two and see that it works as you expect. You can mark items as complete and remove them. Your frontend is successfully storing items in the backend.
  • At this point, you have a running todo list manager with a few items.

    If you take a quick look at your containers, you should see at least one container running that's using the getting-started image and on port 3000 . To see your containers, you can use the CLI or Docker Desktop's graphical interface.

    CLI Docker Desktop

    Run the following docker ps command in a terminal to list your containers.