docker基本管理和概念

1、定义:一个开源的应用容器引擎,基于go语言开发,运行在liunx系统中的开源的、轻量级的“虚拟机”

docker的容器技术可以在一台主机上轻松的为任何应用创建一个轻量级的、可移植的、自给自足的容器

docker的宿主机是liunx系统,集装箱可以理解为相互隔离的容器(组件或应用程序APP),每个容器都是一个独立的应用程序

2docker设计宗旨

build,ship and run any app,anywhere一次封装,到处运行

build:封装好的程序,只要部署即可使用,一次封装

ship and run any app:一次封装完成之后的程序可以在任何环境运行

anywhere:任意宿主机

过程:封装、发布、部署、运行、维护、运行、销毁。可以一整套的方式管理应用程序的声明周期

3docker优点

(1)灵活:再复杂的应用也可以实现容器化

(2)轻量级:小型的、不完整的、最小化封装的程序,与宿主机共享一个内核

(3)可互换:可以随时升级、更新

(4)便携式:本地、云平台都可以构建、部署(在任何地方运行)

(5)可扩展:自动分发容器副本(自动进行部署)

(6)可堆叠:在一个宿主机上可以创建不同版本的同一容器,也可以是多个相同版本的同一容器

4、liunx命名空间namespace

namespace:是一种内核特性,允许将一组系统资源隔离,在一个命名空间的进程在系统中可以拥有独立的资源

【面试题】namespace的六项隔离措施

基于这六个隔离项,实现容器和容器之间、容器和宿主机之间的资源隔离

①UTS

系统调用参数:CLONE_NEWUTS

隔离内容:主机与域名。在UTS命名空间中创建进程,进程可以看见自己的主机与域名,与其他进程分隔开

②IPC

系统调用参数:CLONE_NEWIPC

隔离内容:信号量、消息队列、共享内存。在IPC命名空间中,进程可以拥有独立的进程间通信资源

③PID

系统调用参数:CLONE_NEWPID

隔离内容:每个进程都有自己独立的进程号空间

④network

系统调用参数:CLONE_NEWNET

隔离内容:网络设备、网络栈、端口。每个进程都有一个自己独立的网络资源、端口号

⑤mount

系统调用参数:CLONE_NEWNS

隔离内容:挂载点。在mount命名空间中,每个进程或设备都有一个自己的文件系统挂载点,相互之间互不干扰

⑥user

系统调用参数:CLONE_NEWUSER

隔离内容:用户和用户组

docker下载链接:https://hub.docker.com/

5、docker的核心组件

  1. 镜像:docker的基础,最小单位,类似于虚拟机ISO文件,可可理解为压缩包,但不是解压即用,是一个环境部署的脚本,甚至包含完整的操作系统。一个镜像就是一个可执行的包,包里包含运行这个程序的所有内容(代码、配置文件、环境变量等)
  2. 容器:docker的容器是基于镜像运行起来的实例,可以启动、停止、删除。每一个容器是相互隔离的,互不可见
  3. 仓库:保存镜像。所有的镜像都是从仓库中获取的。分为公有仓库和私有仓库。在linux系统中下载到本地,镜像、容器、日志默认在/var/lib/docker中

6、docker与传统虚拟机之间的区别【面试题。应届】

特性

docker

虚拟机

启动速度

秒级

分钟级

计算能力损耗

几乎无

损耗50%

性能

接近原生系统

弱于原生系统

系统支持量

上千个

根据硬件系统条件(几十个)

隔离性

资源隔离

完全隔离

安全性

安全性差

安全性好

7安装docker【docker只支持64位系统,最少2核4G】

(1)安装依赖包

yum -y install yum-utils device-mapper-persistent-data lvm2

yum-utils

提供yum-cofig-manager工具,可以远程自定义获取yum源

device-mapper-persistent

进行逻辑卷管理的通用设备映射机制

(2)设置阿里云镜像源

yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

(3)安装 Docker-CE并设置为开机自动启动

yum -y install docker-ce docker-cs-cli contarnerd.io

systemctl start docker.service

systemctl enable docker.service

docker-ce

docker的社区版,面向开发者、小型团队和个人使用。免费

docker-cs-cli

提供docker的命令行工具

contarnerd.io

负责管理容器的生命周期(创建、运行、停止、继续、销毁)

docker安装完毕

(4)镜像加速下载

浏览器访问 https://cr.console.aliyun.com/cn-hangzhou/instances/mirrors 获取镜像加速器配置

8、docker命令

查看 docker 版本信息

docker version

docker 信息查看

docker info

Docker 镜像操作

搜索镜像

docker search 关键字

获取镜像

docker pull 镜像名称:标签

查看下载到本地的所有镜像

docker images

根据镜像的唯一标识 ID 号,获取镜像详细信息

