Docker知识--01

虚拟化

# 什么是虚拟化
         在计算机中,虚拟化(英语:Virtualization)是一种资源管理技术,是将计算机的各种实体资源,如服务器、网络、内存及存储等,予以抽象、转换后呈现出来,打破实体结构间的不可切割的障碍,使用户可以比原本的组态更好的方式来应用这些资源。这些资源的新虚拟部份是不受现有资源的架设方式,地域或物理组态所限制。一般所指的虚拟化资源包括计算能力和资料存储。
        在实际的生产环境中,虚拟化技术主要用来解决高性能的物理硬件产能过剩和老的旧的硬件产能过低的重组重用,透明化底层物理硬件,从而最大化的利用物理硬件  对资源充分利用,虚拟化技术种类很多,例如:软件虚拟化、硬件虚拟化、内存虚拟化、网络虚拟化、桌面虚拟化、服务虚拟化、虚拟机等等。

# 虚拟化的软件有哪些
kvm:开源的免费的,是一个开源的系统虚拟化模块,自Linux 2.6.20之后集成在Linux的各个主要发行版本中
exsi :vmware商用的,装在裸机上,可以虚拟化出很多机器

vmware 装的哪个虚拟机软件VMware Workstation Pro

------对机器进行虚拟化------
 openstack(python开发的,开源的):电信云,华为云 openstack  

                管理云平台:对虚拟化出的虚拟机进行管理,创建虚拟化,删除虚拟机
阿里云(自研,阿里飞天):云服务器,到一个网站,点点---付款--完成
腾讯自研
----- 对虚拟机进行管理----
    docker:容器技术--学习---创建一个个容器
    docker-compose:单机容器管理(编排)
    docker-swarm:docker官方出的,用的很少
     k8s:多机容器管理,容器编排:谷歌公司出的
 -----容器管理------
# 名词补充:linux的软件
    nginx:反向代理服务器-web项目上线--转发--负载均衡
    paramiko:python的模块,ssh链接操作linux机器,远程执行命令
    ansible:python写的,基于paramiko封装--基于ssh链接--速度慢一些---管理机器少一些
                指令,palybook--批量操作远程linux机器
                python的sdk:包
    salstack:批量管理远程linxu机器的--基于bs架构:主控机--被控机
    zabbix:监控php写的有web页面---监控 进程 
    普罗米修斯:go语言写的 ,监控容器运行,没有web页面
    granfan:前端--》对接上普罗米修斯---》显示监控情况
    jenkins:java写的  持续集成工具,用于监控持续重复的工作
    gitlab:代码仓库

docker架构

