当前位置: 首页 > news >正文

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 地址也可以实现容器互联。

相关文章:

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 常见…...

深挖C++赋值

详解赋值 const int a 10; int b a;&a 0x000000b7c6afef34 {56496} &a 0x000000b7c6afef34 {10} 3. &b 0x000000b7c6afef54 {10} 总结: int a 10 是指在内存中(栈)中创建一个int (4 byte)大小的空间…...

【免越狱】iOS砸壳 可下载AppStore任意版本 旧版本IPA下载

软件介绍 下载iOS旧版应用,简化繁琐的抓包流程。 一键生成去更新IPA(手机安装后,去除App Store的更新检测)。 软件界面 支持系统 Windows 10/Windows 8/Windows 7(由于使用了Fiddler库,因此需要.Net环境…...

【python笔记02】面向对象思想

关于面向对象要学会啥? 面向对象编程思想面向对象基本概念 对象类 添加和获取对象属性魔术方法(三个常见的)面向对象案例 面向对象编程思想 两个时代的两个产物,没有好坏之分,小系统用面向过程,团队开发…...

Java基础-Java多线程机制

(创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹) 目录 一、引言 二、多线程的基本概念 1. 线程与进程 2. 多线程与并发 3. 多线程的优势 三、Java多线程的实…...

MySQL技巧之跨服务器数据查询:基础篇-A数据库与B数据库查询合并--封装到存储过程中

MySQL技巧之跨服务器数据查询:基础篇-A数据库与B数据库查询合并–封装到存储过程中 我们的最终目的是什么?当然的自动执行这些合并操作! 上一篇 MySQL技巧之跨服务器数据查询:基础篇-A数据库与B数据库查询合并 我们已经知道怎么合…...

MATLAB向量元素的引用

我们定义一个向量后,如果想引用的话,可以通过索引 i n d ind ind来实现。 注意:MATLAB中向量的开始索引是1,与许多编程语言不同。 例如: 如果想引用多个的话,可以用索引 i n d ind ind来提取多个位置 例如…...

leetcode-44-通配符匹配

题解: 代码: 参考: (1)牛客华为机试HJ71字符串通配符 (2)leetcode-10-正则表达式匹配...

基于YOLOv8深度学习的智慧课堂学生专注度检测系统(PyQt5界面+数据集+训练代码)

本研究提出了一种基于YOLOv8深度学习的智慧课堂学生专注度检测系统,旨在实现对课堂中学生专注度的实时分析与评估。随着智慧教育的快速发展,学生的课堂表现和专注度成为评估学习效果的重要因素之一。然而,传统的专注度评估方法往往依赖于主观…...

vue项目使用eslint+prettier管理项目格式化

代码格式化、规范化说明 使用eslintprettier进行格式化,vscode中需要安装插件ESLint、Prettier - Code formatter,且格式化程序选择为后者(vue文件、js文件要分别设置) 对于eslint规则,在格式化时不会全部自动调整&…...

Java基础-组件及事件处理(中)

(创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹) 目录 BorderLayout布局管理器 说明: 示例: FlowLayout布局管理器 说明: …...

UNIX网络编程-TCP套接字编程(实战)

概述 TCP客户端/服务器程序示例是执行如下步骤的一个回射服务器: 客户端从标准输入读入一行文本,并写给服务器。服务器从网络输入读入这行文本,并回射给客户端。客户端从网络输入读入这行回射文本,并显示在标准输出上。 TCP服务器…...

python编写一个自动清理三个月以前的邮件脚本

以下是一个使用 Python 编写的自动清理三个月以前的邮件的脚本。这个脚本适用于连接支持 IMAP 协议的邮箱服务,例如 Gmail。请注意,在执行此操作时,您需要提供电子邮件账号和应用程序专用密码(建议不要使用普通密码,并…...

C++组合复用中,委托的含义与作用

委托(Delegation)的含义与作用 委托是一种软件设计技术,它允许一个对象在处理某个请求时,将请求的处理责任转移给另一个对象。委托的核心思想是通过组合(composition)而不是继承(inheritance&a…...

自制C++游戏头文件:C++自己的游戏头文件!!!(后续会更新)

引言 在这个数字时代,计算机游戏已经成为人们生活中不可或缺的一部分。它们不仅为我们带来了无尽的乐趣,还激发了我们的创造力和解决问题的能力。今天,我们将深入探讨一个特别的头文件——CPPgame.h,它包含了多个结构体和函数&am…...

java 读取 有时需要sc.nextLine();读取换行符 有时不需要sc.nextLine();读取换行符 详解

在 Java 中,使用 Scanner 类读取输入时,换行符的处理行为取决于所用的读取方法。不同方法的工作原理会影响是否需要额外调用 sc.nextLine() 来清理缓冲区中的换行符。 核心问题 根本原因:Scanner 是基于输入流工作的,而换行符&am…...

Redis知识分享(三)

目录 前言 七、事务管理 7.1事务中的异常处理 八、订阅发布 8.1概述 ​8.2.Redis针对发布订阅相关指令 九、主从复制 9.1主从复制概述 9.2.主从复制的用处 9.3主从复制实现原理 ​9.3.1.psync指令 9.3.2.复制偏移量 9.3.3复制积压缓冲区&节点ID 前言 今天…...

python安装包报错

多次安装均报错 ERROR: Could not find a version that satisfies the requirement win10toast ERROR: No matching distribution found for win10toast 然后还提示 WARNING: Retrying (Retry(total4, connectNone, readNone, redirectNone, statusNone)) after connectio…...

Linux性能优化之火焰图简介

Linux 火焰图(Flame Graph)是一种可视化工具,用于分析程序性能问题,尤其是 CPU 使用情况。它展示了程序中函数调用的层次结构和各个调用栈占用的时间比例。 以下是详细介绍,包括火焰图的工作原理、生成步骤和实际使用中…...

Unity类银河战士恶魔城学习总结(P129 Craft UI 合成面板UI)

【Unity教程】从0编程制作类银河恶魔城游戏_哔哩哔哩_bilibili 教程源地址:https://www.udemy.com/course/2d-rpg-alexdev/ 本章节实现了合成面板的UI设置 UI_CraftWindow.cs 字段作用: UI 组件: itemName / itemDescription / icon&#…...

后进先出(LIFO)详解

LIFO 是 Last In, First Out 的缩写,中文译为后进先出。这是一种数据结构的工作原则,类似于一摞盘子或一叠书本: 最后放进去的元素最先出来 -想象往筒状容器里放盘子: (1)你放进的最后一个盘子&#xff08…...

eNSP-Cloud(实现本地电脑与eNSP内设备之间通信)

说明: 想象一下,你正在用eNSP搭建一个虚拟的网络世界,里面有虚拟的路由器、交换机、电脑(PC)等等。这些设备都在你的电脑里面“运行”,它们之间可以互相通信,就像一个封闭的小王国。 但是&#…...

【网络】每天掌握一个Linux命令 - iftop

在Linux系统中,iftop是网络管理的得力助手,能实时监控网络流量、连接情况等,帮助排查网络异常。接下来从多方面详细介绍它。 目录 【网络】每天掌握一个Linux命令 - iftop工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景…...

OpenLayers 可视化之热力图

注:当前使用的是 ol 5.3.0 版本,天地图使用的key请到天地图官网申请,并替换为自己的key 热力图(Heatmap)又叫热点图,是一种通过特殊高亮显示事物密度分布、变化趋势的数据可视化技术。采用颜色的深浅来显示…...

docker详细操作--未完待续

docker介绍 docker官网: Docker:加速容器应用程序开发 harbor官网:Harbor - Harbor 中文 使用docker加速器: Docker镜像极速下载服务 - 毫秒镜像 是什么 Docker 是一种开源的容器化平台,用于将应用程序及其依赖项(如库、运行时环…...

shell脚本--常见案例

1、自动备份文件或目录 2、批量重命名文件 3、查找并删除指定名称的文件: 4、批量删除文件 5、查找并替换文件内容 6、批量创建文件 7、创建文件夹并移动文件 8、在文件夹中查找文件...

OkHttp 中实现断点续传 demo

在 OkHttp 中实现断点续传主要通过以下步骤完成,核心是利用 HTTP 协议的 Range 请求头指定下载范围: 实现原理 Range 请求头:向服务器请求文件的特定字节范围(如 Range: bytes1024-) 本地文件记录:保存已…...

TRS收益互换:跨境资本流动的金融创新工具与系统化解决方案

一、TRS收益互换的本质与业务逻辑 (一)概念解析 TRS(Total Return Swap)收益互换是一种金融衍生工具,指交易双方约定在未来一定期限内,基于特定资产或指数的表现进行现金流交换的协议。其核心特征包括&am…...

土地利用/土地覆盖遥感解译与基于CLUE模型未来变化情景预测;从基础到高级,涵盖ArcGIS数据处理、ENVI遥感解译与CLUE模型情景模拟等

🔍 土地利用/土地覆盖数据是生态、环境和气象等诸多领域模型的关键输入参数。通过遥感影像解译技术,可以精准获取历史或当前任何一个区域的土地利用/土地覆盖情况。这些数据不仅能够用于评估区域生态环境的变化趋势,还能有效评价重大生态工程…...

MySQL中【正则表达式】用法

MySQL 中正则表达式通过 REGEXP 或 RLIKE 操作符实现(两者等价),用于在 WHERE 子句中进行复杂的字符串模式匹配。以下是核心用法和示例: 一、基础语法 SELECT column_name FROM table_name WHERE column_name REGEXP pattern; …...