docker inspect 镜像ID号

为本地的镜像添加新的标签

docker tag 名称:标签 新名称:新标签

删除镜像

docker rmi 仓库名称:标签

存储镜像:将镜像保存成为本地文件

docker save -o 存储文件名 存储的镜像

载入镜像:将镜像文件导入到镜像库中

docker load -i 存出的文件

上传镜像

docker tag nginx:latest soscscs/nginx:web

#新的标签时必须在前面加上自己的dockerhub的username

docker login

登录公共仓库

Username:annie1234

password:【常用密码】

docker push soscscs/nginx:web  #上传镜像

Docker 容器操作

创建容器

docker create [选项] 镜像

查看容器的运行状态

docker ps -a(所有容器)

docker ps (正在运行的容器)

启动容器

docker start 容器的ID/名称

直接创建并运行容器

docker run -itd --name 容器名称 镜像:标签 /bin/bash

进入容器(进入容器前,确保容器正在运行)

docker exec -it 容器ID/名称 /bin/bash

退出容器

exit

终止容器运行

docker stop 容器的ID/名称

本地文件复制到容器

docker cp 本地文件存放路径 容器名称:存放文件路径

容器的导出与导入

导出格式:docker export -o 文件名 容器ID/名称

导入格式:docker import 文件名 -- 镜像名称:标签

删除容器(正在运行的容器)

强制删除:docker rm -f 容器ID/名称

先停再删:docker stop 容器ID/名称

          docker rm 容器ID/名称

批量停止容器

docker ps -a | awk 'NR>=2{print $1}'| xargs docker stop

批量删除所有容器【慎用】

docker ps -a | awk 'NR>=2{print $1}'| xargs docker rm

批量删除none镜像

docker images | grep none | awk '{print $3}' | xargs docker rmi

批量清理后台停止的容器

docker rm $(docker ps -a -q)

①查看 docker 版本信息

docker version

②查看本机docker所有信息

docker info

docker安装完毕后,客户端和服务端都运行在一台机器上

Client

客户端

Server

服务端

overlay2

docker使用的文件系统驱动

overlayFS

overlay file system联合文件系统,用于适配宿主机的文件系统,可以自动适配

(1)docker的镜像操作

①搜索镜像

格式:docker search 关键字

name

镜像名称

description

描述信息

stars

点赞数

official

官方镜像

automated

自动化构建

②获取镜像(拉取镜像)

格式:docker pull 镜像名称[:标签]

#如果下载镜像时不指定标签,则默认会下载仓库中最新版本的镜像,即选择标签为 latest 标签

#加上标签,下载的就是该版本的镜像

③查看下载到本地的所有镜像

docker images

repository

镜像所属的仓库

tag

镜像的标签信息,标记同一个仓库中的不同镜像

image id

镜像的唯一ID 号,唯一标识一个镜像(不重复)

created

镜像创建时间

size

镜像大小

④根据镜像的唯一标识 ID 号,获取镜像详细信息

格式:docker inspect 镜像ID号

lowerDir

底层目录。整个docker的底层文件系统,是一个或多个镜像文件的根文件系统

UpperDir

可写层。可以在容器运行时,在容器内进行写操作,实现容器的可写性

MergeDir

合并目录。lowerDir和UpperDir合并起来形成容器的文件系统,用户看到的也是这个合并视图

workDir

工作目录。处理文件系统变更,当在容器内进行写操作时,overlayfs使用workDir追踪文件系统的变更

⑤为本地的镜像添加新的标签

格式:docker tag 名称:标签 新名称:新标签

⑥删除镜像

方法1:

格式:docker rmi -f 镜像ID  #强制删除镜像

方法2:

格式:docker rmi 镜像名称:标签

#当一个镜像有多个标签时,只是删除其中指定的标签

格式:docker rmi 镜像ID号

#会彻底删除该镜像

注意:一个镜像有多个标签,删除时只是删除标签;只剩最后一个,删除的是镜像本身。若镜像已被容器使用,先停止容器,再删除容器,最后删除镜像

⑦存储镜像:将镜像保存成为本地文件

格式:docker save -o 存储文件名 存储的镜像

⑧载入镜像:将镜像文件导入到镜像库中

格式:docker load -i 存储的文件

⑨上传镜像

docker tag nginx:latest annie1234/nginx:1.22.0

#添加新的标签时必须在前面加上自己的dockerhub的用户名

docker login

#登录公共仓库

Username:annie1234

password:【常用密码】

docker push annie1234/nginx:1.22.0  #上传镜像

(2)docker容器操作

①创建容器

格式:docker create -it 镜像

-it

宿主机和容器形成一个可以交互的shell命令行

-i

表示让容器开启标准输入,接收用户的输入命令

-t

