Docker 篇-Docker 详细安装、了解和使用 Docker 核心功能(数据卷、自定义镜像 Dockerfile、网络)

🔥博客主页: 【小扳_-CSDN博客】
❤感谢大家点赞👍收藏⭐评论✍

文章目录

        1.0 Docker 概述

        1.1 Docker 主要组成部分

        1.2 Docker 安装

        2.0 Docker 常见命令

        2.1 常见的命令介绍

        2.2 常见的命令演示

        3.0 数据卷

        3.1 数据卷常见的命令

        3.2 常见数据卷命令的演示

        3.3 挂载本地目录或文件

        4.0 自定义镜像

        4.1 Dockerfile 文件

        5.0 网络

        5.1 常见的命令


        1.0 Docker 概述

        Docker 是一个开源平台,用于自动化应用程序的部署、扩展和管理,采用的是容器化技术。它允许开发者将应用程序及其所有依赖项打包成轻量级、可移植的容器,从而确保无论在何种环境中运行,应用程序都能够保持一致的行为。

        1.1 Docker 主要组成部分

        Docker 镜像:镜像是一个轻量级、可执行的独立软件包,包含了运行某个软件所需的所有代码、库、环境变量和配置文件。镜像是不可变的,可以从它们创建容器。

        Docker 容器:容器是从镜像创建的运行实例,是轻量级的、隔离的执行环境。容器共享宿主操作系统的核心,但相互之间是隔离的。

        Docker Hub:这是 Docker 的公共仓库,用户可以在这里存储和分享 Docker 镜像。

        1.2 Docker 安装

通过在华为云上安装 Ubuntu 版本的 Docker:

        1)若您安装过 Docker,需要先删掉,之后再安装依赖

sudo apt-get remove docker docker-engine docker.io
sudo apt-get install apt-transport-https ca-certificates curl gnupg2 software-properties-common

        2)根据版本不同,运行公钥,添加软件仓库

信任 Docker 的 GPG 公钥:

curl -fsSL https://mirrors.huaweicloud.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -

对于 amd64 架构的计算机,添加软件仓库:

sudo add-apt-repository "deb [arch=amd64] https://mirrors.huaweicloud.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"

对于树莓派或其它 Arm 架构计算机,请运行:

echo "deb [arch=armhf] https://mirrors.huaweicloud.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list

         3)更新索引文件并安装

sudo apt-get update
sudo apt-get install docker-ce

         4)添加镜像

        首先执行命令,打开文件:

vi /etc/docker/daemon.json 

        添加镜像信息:

{"registry-mirrors": ["https://docker.m.daocloud.io","https://dockerhub.timeweb.cloud","https://huecker.io"]
}

如图: 

        文件内容输入后,再执行以下命令:

sudo systemctl daemon-reload
sudo systemctl restart docker

        5)最后,测试 Docker 是否安装好

输入以下命令:

docker images

出现的结果为: 

         这就完成 Dcoker 安装了。

        2.0 Docker 常见命令

        先来介绍常见的命令,其他不常见的命令可以参考:

Docker 的官方文档:docker | Docker Docs

        2.1 常见的命令介绍

        1)docker pull:拉取镜像

        2)docker push:推送镜像

        3)docker images:查看本地镜像

        4)docker rmi:删除指定本地镜像

        5)docker run:创建容器并运行容器

        6)docker stop:停止指定容器

        7)docker start:启动指定容器

        8)docker restart:重启指定容器

        9)docker rm:删除指定容器

        10)docker ps:查看容器

        11)docker logs:查看容器运行日志

        12)docker exec:进入容器

        13)docker save:保存镜像到本地压缩文件

        14)docker load:加载本地压缩文件到镜像

        15)docker inspect:查看容器详情信息

        16)docker build:创建本地镜像

用一副图来表示这些命令的关系:

        默认情况下,每次重启虚拟机我们都需要手动启动 Docker 和 Docker 中的容器。通过命令可以实现开机自启:

# Docker开机自启
systemctl enable docker# Docker容器开机自启
docker update --restart=always [容器名/容器id]

        2.2 常见的命令演示

使用 Docker 安装 Nginx 软件为例子:

        1)首先从 Docker 中央仓库中拉取 nginx镜像:

docker pull nginx

具体如下:

        2)查看镜像:

docker images

