Docker Web Application

Introduction

In this demo, we will deploy a simple Hello World NodeJS web app. DuploCloud pulls Docker images from Docker Hub. You can choose a public image or provide credentials to access your private repository. For the sake of this demo, we will use a ready-made image available on DuploCloud’s repository on Docker Hub.

  1. Create a new host

  2. Create a service

  3. Create a load balancer

Step 1: Create a new host

  1. Login to your DuploCloud console.

  2. Click on DevOps --> Hosts

  3. Select “Hosts” from the tabs. A Host is an instance in which your Docker container will run. You should choose a host with the appropriate processing capacity for your application.

You should see the Host listed under the Hosts Listing table.

Step 2: Create a service

  1. Next, we can create a Service. A Service is nothing but a container with user-specified image and environment variables. Let’s go ahead and click the + icon to create a new service.

  2. Name the service “test-service“. For this demo, we will use the latest, nodejs-hello image from Duplo’s public Docker hub repository. Fill in duplocloud/nodejs-hello:latest in the Docker Image field.

  3. Enter the desired number of replicas you want in the swarm. Please note that each replica runs in an individual Host. The number of replicas must equal the number of Hosts. For the sake of this demo, we will choose 1.

  4. Fill in the desired environment variables, this is ideal for credentials or application specific configurations.

  5. Volume mapping is super easy, simply give the host path and container path as shown.

NOTICE: We highly recommend keeping the Hosts stateless and using Azure Storage for static assets. We will keep this field empty for this demo.

Step 3: Create a load balancer

Almost there. Since the hello-nodejs image serves on port 3000 we need to create a load balancer (LB) configuration to map the external port (LB) to the internal port (container).

Select the Test-service and click the plus icon on the load balancer configuration table. Fill the menu as shown below and click submit.

Please wait for ~5 minutes as it can take a while for the Load Balancer to get provisioned.

Last updated

Logo

© DuploCloud, Inc. All rights reserved. DuploCloud trademarks used herein are registered trademarks of DuploCloud and affiliates