给容器分配终端(虚拟的伪终端)

注意:创建容器后自动创建一个docker0

②查看容器的运行状态

docker ps -a #显示所有的容器

docker ps    #显示正在运行的容器

③启动容器

格式:docker start 容器的ID/名称

up表示容器正在运行

exited表示容器退出,不运行

④直接创建并运行容器

格式:docker run -itd --name 容器名称 镜像:标签 /bin/bash

-d

可以让创建的容器以守护进程形式在后台运行,容器运行的程序不会结束

问题1:没有镜像能不能直接run?

可以,会自动拉取镜像

问题2:运行的程序是什么?不运行会怎样?

/bin/bash。-d结合,会给容器一个直接运行的命令,后台没有指令,容器没有可运行的程序,将会直接退出

-it

形成交互式的shell命令

-name

给容器命名

nginx:latest

镜像名称和标签,若本地没有可以自动下载

⑤进入容器(进入容器前,确保容器正在运行)

格式:docker exec -it 容器ID/名称 /bin/bash

⑥退出容器exit

⑦终止容器运行

格式:docker stop 容器的ID/名称

⑧本地文件复制到容器

格式:docker cp 本地文件存放路径 容器名称:存放文件路径

⑨容器文件复制到本地

⑩容器的导出与导入

导出格式:docker export -o 文件名 容器ID/名称

导入格式:docker import 文件名 -- 镜像名称:标签

注意:导出的容器仍然是一个镜像,必须要运行run或create才能成为容器;已经配置好的导出的容器镜像,可以部署到其他主机直接使用(工作中,我们用的都是开发已设置、配置好的容器镜像)

docker特性:即使在创建过程中报错,容器仍会被创建,但此容器不可用;导入镜像,或者导入容器镜像,若标签和已有标签重复,导入的镜像或者容器镜像tag变成none

⑪删除容器(正在运行的容器)

格式:docker rm -f 容器ID/名称

方法1:强制删

方法2:先停再删

⑫批量操作【不建议使用批量操作】

批量停止容器

docker ps -a | awk 'NR>=2{print $1}'| xargs docker stop

批量删除所有容器【慎用】

docker ps -a | awk 'NR>=2{print $1}'| xargs docker rm

批量删除none镜像

docker images | grep none | awk '{print $3}' | xargs docker rmi

批量清理后台停止的容器

docker rm $(docker ps -a -q)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/212121.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Maven——使用Nexus创建私服

私服不是Maven的核心概念,它仅仅是一种衍生出来的特殊的Maven仓库。通过建立自己的私服,就可以降低中央仓库负荷、节省外网带宽、加速Maven构建、自己部署构件等,从而高效地使用Maven。 有三种专门的Maven仓库管理软件可以用来帮助大家建立…

六个自媒体写作方法,提升自媒体创作收益

在自媒体时代,写作成为了一个不可或缺的技能。特别是对于新手来说,掌握一些有效的写作方法,可以事半功倍,更好地展现个人创意和观点。在这里,我将分享六个适合新手的自媒体写作方法,希望能够为你在写作之路…

class039 嵌套类问题的递归解题套路【算法】

class039 嵌套类问题的递归解题套路 算法讲解039【必备】嵌套类问题的递归解题套路 Code1 772. 基本计算器 III 实现一个基本的计算器来计算简单的表达式字符串。 表达式字符串只包含非负整数,算符、-、*、, ,左括号(和右括号)。整数除法需要向下截…

unity学习笔记

一、射线检测 如何让鼠标点击某个位置,游戏角色就能移动到该位置? 实现的原理分析:我们能看见游戏的东西就是摄像机拍摄到的东西,所以摄像机的镜平面就是当前能看到的了。 那接下来我们可以让摄像机发射一条射线,鼠标…

【网络编程】-- 01 概述、IP

网络编程 1 概述 1.1 计算机网络 (连接分散计算机设备以实现信息传递的系统) 计算机网络是指将地理位置不同的具有独立功能的多台计算机及其外部设备,通过通信线路连接起来,在网络操作系统,网络管理软件及网络通信协议的管理和协调下&…

06 硬件知识入门(MOSS管)

1 简介 MOS管和三极管的驱动方式完全不一样,以NPN型三极管为例,base极以小电流打开三极管,此时三极管的集电极被打开,发射极的高电压会导入,此时电流:Ic IbIe ;电压:Ue>Uc>Ub…

JAVA IO:NIO

1.阻塞 IO 模型 ​ 最传统的一种 IO 模型,即在读写数据过程中会发生阻塞现象。当用户线程发出 IO 请求之后,内核会去查看数据是否就绪,如果没有就绪就会等待数据就绪,而用户线程就会处于阻塞状态,用户线程交出 CPU。当…

HarmonyOS ArkTS与c++交互通信