具体如下:

        成功从 Docker 中央仓库中拉取到 nginx 镜像。

        3)创建并运行容器:

docker run -d --name nginx -p 80:80 nginx

        命令解析:-d 指在后台运行,--name 指定容器的名字,-p 端口映射,nignx 镜像名 

 具体如下:

        4)查看运行容器:

docker ps

具体如下:

也可以加格式化访问,会更加清爽:

docker ps --format "table {{.ID}}\t{{.Image}}\t{{.Ports}}\t{{.Status}}\t{{.Names}}"

具体如下:

        5)访问网址:

        因为 nginx 已经部署到了云服务器了,那么通过 IP:端口号进行访问

具体如下:

        成功访问了。

        6)停止容器:

docker stop nginx

具体如下:

        停止之后,通过查看容器运行情况,发现 nginx 容器已经停止了。

        7)启动容器:

docker start nginx

具体如下:

        通过启动命令之后,再查看运行容器,发现 nginx 正在运行。

        8)查看容器详情:

docker inspect nginx

具体如下:

        9)进入容器,查看容器目录

docker exec -it nginx bash

具体如下:

        进入到 nginx 容器中,通过 ls 命令查看容器中的目录

额外举个 MySQL 的例子:

        通过 docker exec -it mysql bash 进入到 mysql 容器,再通过 mysql -uroot -p 进入到 mysql 控制台

具体如下:

         10)强制删除运行中的容器

docker rm nginx -f

具体如下:

        删除完之后,查看运行中的容器,发现 nginx 已经被删除了。

        11)查看日志

        通过 mysql 举个例子

docker logs -f mysql

具体如下:

        3.0 数据卷

        数据卷(Volume) 是一个虚拟目录,是容器内目录与宿主机目录之间映射的桥梁。

        因此,容器提供程序的运行环境,但是程序运行产生的数据、程序运行依赖都配置都应该与容器解耦。

        比如说,MySQL、nginx 容器运行后,如果需要修改其中某些配置该怎么办?这时候,就需要用到数据卷,将宿主机与容器内的配置信息进行映射。

        以 nginx 为例,在 nginx 中有两个关键的目录:

        1)html:放置一些静态资源。

        2)conf:放置配置文件。

        利用数据卷将两个目录与宿主机目录关联,如图:

在上图中:
        我们创建了两个数据卷:conf、html,Nginx 容器内部的 conf 目录和 html 目录分别与两个数据卷关联。
        而数据卷 conf 和 html 分别指向了宿主机的 /var/lib/docker/volumes/conf/_data 目录和 /var/lib/docker/volumes/html/_data 目录。
        这样以来,容器内的 conf 和 html 目录就 与宿主机的 conf 和 html 目录关联起来,我们称为挂载。此时,我们操作宿主机的 /var/lib/docker/volumes/html/_data 就是在操作容器内的 /usr/share/nginx/html/_data 目录。只要我们将静态资源放入宿主机对应目录,就可以被 Nginx 代理了。

        /var/lib/docker/volumes 这个目录就是默认的存放所有容器数据卷的目录,其下再根据数据卷名称创建新目录,格式为 /数据卷名 /_data。

        3.1 数据卷常见的命令

        1)docker volume create:创建数据卷

        2)docker volume ls:查看所有数据卷

        3)docker volume inspect:查看某个数据卷的详情

        4)docker volume rm:删除指定数据卷

        5)docker volume prune:清除数据卷

        注意:容器与数据卷的挂载要在创建容器时配置,对于创建好的容器,是不能设置数据卷的。而且创建容器的过程中,数据卷会自动创建。

        3.2 常见数据卷命令的演示

        以 niginx 为例子,将容器中的 /usr/share/nginx/html 目录挂载到宿主机中。

        1)首先创建容器并指定数据卷,注意通过 -v 参数来指定数据卷:

docker run -d --name nginx -p 80:80 -v html:/usr/share/nginx/html nginx

具体如下:

        2)查看数据卷:

docker volume ls

具体如下:

        可以通过修改宿主机中的 html 来修改配置,从而会自动映射到 nginx 容器中的配置:

修改之前:

修改宿主机的 html:

        此时,宿主机中的 index.html 文件被修改了,观察是否映射到容器中的 index.html 文件:

        发现已经被修改了,但是修改文字对不上号,这可能是字符集导致的乱码。

