Docker容器引擎(1)

目录

一.Docker 概述

为什么要用到容器?

docker是什么?

 容器与虚拟机的区别?

docker的三个核心概念:

二.安装docker

安装依赖包:

安装 Docker-CE并设置为开机自动启动:

查看 docker 版本信息:

Docker 镜像操作:

搜索镜像:

获取镜像:

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

查看下载的镜像文件信息:

镜像加速下载:

修改镜像标签:

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

删除镜像:

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

将生成文件复制到20节点上:

到20节点上查看,并将镜像文件导入到镜像库中:

Docker 容器操作:

查看容器的运行状态:

启动容器:

停止容器:

进入容器:

我们要从宿主机上传文件到容器中:

​编辑

删除容器:

​编辑

容器的导出与导入:

退出后,生成文件:

传入文件:

run创建并启动容器:

当利用 docker run 来创建容器时, Docker 在后台的标准运行过程是:

我们将镜像nginx删除后再进行该命令的执行:


一.Docker 概述

为什么要用到容器?


1)容器可以屏蔽底层操作系统的差异性,让业务应用不管在哪里都是使用容器的环境运行,从而保证开发测试环境与生产环境的一致性
2)容器部署起来非常便捷和迅速,缩短开发测试部署的周期时间
 

Docker是一个开源的应用容器引擎,基于go语言开发并遵循了apache2.0协议开源。

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

docker是什么?


docker是用go语言开发并开源的容器引擎,用来运行容器里的应用。docker也是可用来管理容器和镜像的一种工具。
 

 容器与虚拟机的区别?

容器  :                                                        
所有容器共享宿主机的内核                                            
通过namespace实现资源隔离,通过cgroup实现限制资源的最大使用量        

秒级启动速度            
容器相当于宿主机的进程,性能几乎没有损耗    
单机容量能支持成百上千个容器                                        
 

虚拟机:

完全隔离。每个虚拟机都有独立的硬件资源                                
每个虚拟机都有独立的操作系统和内核 

 分钟级启动速度                                
需要通过hypervisor虚拟机管理程序对宿主机资源虚拟访问,有一定的性能损耗
单机容器只能支持最多几十个虚拟机

docker的三个核心概念:


镜像:是创建容器的基础,是一个只读的模板文件,里面包含运行容器中的应用程序所需要的所有内容(应用程序文件、配置文件、运行库文件、依赖包等)
容器:是用镜像运行的实例,容器可以被创建、启动、停止、删除,每个容器之间默认是相互隔离的
仓库:是用来集中保存镜像的地方,有公有仓库和私有仓库之分

二.安装docker

安装依赖包:

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

设置阿里云镜像源:

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

安装 Docker-CE并设置为开机自动启动:

yum install -y docker-ce docker-ce-cli containerd.io

安装好的Docker系统有两个程序,Docker服务端和Docker客户端。其中Docker服务端是一个服务进程,负责管理所有容器。 Docker客户端则扮演着Docker服务端的远程控制器,可以用来控制Docker的服务端进程。大部分情况下Docker服务端和客户端运行在一台机器上。

查看 docker 版本信息:

docker version

客户端信息:

服务端信息:

看详细信息:

docker info

客户端:

服务端:

Docker 的镜像、容器、日志等内容全部都默认存储在 /var/lib/docker:

Docker 镜像操作:

搜索镜像:

docker search 关键字

获取镜像:

docker pull 仓库名称[:标签(镜像的版本)

下载完成:

不加标签,会下载最新的版本的镜像:

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

docker images

查看下载的镜像文件信息:

cat /var/lib/docker/image/overlay2/repositories.json

镜像加速下载:

mkdir -p /etc/docker
tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://0ostn1c5.mirror.aliyuncs.com"]
}
EOF
systemctl daemon-reload
systemctl restart docker

再获取镜像就会加速:

修改镜像标签:

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

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

格式:docker inspect 镜像ID号

删除镜像:

docker rmi 仓库名称:标签:当一个镜像有多个标签时,只是删除其中指定的标签

docker rmi 镜像ID号:会彻底删除该镜像

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

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

再开启一台docker服务器:

将生成文件复制到20节点上:

到20节点上查看,并将镜像文件导入到镜像库中:

docker load < 存出的文件

docker load -i 存出的文件

先删除在进行导入:

Docker 容器操作:

容器创建:就是将镜像加载到容器的过程。

格式:docker create [选项] 镜像

常用选项:
-i:让容器开启标准输入接受用户输入命令
-t:让 Docker 分配一个伪终端 tty
-it :合起来实现和容器交互的作用,运行一个交互式会话 shell 

查看容器的运行状态:

docker ps -a  : -a 选项可以显示所有的容器,不加只显示运行状态的容器

启动容器:

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

停止容器:

0状态正正常关闭,137为异常关闭:

再创建容器:

进入容器:

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

-i 选项表示让容器的输入保持打开;
-t 选项表示让 Docker 分配一个伪终端。

