Skip to content

Latest commit

 

History

History
108 lines (73 loc) · 3.61 KB

File metadata and controls

108 lines (73 loc) · 3.61 KB

React & Node-Express on Docker Template

Table of Contents

About

A template for setting up a React frontend and a Node-Express backend in docker containers (that talk to each other) using a single command.

Built With

Prerequisites to Getting Started

  • Docker Desktop

Getting Started

  1. Clone the project source code.
git clone https://github.com/AVu120/react-and-node-express-on-docker.git
  1. Navigate into the project directory.
cd react-and-node-express-on-docker
  1. Run this single command to build the react-frontend (client) & node-express-backend (server) docker images, run them as containers, and have them connect to each other.
docker-compose up
  • Wait until both containers are up and running before proceeding.
  • Client is running on port 3000.
  • Server is running/listening on port 5000.
  1. When necessary, install only the client dependencies you need (e.g. install react-scripts to execute 'npm run build' before deploying app to production). Note that local node_modules will not be copied into the container.
cd client
npm i react-scripts etc.
  1. When you need to add-new/update npm packages to/in an image/container, update the relevant package.json, stop that container, then run
docker-compose build <service-name>

then run

docker-compose up

to restart all the containers (with the new/updated packages).

Accessing the Application

  1. Enter localhost:3000 into any web-browser.

Troubleshooting Errors

No such file or directory:

  • After running docker-compose up, if you see anything like the below error messages:
npm ERR! path /usr/src/app/package.json
npm ERR! enoent ENOENT: no such file or directory, open '/usr/src/app/package.json'
npm ERR! enoent This is related to npm not being able to find a file.
Error: Cannot find module '/usr/src/app/package.json'
  • Open Docker Desktop > Settings > Resources > File Sharing:
  • Unselect the local drive which contains the react-and-node-express-on-docker directory (or the directory containing this project's code).
  • Click 'Apply & Restart' button.
  • Re-select the previously unselected local drive.
  • Click 'Apply & Restart' button.
  • Run docker-compose up and the error shouldn't occur now.

Cannot start service (service-name): OCI runtime create failed:

  • After running docker-compose up, if you see anything like the below error messages:
Cannot start service (service-name): OCI runtime create failed
container_linux.go:349: starting container process caused "process_linux.go:449:
container init caused \"rootfs_linux.go:58: mounting \\\"/var/lib/docker/volumes/511d40c5336f7bcc0df59a8b562e534cfc047b6a3758ab5806fcd49b0028dff7/_data\\\" to rootfs \\\"/var/lib/docker/overlay2/672bcfc131bf96adf217692345bbe603dfb830e84bbcf4158ecf04002baa27da/merged\\\" at \\\"/var/lib/docker/overlay2/672bcfc131bf96adf217692345bbe603dfb830e84bbcf4158ecf04002baa27da/merged/usr/src/app/node_modules\\\" caused \\\"mkdir /var/lib/docker/overlay2/672bcfc131bf96adf217692345bbe603dfb830e84bbcf4158ecf04002baa27da/merged/usr/src/app/node_modules: file exists\\\"\"": unknown

ERROR: Encountered errors while bringing up the project.
  • Restart Docker Desktop.
  • Run docker-compose up and the error shouldn't occur now.