使用英文再测试一遍:

        宿主机中的 index.html:

        再来访问 nginx 

        因此,宿主机中的 index.html 与容器中的 index.html 成功完成了映射。

         3)查看数据卷详情:

docker volume inspect html

具体如下:

        3.3 挂载本地目录或文件

        可以发现,数据卷的目录结构较深,如果我们去操作数据卷目录会不太方便。在很多情况下,我们会直接将容器目录与宿主机指定目录挂载。挂载语法与数据卷类似:

# 挂载本地目录
-v 本地目录:容器内目录
# 挂载本地文件
-v 本地文件:容器内文件

        注意:本地目录或文件必须以 / 或 ./ 开头,如果直接以名字开头,会被识别为数据卷名而非本地目录名。 

例如:

-v mysql:/var/lib/mysql # 会被识别为一个数据卷叫mysql,运行时会自动创建这个数据卷
-v ./mysql:/var/lib/mysql # 会被识别为当前目录下的mysql目录,运行时如果不存在会创建目录

        使用 mysql 为例,将 mysql 容器中的 /var/lib/mysql 文件挂载到 ./mysql/data 本地目录。

docker run -d \--name mysql \-p 3306:3306 \-e TZ=Asia/Shanghai \-e MYSQL_ROOT_PASSWORD=123 \-v ./mysql/data:/var/lib/mysql \mysql

具体如下:

         本地目录与容器中的  /var/lib/mysql 文件挂载成功了,因此可以通过修改本地目录的数据,从而实现对容器中的 mysql 数据进行修改。

        4.0 自定义镜像

        要想自己构建镜像,必须先了解镜像结构。镜像之所以能让我们快速跨操作系统部署应用而忽略器运行环境、配置,就是因为镜像中包含了程序运行需要的系统函数库、环境、配置、依赖。

        因此,自定义镜像本质就是依次准备好程序运行的基础环境、依赖、应用本身、运行配置等文件,并且打包而成。

举个例子,从 0 部署一个 Java 应用,大概的流程:

        1)准备一个 linux 服务(CentOS 或者 Ubuntu 均可)

        2)安装并配置 JDK

        3)上传 Jar 包

        4)运行 Jar 包

        那因此,打包镜像也是分为这么几步:

        1)准备 Linx 环境,Java 项目并不需要完整的操作系统,仅仅是基础运行环境即可。

        2)安装并配置 JDK 。

        3)拷贝 Jar 包。

        4)配置启动脚本。

        上述步骤中每一个操作其实都是在生产一些文件,系统运行环境、函数库、配置最终都是磁盘文件,所以镜像就是一堆文件的集合。

        但是需要注意的是,镜像文件不是随意堆放的,而是按照操作的步骤分层叠加而成,每一层形成的文件都会单独打包并标记一个唯一 id,称为 Layer(层)。这样,在构建一些重复的层,就不需要重复拷贝这些层了。

        4.1 Dockerfile 文件

        由于制作镜像的过程中,需要逐层处理和打包,比较复杂,所以 Docker 就提供了自动打包镜像的功能。我们只需要将打包的过程,每一层要做的事情用固定的语法写下来,交给 Docker 去执行即可。

        而这种记录镜像结构的文件就称为 Dockerfile,其对应的语法可以参考官方文档:Dockerfile reference | Docker Docs

其中的语法比较多,比较常用的有:

        1)FROM:指定基础镜像。

        2)ENV:设置环境变量,可在后面指令使用。

        3)COPY:拷贝本地文件到镜像的指定目录。

        4)RUN:执行 Linux 的 shell 命令,一般是安装过程的命令。

        5)EXPOSE:指定容器运行时监听的端口,是给镜像使用者看的。

        6)ENTRYPOINT:镜像中应用的启动命令,容器运行时调用。

例如,要基于 Ubuntu 镜像来构建一个 Java 应用,其 Dockerfile 内容如下:

# 指定基础镜像
FROM ubuntu:16.04
# 配置环境变量,JDK的安装目录、容器内时区
ENV JAVA_DIR=/usr/local
ENV TZ=Asia/Shanghai
# 拷贝jdk和java项目的包
COPY ./jdk8.tar.gz $JAVA_DIR/
COPY ./docker-demo.jar /tmp/app.jar
# 设定时区
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
# 安装JDK
RUN cd $JAVA_DIR \&& tar -xf ./jdk8.tar.gz \&& mv ./jdk1.8.0_144 ./java8
# 配置环境变量
ENV JAVA_HOME=$JAVA_DIR/java8
ENV PATH=$PATH:$JAVA_HOME/bin
# 指定项目监听的端口
EXPOSE 8080
# 入口,java项目的启动命令
ENTRYPOINT ["java", "-jar", "/app.jar"]

        思考一下:以后我们会有很多很多 java 项目需要打包为镜像,他们都需要 Linux 系统环境、JDK 环境这两层,只有上面的3层不同(因为 jar 包不同)。如果每次制作 java 镜像都重复制作前两层镜像,是不是很麻烦。

        所以,就有人提供了基础的系统加JDK环境,我们在此基础上制作 java 镜像,就可以省去 JDK 的配置了:

# 基础镜像
FROM openjdk:11.0-jre-buster
# 设定时区
ENV TZ=Asia/Shanghai
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
# 拷贝jar包
COPY docker-demo.jar /app.jar
# 入口
ENTRYPOINT ["java", "-jar", "/app.jar"]

         因此,我们只需要准备 JDK 的基础镜像和 jar 包即可。

举个例子:

        1)现在准备好了 Dockerfile 文件和 jar 包、jdk.jar

        先将 jdk.jar 的基础镜像加载到镜像中:

docker load -i jdk.tar

具体如下:

        2)接着指定命令:

        进入 demo 目录:

         再执行该命令:

# 直接指定Dockerfile目录
docker build -t docker-demo .

命令说明:
        docker build : 就是构建一个 docker 镜像
        -t docker-demo :-t 参数是指定镜像的名称(repository 和 tag)
        . : 最后的点是指构建时 Dockerfile 所在路径,由于我们进入了 demo 目录,所以指定的是 . 代表当前目录,也可以直接指定 Dockerfile 目录。

        因为 Dockerfile 就在当前目录下,直接使用 . 来声明 Dockerfile 的位置。

具体如下:

        3)查看镜像:

具体如下:

         4)创建并运行容器:

docker run -d --name dd -p 8080:8080 docker-demo

具体如下:

        运行之后,查看运行容器

        5)访问容器:

        5.0 网络

        假设创建了一个 Java 项目的容器,而 Java 项目往往需要访问其它各种中间件,例如 MySQL、Redis 等。现在,我们的容器之间能否互相访问呢?我们来测试一下:

        首先,我们查看下 MySQL 容器的详细信息,重点关注其中的网络 IP 地址:

# 1.用基本命令,寻找Networks.bridge.IPAddress属性
docker inspect mysql
# 也可以使用format过滤结果
docker inspect --format='{{range .NetworkSettings.Networks}}{{println .IPAddress}}{{end}}' mysql
# 得到IP地址如下:
172.17.0.2# 2.然后通过命令进入dd容器
docker exec -it dd bash# 3.在容器内,通过ping命令测试网络
ping 172.17.0.2
# 结果
PING 172.17.0.2 (172.17.0.2) 56(84) bytes of data.
64 bytes from 172.17.0.2: icmp_seq=1 ttl=64 time=0.053 ms
64 bytes from 172.17.0.2: icmp_seq=2 ttl=64 time=0.059 ms
64 bytes from 172.17.0.2: icmp_seq=3 ttl=64 time=0.058 ms

        但是,容器的网络 IP 其实是一个虚拟的 IP,其值并不固定与某一个容器绑定,如果我们在开发时写死某个 IP,而在部署时很可能 MySQL 容器的IP会发生变化,连接会失败。

        所以,我们必须借助于 docker 的网络功能来解决这个问题。

        5.1 常见的命令

        1)docker network create:创建一个网络

        2)docker network ls:查看所有网络

        3)docker network rm:删除指定网络

        4)docker network prune:清除未使用的网络

        5)docker network connect:使指定容器连接加入某网络

        6)docker network disconnect:使指定容器连接离开某网络

        7)docker network inspect:查看网络详情信息

自定义网络演示:

        首先,创建一个网络:

docker network create xbs

具体如下:

        接着查看网络:

docker network ls

具体如下:

        再接着详细了解 xbs 网络:

docker network inspect xbs

具体如下:

        网关为:172.18.0.1 

         将 mysql 加入到该网络中:

docker network connect xbs mysql

具体如下:

        查看 mysql 网络详情:

docker inspect mysql

 具体如下:

        此时 mysql 容器中的网关为 172.18.0.1,IP 为 172.18.0.2 。

        配置完 mysql 容器之后,只要在该网段中的所有容器,都可以根据容器名进行相互访问。

 

        接着将 Java 项目的容器加入该网段:

docker network connect xbs dd

 具体如下:

        查看详情信息

        网关为 172.18.0.1,Java 项目的 IP 为 172.18.0.4 。因此,dd 容器可以与 mysql 容器进行相互访问,联通的。

        dd 容器与 mysql 容器尝试进行拼接:

docker exec -it dd bash

具体如下:

        在加入了同一个网段之后,只需要通过访问容器名就可以实现 dd 容器与 mysql 容器进行连通。

总结:

        1)在自定义网络中,可以给容器其多个别名,默认的别名是容器名本身。

        2)在同一个自定义网络中的容器,可以通过别名互相访问。

        3)现在无需记住 IP 地址也可以实现容器互联。

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

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

相关文章

三格电子-EtherNet IP转Modbus TCP网关

EtherNet/IP转Modbus TCP网关 SG-EIP-TCP-210 产品用途 SG-EIP-TCP-210 网关可以实现将 Modbus TCP 接口设备连接到 EtherNet/IP 网络中。用户不需要了解具体的 Modbus TCP 和 EtherNet/IP 协议即可实现将 Modbus TCP 设备挂载到 EtherNet/IP 接口的 PLC 上,并和 …

修改gitee提交时用户名密码输错导致提交失败的解决方法

1、打开控制面板,点击用户账户 点击管理Windows凭据 点击Windows凭据,找到gitee,删除后重新git push 重新输入密码即可

Pytest-Bdd-Playwright 系列教程(10):配置功能文件路径 优化场景定义

Pytest-Bdd-Playwright 系列教程(10):配置功能文件路径 & 优化场景定义 前言一、功能文件路径的配置1.1 全局设置功能文件路径1.2. 在场景中覆盖路径 二、避免重复输入功能文件名2.1 使用方法2.2 functools.partial 的背景 三、应用场景总…

安装gentoo之第二步:安装gentoo基本系统

目标 :将gentoo配置为服务器, 一、下载并解压stage文件 1.官网下载stage文件 网址:https://www.gentoo.org/downloads/ 将gentoo配置为服务器,所以只下载了stage3-amd64-systemd-20241117T163407Z.tar.xz这个最小的stage文件. 基…

Methode Electronics EDI 需求分析

Methode Electronics 是一家总部位于美国的全球性技术公司,专注于设计和制造用于多个行业的电子和电气组件,产品涵盖汽车、工业、电信、医疗设备以及消费电子等多个领域,提供创新的解决方案。 填写Methode_EDI_Parameters_Template Methode_…

Java基础知识(六)

文章目录 StringString、StringBuffer、StringBuilder 的区别?String 为什么是不可变的?字符串拼接用“” 还是 StringBuilder?String#equals() 和 Object#equals() 有何区别?字符串常量池的作用了解吗?String s1 new String("abc&qu…

一文解决Latex中的eps报错eps-converted-to.pdf not found: using draft setting.

在使用Vscode配的PDFLatex编译IEEE TII的Latex模板时,出现eps文件不能转换为pdf错误,看了几十篇方法都没用,自己研究了半天终于可以正常运行了。主要原因还是Settings.JSON中的PDFLatex模块缺少:"--shell-escape", 命令…

Redis基本的全局命令

在学习redis基本的全局命令之前呢,我们必须先进入redis-cli客户端才行。 如图: get和set get和set是redis两个最核心的命令。 get:根据key来获取value。 set:把key和value存储进去。 如set命令如图: 对于上述图中&…

力扣题目总结