登录容器:

退出:

我们要从宿主机上传文件到容器中:

现在宿主机添加文件:

docker cp  文件路径  容器名:绝对路径目录

查看容器mnt目录下:

从容器输出到宿主机上:

docker cp  容器名/容器ID :绝对路径目录  宿主机的文件路径

删除宿主机的文件:

查看下opt:

删除容器:

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

先停止:

再删除:

创建容器:开启并强制删除:

容器的导出与导入:

用户可以将任何一个 Docker 容器从一台机器迁移到另一台机器。在迁移过程中,可以使用docker export 命令将已经创建好的容器导出为容器快照文件,无论这个容器是处于运行状态还是停止状态均可导出。可将导出文件传输到其他机器,通过相应的导入命令实现容器的迁移。

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

docker export -o 文件名   容器ID/名称

先给容器添加文件:

退出后,生成文件:

导入格式:cat 文件名 | docker import – 镜像名称:标签

docker import  文件名  -- 镜像名称:标签

传入文件:

run创建并启动容器:

可以直接执行 docker run 命令, 等同于先执行 docker create 命令,再执行 docker start 命令。

当利用 docker run 来创建容器时, Docker 在后台的标准运行过程是:


(1)检查本地是否存在指定的镜像。当镜像不存在时,会从公有仓库下载;
(2)在只读镜像层挂载一层可读可写的容器层;
(3)从docker网桥接口中分配一个虚拟机接口和ip到容器中;
(4)使用镜像的默认启动命令或指定命令启动容器,直到容器pid=1的结束为止

格式:docker run  [选项] 镜像

-d:后台运行

--name:指定名字

-i:让容器开启标准输入接受用户输入命令

-t:让 Docker 分配一个伪终端 tty

--rm:删除

我们将镜像nginx删除后再进行该命令的执行:

先停止所依赖的镜像的容器的运行状态:

在进行run创建容器,本地是否存在指定的镜像。当镜像不存在时,会从公有仓库下载;

查看镜像:

查看容器:

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

10个常考的前端手写题,你全都会吗?(下)

前言 &#x1f4eb; 大家好&#xff0c;我是南木元元&#xff0c;热爱技术和分享&#xff0c;欢迎大家交流&#xff0c;一起学习进步&#xff01; &#x1f345; 个人主页&#xff1a;南木元元 今天接着上篇再来分享一下10个常见的JavaScript手写功能。 目录 1.实现继承 ES5继…

docker 部署springboot项目

新建Dockerfile ## AdoptOpenJDK 停止发布 OpenJDK 二进制&#xff0c;而 Eclipse Temurin 是它的延伸&#xff0c;提供更好的稳定性 ## 感谢复旦核博士的建议&#xff01;灰子哥&#xff0c;牛皮&#xff01; FROM eclipse-temurin:8-jre## 将后端项目的 Jar 文件&#xff0c…

软考复习之多媒体篇

常用的计算公式 数据传输率&#xff08;单位:b/s&#xff09; 未压缩的数据传输率 采样频率&#xff08;Hz&#xff09;* 量化位数&#xff08;位&#xff09;* 声道数 波形声音经过数字化后的信息数据量&#xff08;单位:字节&#xff09; 声音信号数据量 数据传输率 * …

简单实现网络编程

1. 前置知识 在学习网络编程前&#xff0c;我们需要先了解一些前置知识 1.1 客户端和服务器 在网络编程中&#xff0c;客户端和服务器是两个关键的角色。 客户端是发起连接并向服务器发送请求的一方。客户端通常是一个应用程序或设备&#xff0c;通过与服务器建立连接&…

白盒测试和黑盒测试的区别

黑盒测试 等价类划分 白盒测试 灰盒测试

K8S图像化工具rancher

Rancher是一个开源的企业级多集群的k8s管理平台 Rancher和k8s的区别 都是为了容器的调度和编排系统&#xff0c;但是rancher不仅能够调度&#xff0c;还能挂历k8s集群&#xff0c;自带监控&#xff08;普罗米修斯&#xff09;&#xff0c;你哪怕不知带k8s是什么&#xff0c;一样…

跟着pink老师前端入门教程-day09

二十二、定位 22.1 为什么需要定位 1. 某个元素可以自由的在一个盒子内移动位置&#xff0c;并且压住其他盒子 2. 当我们滚动窗口时&#xff0c;盒子是固定屏幕某个位置的 解决方法&#xff1a; 1. 浮动可以让多个块级盒子一行没有缝隙排列显示&#xff0c;经常用于横向排…

C#用DateTime.Now静态属性返回日期的星期信息

目录 一、使用的方法 1.Now属性 2.ToString方法 二、示例 使用DateTime结构的Now静态属性&#xff0c;可以方便地获取系统日期信息。调用时间对象的ToString方法&#xff0c;在该方法的参数中添加适当的格式化字符串&#xff0c;将返回日期的星期信息。 一、使用的方法 1…