# 起源:

        Docker 是一个开源项目,诞生于 2013 年初,最初是 dotCloud 公司内部的一个业余项目。它基于 Google 公司推出的 Go 语言实现。 项目后来加入了 Linux 基金会,遵从了 Apache 2.0 协议,项目代码在 [GitHub](https://github.com/docker/docker) 上进行维护

        Docker 自开源后受到广泛的关注和讨论,以至于 dotCloud 公司后来都改名为 Docker Inc。Redhat 已经在其 RHEL6.5 中集中支持 Docker;Google 也在其 PaaS 产品中广泛应用

         Docker 项目的目标是实现【轻量级的操作系统虚拟化解决方案】。 Docker 的基础是 Linux 容器(LXC)等技术

        LXC 的基础上 Docker 进行了进一步的封装,让用户不需要去关心容器的管理,使得操作更为简便。用户操作 Docker 的【容器就像操作一个快速轻量级的虚拟机】一样简单

# Docker 概念:

       docker 是cs架构  ,mysql,redis,c和s要通信,底层tcp协议,自己做封装

       dockerc和s要通信,没有自定义协议,使用的http协议,符合resful规范
                        mysql://地址+端口
                        redis://地址+端口
                        http://地址+端口                

# 镜像和容器:
Docker镜像:镜像是基于一堆文件,类似于:虚拟机装操作系统的centos xx.iso 文件,4个多g,带了软件,类似于一堆文件

Docker容器:镜像运行起来,成为了容器,【当成一台虚拟机上面装了一些软件
    一个镜像运行出多个容器---容器当成轻量级的操作系统
    类和对象的概念:镜像是类---生成多个对象
Registry(注册中心):docker仓库拉取镜像的位置
    -镜像是从注册中心中拉取下来

Docker安装

# 在linux机器上安装:
1、卸载docker:
        yum remove docker docker-common  docker-selinux docker-engine
        rm -rf /var/lib/docker

2、yum 包更新到最新:sudo yum update
3、安装需要的软件包, yum-util 提供yum-config-manager功能,另外两个是devicemapper驱动依赖的

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

4、设置yum源为阿里云

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

5、安装docker:sudo yum install docker-ce
6、安装后查看docker版本:docker -v

7、启动docker

    systemctl status docker         # 查看docker软件运行状态
    systemctl start docker           #启动docker    
    systemctl restart docker       # 重启
    systemctl stop docker          # 停止

8、拉取镜像
9、查看本地镜像:docker images

10、运行成容器
运行cento7镜像成容器: docker run -di --name=centos  centos:7

11、查看正在运行的容器:docker ps

        docker exec -it 容器id号  /bin/bash

# 保存退出
        systemctl daemon-reload   # 重新加载docker配置
        systemctl restart docker  # 重启docker

docker和传统虚拟机比较

# docker 不需要虚拟化出 操作系统这一层---更轻量级--占空间更新---还能实现隔离

# 虚拟机技术的缺点:
    1.资源占用太多
    2.冗余步骤多
    3.启动很

# 容器化技术:
        1.服务器资源利用率高
        2.比较轻量化
        3.打包镜像测试,一键运行

比较Docker和虚拟机技术不同:
​ 1.传统虚拟机虚出一条硬件,运行一个完整的操作系统,然后在这个系统上安装和运行软件
​ 2.容器内的应用之间运行在 宿主机的内容,容器是没有自己的内核的,也没有虚拟我们的硬件,所以久轻便了
​ 3.每个容器间是互相隔离的,每个容器内都有属于自己的文件系统,互不影响
​ 4.安全性,docker的安全性更弱,
​ 5.与虚拟机相比,docker隔离性更弱,docker属于进程之间的隔离,虚拟机可实现系统级别隔离

6、docker创建时秒级的,docker快速迭代性,无论是开发、测试、部署都可以节约大量时间

docker镜像操作

#  搜索镜像:
    去网站搜:https://hub.docker.com/ 
    使用命令行搜:docker search mysql
# 获取镜像,拉去镜像---从register下载到本地--阿里云镜像站--加速拉取
    docker pull mysql:5.7 # 下载mysql 5.7镜像
    docker pull redis:latest # 下载redis最新的镜像
    docker pull nginx:latest  # 下载 nginx最新的镜像
    docker pull centos:centos7  # 下载 nginx最新的镜像
#  查看镜像:
            docker images

#  删除镜像:
            docker rmi redis:latest

注册并登录到远程仓库

# gitee---远程仓库---本地代码---提交
            登录进入可以看到你开源的项目
   docker--hub.docker--镜像----我们自己的镜像,也可以传上去,给所有人用
            登录进入:就能看到你传的镜像

# 注册一个hub.docker 的账号
# 登录进入


# 上传你的镜像 :
1、登录:docker login     

2、给镜像打个标签:docker tag 本地镜像名:标签  你的名字/镜像名字:标签
        docker tag redis:latest   liuqingzheng/rredis:vv1   3、上传到远程仓库:docker push liuqingzheng/rredis:vv1

docker容器操作

# 把镜像运行成容器,并且一个镜像,可以运行出多个容器

         把centos7 运行成容器
        --name=centos7 容器名
        run :创建并运行
        -di :创建出容器并运行,命令行还在宿主机
        docker run  -di --name=centos77 centos:centos7

查看正在运行的容器:docker ps


查看所有容器:docker ps -a
查看最后一次运行的容器:docker ps -l
启动停止的容器:docker start id/名字

停止运行的容器:docker stop 7d5e

停止所有在运行的容器:docker stop `docker ps -q`
删除容器:
    docker rm 容器id
# 记住四条:
    docker ps
    docker ps -a
    docker start
    docker stop
# 进入到容器内部:
        docker exec -it 容器id /bin/bash
        docker exec -it 90fd0665494f /bin/bash

# 在centos的容器中安装mysql 3.9 
    不是在宿主机上装
    容器中

今日思维导图:

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

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

相关文章

【计算机网络】IP 协议

网络层IP协议 一、认识 IP 地址二、IP 协议报头格式三、网段划分1. 初识子网划分2. 理解子网划分3. 子网掩码4. 特殊的 IP 地址5. IP 地址的数量限制6. 私有 IP 地址和公网 IP 地址7. 理解全球网络(1)理解公网(2)理解私网&#xf…

C语言---指针的两个运算符:点和箭头

目录 点(.)运算符箭头(->)运算符需要注意实际例子 C语言中的指针是一种特殊的变量,它存储了一个内存地址。点(.)和箭头(->)是用于访问结构体和联合体成员的运算符。…

[LeetBook]【学习日记】排序算法——归并排序

主要思想 归并排序是一种分治算法,其排序过程包括分和治分是指将要排序的序列一分为二、二分为四,直到单个序列中只有一个数治是指在分完后,将每两个元素重新组合,四合为二、二合为一,最终完成排序 图片作者&#xf…

SkiaSharp使用SKCanvas.DrawText绘制2D文本时部分字符渲染位置异常。

Skia是一个开源的 2D 图形库,支持多种平台和语言,可以用于绘制各种图形和效果,SkiaSharp是其.Net版本。 在绘制文本时,一般做法是: private void SkContainer_PaintSurface(object? sender, SkiaSharp.Views.Deskto…

Linux系统安装宝塔面板结合内网穿透实现公网登录本地面板——“cpolar内网穿透”

文章目录 一、使用官网一键安装命令安装宝塔二、简单配置宝塔,内网穿透三、使用固定公网地址访问宝塔 宝塔面板作为建站运维工具,适合新手,简单好用。当我们在家里/公司搭建了宝塔,没有公网IP,但是想要在外也可以访问内…

Midjourney 和 Dall-E 的优劣势比较

Midjourney 和 Dall-E 的优劣势比较 Midjourney 和 Dall-E 都是强大的 AI 绘画工具,可以根据文本描述生成图像。 它们都使用深度学习模型来理解文本并将其转换为图像。 但是,它们在功能、可用性和成本方面存在一些差异。 Midjourney 优势: 可以生成更…

攻防世界新手模式例题(Web)

PHP2 首先我们查看页面,查看前端代码 发现均没有什么有效信息,由题目可知,此问题与php相关,于是我们可以看一下他的index.php文件 查看时用?index.phps 补充知识:phps文件就是php的源代码文件,通常用于…

算法之位运算

常见的位运算操作: 首先先熟悉一下常见的位运算操作: 1. 基础位运算 左移<<, 右移>>, 按位与&, 按位或|, 按位异或^, 按位取反~ 注意: 异或其实是一种无进位相加. 2. 给定一个 n, 确定它的二进制表示中第x位是 0 还是 1 n & (1<<x) 或者 (n>…

消费者组大观:5种状态,1场分布式奇迹

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 消费者组大观&#xff1a;5种状态&#xff0c;1场分布式奇迹 前言EmptyDead状态处理 Dead 状态的策略&#xff1a;防范和恢复&#xff1a; PreparingRebalance处理 "PreparingRebalance" 状…

【Leetcode-102.二叉树的层序遍历】

题目详情&#xff1a; 给你二叉树的根节点 root &#xff0c;返回其节点值的 层序遍历 。 &#xff08;即逐层地&#xff0c;从左到右访问所有节点&#xff09;。 示例 1&#xff1a; 输入&#xff1a;root [3,9,20,null,null,15,7] 输出&#xff1a;[[3],[9,20],[15,7]]示例…

Linux软件管理(1)

软件管理 下载 wget Linux wget是一个下载文件的工具&#xff0c;它用在命令行下。 wget工具体积小但功能完善&#xff0c;它支持断点下载功能&#xff0c;同时支持FTP和HTTP下载方式&#xff0c;支持代理服务器和设置起来方便简单。 1.语法 wget [选项]……[URL]…… 2、…

React - 实现菜单栏滚动

简介 本文将会基于react实现滚动菜单栏功能。 技术实现 实现效果 点击菜单&#xff0c;内容区域会自动滚动到对应卡片。内容区域滑动&#xff0c;指定菜单栏会被选中。 ScrollMenu.js import {useRef, useState} from "react"; import ./ScrollMenu.css;export co…

【MATLAB源码-第165期】基于matlab的科莫多巨蜥算法(KMA)机器人栅格路径规划,输出做短路径图和适应度曲线。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 科莫多巨蜥算法&#xff08;Komodo Mlipir Algorithm&#xff0c;简称KMA&#xff09;是一种受到印尼科莫多岛上独特生物——科莫多巨蜥启发的创新算法。尽管这个算法的名称听起来很有趣&#xff0c;但实际上它并不是一个公认…

写论文matplotlib使用同一色系的颜色

推荐网站 Colorsinspo - All in one resource for finding everything about colors | Colorsinspo 网页直接可以复制颜色 除此之外&#xff0c;自己还试了一个色系&#xff08;可惜不理想&#xff0c;看着不均匀&#xff09;&#xff0c;先存到这里 color_name [lightgr…

数据结构从入门到精通——直接插入排序

直接插入排序 前言一、直接插入排序的基本思想&#xff1a;二、直接插入排序的实例三、直接插入排序的动图展示四、直接插入排序的具体代码test.c 前言 直接插入排序是一种简单的排序算法&#xff0c;其工作原理是逐个将待排序元素插入到已排序序列中的适当位置&#xff0c;直…

7-初识Keras:轻松完成神经网络模型搭建

声明 本文章基于哔哩哔哩付费课程《小白也能听懂的人工智能原理》。仅供学习记录、分享&#xff0c;严禁他用&#xff01;&#xff01;如有侵权&#xff0c;请联系删除 目录 一、知识引入 &#xff08;一&#xff09;矩阵和向量 1、向量 2、矩阵 &#xff08;二&#xff…

java Flink(四十三)Flink Interval Join源码解析以及简单实例

背景 之前我们在一片文章里简单介绍过Flink的多流合并算子 java Flink&#xff08;三十六&#xff09;Flink多流合并算子UNION、CONNECT、CoGroup、Join 今天我们通过Flink 1.14的源码对Flink的Interval Join进行深入的理解。 Interval Join不是两个窗口做关联&#xff0c;…

001_【基础篇】SpringBoot入门案例创建与实现

要求&#xff1a;使用 Springboot 开发一个 web 程序&#xff0c;浏览器发起请求/hello后&#xff0c;给浏览器返回字符串 hello springboot 使用 springboot 只需要引入一个起步依赖 <dependency><groupId>org.springframework.boot</groupId><artifac…

STP环路避免实验(思科)

华为设备参考&#xff1a;STP环路避免实验&#xff08;华为&#xff09; 一&#xff0c;技术简介 Spanning Tree Protocol&#xff08;STP&#xff09;&#xff0c;即生成树协议&#xff0c;是一种数据链路层协议。主要作用是防止二层环路&#xff0c;并自适应网络变化和故障…