一、创建Native C Module 1、右键项目->new->module 如图: 2、修改build-profile.json5配置 "externalNativeOptions": {"path": "./src/main/cpp/CMakeLists.txt","arguments": "-v -DOHOS_STLc_shared&quo…

java--枚举

1.枚举 枚举是一种特殊类 2.枚举类的格式 注意: ①枚举类中的第一行,只能写一些合法的标识符(名称),多个名称用逗号隔开。 ②这些名称,本质是常量,每个常量都会记住枚举类的一个对象。 3.枚举类的特点 ①枚举类的…

ArcGIS提示当前许可不支持影像服务器

1、问题&#xff1a; 在用ArcGIS上处理影像栅格数据时&#xff08;比如栅格数据集裁剪、镶嵌数据集构建镶嵌线等&#xff09;经常会出现。 无法启动配置 RasterComander.ImageServer <详信息 在计算机XXXXX上创建服务器对象实例失败 当前许可不支持影像服务器。 ArcGIS提示当…

ChatGPT学习笔记

1 ChatGPT架构图 &#xff08;ChatGPT_Diagram.svg来自于【OpenA | Introducing ChatGPT】&#xff09; 2 模型训练 ChatGPT在训练时使用了PPO方法&#xff1b;

视界臻色彩 轻巧薄未来 《2023年中国OLED电视发展白皮书》发布

随着中国经济迈入新周期&#xff0c;彩电行业也进入存量竞争阶段。在此背景下&#xff0c;主流品牌围绕新产品、新技术、新应用等方面积极发力&#xff0c;特别是在高端彩电市场的争夺中&#xff0c;伴随着三星OLED的入局开始变得愈发激烈。我国“十三五”规划中明确指出&#…

算法通关村第三关—双指针思想及其应用(白银)

双指针思想及其应用 一、双指针思想 这里介绍一种简单但非常有效的方式一双指针。所谓的双指针其实就是两个变量&#xff0c;不一定真的是指针。双指针思想简单好用&#xff0c;在处理数组、字符串等场景下很常见。 看个例子&#xff0c;从下面序列中删除重复元素[1,2,2,2,3,…

如何使用phpStudy本地快速搭建网站并内网穿透远程访问

文章目录 使用工具1. 本地搭建web网站1.1 下载phpstudy后解压并安装1.2 打开默认站点&#xff0c;测试1.3 下载静态演示站点1.4 打开站点根目录1.5 复制演示站点到站网根目录1.6 在浏览器中&#xff0c;查看演示效果。 2. 将本地web网站发布到公网2.1 安装cpolar内网穿透2.2 映…

Spring 声明式事务

Spring 声明式事务 1.Spring 事务管理概述1.1 事务管理的重要性1.2 Spring事务管理的两种方式1.2.1 编程式事务管理1.2.2 声明式事务管理 1.3 为什么选择声明式事务管理 2. 声明式事务管理2.1 基本用法2.2 常用属性2.2.1 propagation&#xff08;传播行为&#xff09;2.2.2 iso…

(动手学习深度学习)第13章 实战kaggle竞赛:树叶分类

文章目录 实战kaggle比赛&#xff1a;树叶分类1. 导入相关库2. 查看数据格式3. 制作数据集4. 数据可视化5. 定义网络模型6. 定义超参数7. 训练模型8. 测试并提交文件 竞赛技术总结1. 技术分析2. 数据方面模型方面3. AutoGluon4. 总结 实战kaggle比赛&#xff1a;树叶分类 kagg…

MYSQL练题笔记-排序和分组-全7题已完成

排序和分组这部分共7道题&#xff0c;如下&#xff0c;只说一说3道&#xff0c;其他都写对了&#xff0c;也不难&#xff0c;只有最后一题难一点点&#xff0c;没想到那种解法&#xff0c;一看到主键和外键就想利用连接。 1.销售分析的题目和表相关内容如下 就是利用product_id…

西工大计算机学院计算机系统基础实验一(函数编写11~14)

稳住心态不要慌&#xff0c;如果考试周冲突的话&#xff0c;可以直接复制这篇博客和上一篇博客西工大计算机学院计算机系统基础实验一&#xff08;函数编写1~10&#xff09;-CSDN博客最后的代码&#xff0c;然后直接提交&#xff0c;等熬过考试周之后回过头再慢慢做也可以。 第…

pycharm使用Anaconda中的虚拟环境【我的入门困惑二】

Anaconda的作用 Anaconda的存在&#xff0c;使得一台电脑上可以存在多个不同版本的python和相应的包&#xff0c;这解决了多个项目运行时&#xff0c;所需要的python和包版本不同的问题。 本文内容 今天就来简单说说如何在pycharm使用Anaconda中的虚拟环境。 详细介绍 首先…