The difference between images and containers in docker: 1. An image is a template that contains various environments or services, while a container is an instance of an image; 2. An image cannot be run and is static, while Containers are runnable and dynamic.
The operating environment of this tutorial: linux7.3 system, docker-1.13.1 version, Dell G3 computer.
What is the difference between an image and a container in docker?
1. Docker image
To understand the difference between a Docker image and a Docker container, indeed not easy.
Assuming that the Linux kernel is layer 0, then no matter how you run Docker, it will run on top of the kernel layer. This Docker image is a read-only image, located at layer 1. It cannot be modified or the state cannot be saved.
A Docker image can be built on top of another Docker image, and this cascading relationship can be multi-layered. The image layer of the first layer is called the base image (Base Image), and the images of other layers (except the top layer) are called the parent image (Parent Image). These images inherit all properties and settings from their parent image and add their own configuration in the Dockerfile.
Docker images are identified by image ID. The image ID is a 64-character hexadecimal string. But when we run an image, we usually don't use the image ID to refer to the image, but the image name. To list all valid local images, you can use the command
# docker images
Mirrors can be published as different versions. This mechanism is called Tag.
As shown in the figure above, the neo4j image has two versions: the lastest version and the 2.1.5 version.
You can use the pull command to add the specified label:
# docker pull ubuntu:14.04 # docker pull ubuntu:12.04
2. Docker container
Docker container can be created using the command:
# docker run imagename
It will add a writable layer on top of all image layers. This writable layer has processes running on the CPU and has two different states: Running and Exited. This is the Docker container. When we use docker run to start the container, the Docker container enters the running state. When we stop the Docker container, it enters the exit state.
When we have a running Docker container, all changes we make to it from the running state to the stopped state will be permanently written to the container's file system. Remember that changes to a container are written to the container's file system, not to the Docker image.
We can use the same image to start multiple Docker containers. These containers are all active after startup and are isolated from each other. Changes we make to one of the containers will only be limited to that container itself.
If the underlying image of the container is modified, the currently running container will not be affected and automatic updates will not occur.
If we want to update a container to a new version of its image, we must be careful to ensure that we build the data structure in the correct way, otherwise we may end up losing all the data in the container.
A 64-character hexadecimal string that defines the container ID, which is the unique identifier of the container. The interaction between containers is identified by the container ID. Since the characters of the container ID are too long, we usually only need to type the first 4 characters of the container ID. Of course, we can also use the container name, but it is obviously easier to use a 4-character container ID.
Recommended learning: "docker video tutorial"
The above is the detailed content of What is the difference between images and containers in docker. For more information, please follow other related articles on the PHP Chinese website!

Docker is important on Linux because Linux is its native platform that provides rich tools and community support. 1. Install Docker: Use sudoapt-getupdate and sudoapt-getinstalldocker-cedocker-ce-clicotainerd.io. 2. Create and manage containers: Use dockerrun commands, such as dockerrun-d--namemynginx-p80:80nginx. 3. Write Dockerfile: Optimize the image size and use multi-stage construction. 4. Optimization and debugging: Use dockerlogs and dockerex

Docker is a containerization tool, and Kubernetes is a container orchestration tool. 1. Docker packages applications and their dependencies into containers that can run in any Docker-enabled environment. 2. Kubernetes manages these containers, implementing automated deployment, scaling and management, and making applications run efficiently.

The purpose of Docker is to simplify application deployment and ensure that applications run consistently in different environments through containerization technology. 1) Docker solves the environmental differences problem by packaging applications and dependencies into containers. 2) Create images using Dockerfile to ensure that the application runs consistently anywhere. 3) Docker's working principle is based on images and containers, and uses the namespace and control groups of the Linux kernel to achieve isolation and resource management. 4) The basic usage includes pulling and running images from DockerHub, and the advanced usage involves managing multi-container applications using DockerCompose. 5) Common errors such as image building failure and container failure to start, you can debug through logs and network configuration. 6) Performance optimization construction

The methods of installing and using Docker on Ubuntu, CentOS, and Debian are different. 1) Ubuntu: Use the apt package manager, the command is sudoapt-getupdate&&sudoapt-getinstalldocker.io. 2) CentOS: Use the yum package manager and you need to add the Docker repository. The command is sudoyumininstall-yyum-utils&&sudoyum-config-manager--add-repohttps://download.docker.com/lin

Using Docker on Linux can improve development efficiency and simplify application deployment. 1) Pull Ubuntu image: dockerpullubuntu. 2) Run Ubuntu container: dockerrun-itubuntu/bin/bash. 3) Create Dockerfile containing nginx: FROMubuntu;RUNapt-getupdate&&apt-getinstall-ynginx;EXPOSE80. 4) Build the image: dockerbuild-tmy-nginx. 5) Run container: dockerrun-d-p8080:80

Docker simplifies application deployment and management on Linux. 1) Docker is a containerized platform that packages applications and their dependencies into lightweight and portable containers. 2) On Linux, Docker uses cgroups and namespaces to implement container isolation and resource management. 3) Basic usages include pulling images and running containers. Advanced usages such as DockerCompose can define multi-container applications. 4) Debug commonly used dockerlogs and dockerexec commands. 5) Performance optimization can reduce the image size through multi-stage construction, and keeping the Dockerfile simple is the best practice.

Docker is a Linux container technology-based tool used to package, distribute and run applications to improve application portability and scalability. 1) Dockerbuild and dockerrun commands can be used to build and run Docker containers. 2) DockerCompose is used to define and run multi-container Docker applications to simplify microservice management. 3) Using multi-stage construction can optimize the image size and improve the application startup speed. 4) Viewing container logs is an effective way to debug container problems.

Docker container startup steps: Pull the container image: Run "docker pull [mirror name]". Create a container: Use "docker create [options] [mirror name] [commands and parameters]". Start the container: Execute "docker start [Container name or ID]". Check container status: Verify that the container is running with "docker ps".


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Atom editor mac version download
The most popular open source editor

SublimeText3 Linux new version
SublimeText3 Linux latest version

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

Zend Studio 13.0.1
Powerful PHP integrated development environment

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.