If there are ten buzzwords in the tech world in 2019, containerization will definitely have a place. With the popularity of Docker, more and more front-end fields are applied to Docker. In this article, we’ll take a look at how Nebula Graph, an open source distributed graphics database, applied Docker to a visual interface and optimized the Docker image from 1.3 GB to 0.3 GB.
Why Docker
For daily front-end development, Docker is sometimes used in conjunction with Nebula Graph Studio for the following reasons:
- Unified operating environment: Our tool has several services grouped together behind it, such as existing services in different technology stacks, purely front-end static resources.
- Low user cost: the cloud service is still under development at present, so that users can be insensitive to the service combination and can directly launch the application locally and use it with one click.
- Rapid deployment: The team already provided the Nebula version of the practice, giving us a bit of a front end reference.
Docker image build
Since we want to use Docker to host our application, we need to mirror the project. As with all build images, you need to configure a file called Dockerfile, which describes the steps to copy the project to the image and set up the startup mode:
Copy the current project contents to the /nebula web-console directory in the image. RUN NPM RUN build EXPOSE 7001 RUN [" NPM ", "RUN ", "docker-start"]Copy the code
Docker image volume optimization
If the Docker image is built according to the above configuration file, taking our project as an example, it will generate an image with a volume of about 1.3GB, which seems a little scary, because it takes a long time to download the image even on the user’s computer with fast Internet connection, which is unacceptable.
After investigating the relevant data, we learned that the Docker image volume can be reduced for optimization from the following aspects:
Base mirror source selection
The so-called base image source is a base environment (as shown in Node :10) that we select during the construction step. When we check the base environment image of Node.js on Dockerhub, we will find that there are multiple versions. Although they are all node.js related base images, different versions. In addition to the different node.js versions, the internal integration environment is also different. For example, the version with Alpine is equivalent to a relatively sophisticated Linux system image. In this version of the container running, you will find that there are no tools that come with our regular system, such as bash, curl, etc. So I’m going to reduce the volume.
According to the actual needs of the project, when I changed the basic image to alpine version and built it again, the volume of the image has been greatly reduced, from 1.3GB to 500+MB, and the volume optimization effect is obvious. Therefore, when you find that the volume of the image you built is too large, you can consider replacing the basic image source. See if you are using a bloated mirror source.
Multi-stage build mirror
The so-called multi-stage refers to the strategy adopted when Docker image is constructed. For details, please click the link provided.
Docker build rules
In short, use the rules provided by the Docker build: Dockerfile operation will add a “layer”, the so-called mirror mirror each layer will increase the volume, through the adoption of multi-step strategy, with the same meaning with each step contains a series of operations (such as build, deployment), step and step through the way of product image references, between the need to cut the final build image layer, Specific operations are as follows:
# set the image generated in step 1, And name it Builder FROM Node: 10-Alpine as Builder WORKDIR /nebula-web-console # Copy the current project contents to the image ADD. /nebula-web-console # RUN NPM install RUN NPM RUN build.... FROM node:10-alpine WORKDIR /nebula-web-console COPY --from= builder. /nebula web-console CMD [" NPM ", "run", "docker-start"]Copy the code
.dockerignore
Gitignore is the same as.gitignore. When we COPY or ADD files, we ignore unnecessary files (such as documentation files, git files, node_modules, and other files that are not required to be generated), so as to reduce the image size. Dockerignore.
Operation combined
Each operation adds a layer to the previous one. You can use & to merge multiple operations and reduce the number of layers. For example:
RUN NPM install RUN NPM RUN buildCopy the code
To:
RUN NPM install && NPM RUN buildCopy the code
Thus we reduce the increase in the number of layers, i.e. the volume of the mirror image. At the same time, we can reduce the number of “layers” added during the mirror building process by minimizing unnecessary operations while achieving the same goal.
Front-end conventional volume optimization
- Compressing ugly code and removing source code can be done during the build phase, which further reduces the image’s file size.
- Node_modules Downloads only the code required by the production environment. This can be done in the deployment phase, and only downloads the third-party dependencies required by the production environment:
npm install --production
。 - Public resources on CDN If the image is expected to run in the network environment, it can be considered to put some relatively large public files (pictures, third-party libraries, etc.) on the CDN server to strip out some resources and further reduce the volume.
- .
Just as a clue, more of the usual front-end optimization steps can be migrated to the mirror, after all, like our native development, the mirror build is also a running code environment.
summary
These are some of the ways I used to optimize image volume using A Docker image to run with Nebula Studio. For those of you who need a reference, please point out any inaccuracy. Also welcome to Nebula Graph Studio: github.com/vesoft-inc/…