C语言入门到精通之练习实例10:打印楼梯,同时在楼梯上方打印两个笑脸(附源码)

题目&#xff1a;打印楼梯&#xff0c;同时在楼梯上方打印两个笑脸。 程序分析&#xff1a;用 ASCII 1 来输出笑脸&#xff1b;用i控制行&#xff0c;j来控制列&#xff0c;j根据i的变化来控制输出黑方格的个数。 如果出现乱码情况请参考【C 练习实例7】的解决方法。 // Cr…

uniapp 在static/index.html中添加全局样式

前言 略 在static/index.html中添加全局样式 <style>div {background-color: #ccc;} </style>static/index.html源码&#xff1a; <!DOCTYPE html> <html lang"zh-CN"><head><meta charset"utf-8"><meta http-…

从零开始用Rust编写nginx,命令行参数的设计与解析及说明

wmproxy wmproxy已用Rust实现http/https代理, socks5代理, 反向代理, 静态文件服务器&#xff0c;四层TCP/UDP转发&#xff0c;七层负载均衡&#xff0c;内网穿透&#xff0c;后续将实现websocket代理等&#xff0c;会将实现过程分享出来&#xff0c;感兴趣的可以一起造个轮子 …

教育研究方法有哪些分类

教育研究方法的分类是多种多样的&#xff0c;可以从不同的角度进行划分。根据研究目的、研究范围、研究层次等&#xff0c;可以将教育研究方法分为不同的类型。 一、根据研究目的划分 基础性研究基础性研究也称为理论性研究&#xff0c;主要是为了探索和发现新的理论观点和原…

uniapp开发过程一些小坑

问题1、uniapp使用scroll-view的:scroll-into-view“lastChatData“跳到某个元素id时候&#xff0c;在app上不生效&#xff0c;小程序没问题 使用this.$nextTick或者 setTimeout(()>{that.lastChatData 元素id },500) 进行延后处理就可以了。 问题2&#xff1a;uniapp开…

运动刷步工具2.4。运动步数同步wx和支付宝

时隔一年&#xff1b;上次更新还是2022-11-26&#xff0c;陆续收到私信旧版已不能使用&#xff0c;2.4版本更新修复超时问题。后续有时间还会更新邮箱登录功能2023-11-15更新&#xff1a;修复错误超时问题测试不行的小伙伴&#xff0c;先看说明再使用&#xff01;&#xff01;&…

关于常见分布式组件高可用设计原理的理解和思考

文章目录 1. 数据存储场景和存储策略1.1 镜像模式-小规模数据1.2 分片模式-大规模数据 2. 数据一致性和高可用问题2.1 镜像模式如何保证数据一致性2.2 镜像模式如何保证数据高可用2.2.1 HA模式2.2.2 分布式选主模式 2.3 分片模式如何数据一致性和高可用 3. 大规模数据集群的架构…

垃圾收集算法

垃圾收集算法有如下几种&#xff1a; 分代收集理论&#xff1a;年龄代和老年代选择各自的垃圾收集算法。 复制算法&#xff1a;可达性分析算法找非垃圾对象&#xff0c;然后把非垃圾对象移动到另一端&#xff0c;这一端的垃圾对象清除&#xff0c;该方法浪费内…

如何查找SpringBoot应用中的请求路径(不使用idea)

背景 昨天有个同事向我咨询某个接口的物理表是哪个&#xff0c;由于公司业务较多、这块业务的确不是我负责的&#xff0c;也没有使用idea不能全局搜索(eclipse搜不到jar内的字符串)&#xff0c;也就回复了不清楚。 除了自己写代码输出servlet的路径和类外&#xff0c;发现了一…

【JVM故障问题排查心得】「Java技术体系方向」Java虚拟机内存优化之虚拟机参数调优原理介绍

Java技术体系方向-JVM虚拟机参数调优原理 内容简介栈上分配与逃逸分析逃逸分析(Escape Analysis)栈上分配基本思想使用场景线程私有对象 虚拟机内存逻辑图JVM内存分配源码&#xff1a;代码总体逻辑 在某些场景使用栈上分配设置JVM运行参数&#xff1a;开启逃逸模式&#xff0c;…

书生·浦语大模型--第四节课笔记--XTuner大模型单卡低成本微调

文章目录 Finetune简介指令跟随微调增量预训练微调LoRA QLoRA XTuner介绍快速上手 8GB显卡玩转LLM动手实战环节 Finetune简介 增量预训练和指令跟随 通过指令微调获得instructed LLM 指令跟随微调 一问一答的方式进行 对话模板 计算损失 增量预训练微调 不需要问题只…

数据结构:3_栈和队列

栈和队列 一.栈 1. 栈的概念及结构 栈&#xff1a;一种特殊的线性表&#xff0c;其只允许在固定的一端进行插入和删除元素操作。**进行数据插入和删除操作的一端称为栈顶&#xff0c;另一端称为栈底。**栈中的数据元素遵守后进先出LIFO&#xff08;Last In First Out&#x…