1.游戏玩法分析IV AC: select IFNULL(round(count(distinct(Result.player_id)) / count(distinct(Activity.player_id)), 2), 0) as fraction from (select Activity.player_id as player_idfrom (select player_id, DATE_ADD(MIN(event_date), INTERVAL 1 DAY) as second_da…

量子计算来袭:如何保护未来的数字世界

目录 前言 一、量子计算安全的学习方向 1. 量子物理学基础 2. 量子计算原理与技术 3. 传统网络安全知识 4. 量子密码学 5. 量子计算安全政策与法规 二、量子计算的漏洞风险 1. 加密算法被破解风险 2. 区块链安全风险 3. 量子密钥分发风险 4. 量子计算系统自身风险 …

AJAX笔记 (速通精华版)

AJAX(Asynchronous Javascript And Xml) 此笔记来自于动力节点最美老杜 传统请求及缺点 传统的请求都有哪些? 直接在浏览器地址栏上输入URL。点击超链接提交 form 表单使用 JS 代码发送请求 window.open(url)document.location.href urlwi…

net某高校社交学习平台的设计与实现

摘 要 高校社交学习平台是一个融合了社交网络特性的在线学习交流系统,旨在促进高校学生之间的信息共享与学习互动。该平台通过提供学习资料、学习视频和学习交流等功能,支持发布学习动态、参与知识问答、并实时追踪学习进度。为学生提供一个全面且便捷的…

七、利用CSS和多媒体美化页面的习题

题目一&#xff1a; 利用CSS技术&#xff0c;结合表格和列表&#xff0c;制作并美化 “ 翡翠阁 ”页面。运行效果如下 运行效果&#xff1a; 代码 <!DOCTYPE html> <html><head><meta charset"utf-8" /><title>翡翠阁</title>&…

学习虚幻C++开发日志——委托(持续更新中)

委托 官方文档&#xff1a;Delegates and Lamba Functions in Unreal Engine | 虚幻引擎 5.5 文档 | Epic Developer Community | Epic Developer Community 简单地说&#xff0c;委托就像是一个“函数指针”&#xff0c;但它更加安全和灵活。它允许程序在运行时动态地调用不…

Linux:自定义Shell

本文旨在通过自己完成一个简单的Shell来帮助理解命令行Shell这个程序。 目录 一、输出“提示” 二、获取输入 三、切割字符串 四、执行指令 1.子进程替换 2.内建指令 一、输出“提示” 这个项目基于虚拟机Ubuntu22.04.5实现。 打开终端界面如图所示。 其中。 之前&#x…

如何更改手机GPS定位

你是否曾想过更改手机GPS位置以保护隐私、玩游戏或访问受地理限制的内容&#xff1f;接下来我将向你展示如何使用 MagFone Location Changer 更改手机GPS 位置&#xff01;无论是在玩Pokmon GO游戏、发布社媒贴子&#xff0c;这种方法都快速、简单且有效。 第一步&#xff1a;下…

【AI大模型引领变革】探索AI如何重塑软件开发流程与未来趋势

文章目录 每日一句正能量前言流程与模式介绍【传统软件开发 VS AI参与的软件开发】一、传统软件开发流程与模式二、AI参与的软件开发流程与模式三、AI带来的不同之处 结论 AI在软件开发流程中的优势、挑战及应对策略AI在软件开发流程中的优势面临的挑战及应对策略 结论 后记 每…

Chapter 2 - 16. Understanding Congestion in Fibre Channel Fabrics

Transforming an I/O Operation to FC frames A read or write I/O operation (Figure 2-28) between an initiator and a target undergoes a series of transformations before being transmitted on a Fibre Channel link. 启动程序和目标程序之间的读取或写入 I/O 操作(图…

VMWARE虚拟交换机的负载平衡算法

一、基于源虚拟端口的路由 虚拟交换机可根据 vSphere 标准交换机或 vSphere Distributed Switch 上的虚拟机端口 ID 选择上行链路。 基于源虚拟端口的路由是 vSphere 标准交换机和 vSphere Distributed Switch 上的默认负载平衡方法。 ESXi主机上运行的每个虚拟机在虚拟交换…

web——sqliabs靶场——第十二关——(基于错误的双引号 POST 型字符型变形的注入)

判断注入类型 a OR 1 1# 发现没有报错 &#xff0c;说明单引号不是闭合类型 测试别的注入条件 a) OR 1 1# a)) OR 1 1# a" OR 11 发现可以用双引号闭合 发现是")闭合 之后的流程还是与11关一样 爆破显示位 先抓包 是post传参&#xff0c;用hackbar来传参 unam…