search
HomeOperation and MaintenanceDockerWhat is docker container technology

Docker container technology refers to the fact that Docker is a container run by a program written in the GO language, which implements an application-level isolation; docker is designed for developers and system administrators to publish and an open platform for running distributed applications.

What is docker container technology

The operating environment of this tutorial: linux7.3 system, docker version 19.03, Dell G3 computer.

What is docker container technology

Docker container technology refers to Docker as a "container" (Linux containers, LXCs) run by a program written in the GO language. Docker implements an application level Isolation, it changes our basic development and operation unit from directly operating the virtual host (VM) to a "container" where the operating program runs.

Docker is an open platform designed for developers and system administrators to publish and run distributed applications. Composed of two parts: Docker Engine: a portable, lightweight runtime environment and package manager.

(Note* Single OS vs Single Thread) Docker Hub: A cloud service created for creating automated workflows and sharing applications. (Note* Cloud image/package management vs npm package management, is it particularly similar to npm?)

From March 20, 2013, the first version of Docker was officially released to Docker 1.0 in June 2014 It took 15 months for it to be officially released. Although its development history is very short, Docker is becoming more and more popular. In fact, Container technology is not an innovation of Docker. Cloud service providers such as HeroKu and NodeJitsu have adopted similar lightweight virtualization technology. However, Docker was the first to open source this Container technology on a large scale and was widely accepted by the community.

Container technology expansion

In the computer world, containers have a long and legendary history. Containers are different from hypervisor virtualization HV. Hypervisor virtualization uses an intermediate layer to virtualize one or more independent machines on physical hardware, while containers run directly on the operating system kernel. user space. Therefore, container virtualization is also called "operating system level virtualization". Container technology allows multiple independent user spaces to run on the same host.

Due to "guesting" in the operating system, the container can only run the same or similar operating system as the underlying host, which does not seem to be very flexible. For example: you can run Redhat Enterprise Linux in an Ubuntu service, but you cannot run Microsoft Windows on an Ubuntu server.

Containers are considered insecure relative to completely isolated hypervisor virtualization. Those who oppose this view believe that because virtual containers virtualize a complete operating system, this undoubtedly increases the scope of attacks, and the potential exposure risk of the hypervisor layer must also be considered.

Despite many limitations, containers are widely deployed in a variety of applications. Container technology is very popular in very large-scale multi-tenant service deployments, lightweight sandboxes, and isolation environments with less stringent security requirements. One of the most common examples is a "chroot jail", which creates an isolated directory environment to run processes. If the process running in the permission isolation prison is breached by an intruder, the intruder will find himself "in jail", trapped in the directory created by the container due to insufficient permissions, and unable to further damage the host machine.

The latest container technology introduces OpenVZ, Solaris Zones and Linux Containers (LXC). With these new technologies, containers are no longer just a simple operating environment. Within its own permission class, a container is more like a complete host. For Docker, it benefits from modern Linux features, such as control group and namespace technology. The isolation between the container and the host is more complete. The container has an independent network and storage stack, and also has Its own resource management capabilities enable multiple containers in the same host to coexist in a friendly manner.

Containers are considered a lean technology because containers require limited overhead. Compared with traditional virtualization and paravirtualization, containers do not require an emulation layer (emulation layer) and a management layer (hypervisor layer), but use the system call interface of the operating system. This reduces the overhead required to run a single container and allows more containers to be run on the host.

Despite their glorious history, containers are still not widely recognized. A very important reason is the complexity of container technology: containers themselves are complex, difficult to install, and difficult to manage and automate. And Docker was born to change all this.

Recommended learning: "docker video tutorial"

The above is the detailed content of What is docker container technology. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
docker中rm和rmi有什么区别docker中rm和rmi有什么区别Jul 14, 2022 am 11:02 AM

docker中rm和rmi的区别:rm命令用于删除一个或者多个容器,而rmi命令用于删除一个或者多个镜像;rm命令的语法为“docker rm [OPTIONS] CONTAINER [CONTAINER...]”,rmi命令的语法为“docker rmi [OPTIONS] IMAGE [IMAGE...]”。

docker官方镜像有哪些docker官方镜像有哪些May 12, 2022 pm 02:23 PM

docker官方镜像有:1、nginx,一个高性能的HTTP和反向代理服务;2、alpine,一个面向安全应用的轻量级Linux发行版;3、busybox,一个集成了三百多个常用Linux命令和工具的软件;4、ubuntu;5、PHP等等。

docker容器重启后数据会丢吗docker容器重启后数据会丢吗Jun 17, 2022 am 10:41 AM

docker容器重启后数据会丢失的;但是可以利用volume或者“data container”来实现数据持久化,在容器关闭之后可以利用“-v”或者“–volumes-from”重新使用以前的数据,docker也可挂载宿主机磁盘目录,用来永久存储数据。

docker是免费的吗docker是免费的吗Jul 08, 2022 am 11:21 AM

docker对于小型企业、个人、教育和非商业开源项目来说是免费的;2021年8月31日,docker宣布“Docker Desktop”将转变“Docker Personal”,将只免费提供给小型企业、个人、教育和非商业开源项目使用,对于其他用例则需要付费订阅。

docker能安装oracle吗docker能安装oracle吗Jul 08, 2022 pm 04:07 PM

docker能安装oracle。安装方法:1、拉取Oracle官方镜像,可以利用“docker images”查看镜像;2、启动容器后利用“docker exec -it oracle11g bash”进入容器,并且编辑环境变量;3、利用“sqlplus /nolog”进入oracle命令行即可。

docker存储空间不足怎么办docker存储空间不足怎么办Jul 22, 2022 pm 03:44 PM

解决方法:1、停止docker服务后,利用“rsync -avz /var/lib/docker 大磁盘目录/docker/lib/”将docker迁移到大容量磁盘中;2、编辑“/etc/docker/daemon.json”添加指定参数,将docker的目录迁移绑定;3、重载和重启docker服务即可。

有类似docker的软件吗有类似docker的软件吗May 12, 2022 pm 03:39 PM

有类似docker的软件:1、Podman,是一个无守护程序的开源Linux原生容器引擎;2、LXD,是一个专为LXC Linux容器设计的开源容器引擎;3、Buildah,是是红帽为容器化系统开发的一个OCI镜像构建工具;4、RunC等。

docker容器管理ui有哪些docker容器管理ui有哪些May 11, 2022 pm 03:39 PM

容器管理ui工具有:1、Portainer,是一个轻量级的基于Web的Docker管理GUI;2、Kitematic,是一个GUI工具,可以更快速、更简单的运行容器;3、LazyDocker,基于终端的一个可视化查询工具;4、DockStation,一款桌面应用程序;5、Docker Desktop,能为Docker设置资源限制,比如内存,CPU,磁盘镜像大小;6、Docui。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

SecLists

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.

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

SublimeText3 English version

SublimeText3 English version

Recommended: Win version, supports code prompts!