Dockerfile and the Tarball
Docker on the Educative Platform
We use Docker to allow authors to create their own custom environments to accommodate any language that is not supported by our platform.
Authors can create custom docker images that deploy on the Google Cloud and allow end-users to directly have access to these customized environments through our platform.
The Jargon
Base Image: An OS userspace.
Image: A read-only template with instructions for creating a Docker container.
Dockerfile: A simple file with no extension, named as Dockerfile is used to builds a Docker image, and specifies everything that will go in the application’s environment setup.
Container: An image when run, builds a container. This contains your application environment, basically where your application will be run.
Tarball
On Educative, we require our Dockerfile and all dependent files to be uploaded on the platform via a tarball.
-tarball--Dockerfile--package.json--file1.js
The above shows the directory structure of our tarball.
The command to create this tarball is as follows:
tar -czvf tarfile.tar.gz Dockerfile file1.js package.json
As you can see, the Dockerfile must be nested directly inside the tarball (not inside any child folder).
This allows Educative to access the Dockerfile directly and create a docker container for our application’s environment.
The other two files i.e package.json and file1.js.
Package.json need not be added as it will be created again on runtime and file1.js just has code for testing and is also optional, it is already provided in the lessons that follow.
Points to Note:
- all files can be found for download in the Appendix of this lesson.
- Only ONE tarball with ONE Dockerfile can be uploaded and used at a time. Uploading a new tarball will replace any previously uploaded.
Dockerfile
Our Dockerfile can be found below:
FROM node:8.15RUN npm -g install eslintRUN npm -g install eslint-config-airbnbRUN npm install -g eslint-plugin-importRUN npm install -g eslint-plugin-jsx-a11yRUN npm install -g eslint-plugin-reactRUN npm install -g prettierRUN npm install -g --save-dev jestRUN npm install -g --save-dev @testing-library/react
Let’s see step by step how this works.
Line 1:
FROM node:8.15
:
The FROM command sets the Base Image for the rest of the instructions. This command must be on top of the Dockerfile.
In this example, we are starting with the base image of node:8.15
. This will allow us to install various npm packages needed for our purposes. Make sure you use node:8.15
version in your Dockerfile if you are making a LiveVM
You can use a specific version of your base image, by appending : and the version_name
at the end of the image name.
In case of LiveVM setup, whatever base image you use, you need to install node:8.15
via Dockerfile for the SPA + LiveVM to work.
For code widget this is not necessary.
Line 3:
RUN npm -g install eslint
The RUN command is used to execute instructions against the image. It is used to run a command during the build process of the docker image.
The RUN npm -g install eslint
line runs a global install for eslint
Lines 4-7:
RUN npm -g install eslint-config-airbnb
RUN npm install -g eslint-plugin-import
RUN npm install -g eslint-plugin-jsx-a11y
RUN npm install -g eslint-plugin-react
These lines run a global install for our configuration file: eslint-config-airbnb, and its various dependencies.
Note: A
package.json
file will be provided in the code files for eslint and you can change eslint configuration from there as needed.
Line 9:
RUN npm install -g prettier
: This runs a global install for Prettier.
Line 11:
RUN npm install -g --save-dev jest
: This line runs a global install for jest
Line 12:
RUN npm install -g --save-dev @testing-library/react
: This runs a global install for React Testing Library.
Uploading the Tarball
Note: In case Image build fails, you can download the Build Logs (image above), to see where the problem went by.
Appendix
File to Download
In the next lesson, we’ll learn how to set up Prettier.