【Docker】Docker学习02 | docker-cli的基本命令

news2024/9/20 6:03:11

本文首发于 ❄️慕雪的寒舍

简单了解一下docker client的常用命令,更多命令可以查看完整命令列表。不同命令之间的关系,可以查看下图。

image.png

如果你看不到图片,不用担心,后面对每个命令进行介绍的时候,会提到它们的作用的。

本文所述的所有命令都是docker-cli的命令(cli是client的缩写),它们本质上都是在和主机上的 docker engine 通信,获取结果。最终容器的运行管理,实际上都是由作为服务端的 docker engine 来处理的。所以在运行 docker-cli 命令之前,需要保证 docker engine 已经启动。一般的Linux系统上,都可以使用 systemctl 命令管理 docker engine 的服务。

systemctl start docker

基础命令

docker的帮助命令和基本信息

docker --help  # 查看帮助命令
docker version # 查看docker信息,会显示client和server的版本
docker info # 显示当前docker的详细信息,包括有几个容器等

镜像相关命令

docker pull

用于下载镜像,当不指定tag的时候,会默认拉取latest版本(大部分镜像都会维护一个tag为latest的镜像)

docker pull 镜像名:tag

如果你不知道某个镜像是否存在,可以用docker search命令来查询它。

docker images

查看当前本地已有的镜像的相关信息

docker images

image.png

❯ docker images
REPOSITORY                TAG           IMAGE ID       CREATED         SIZE
musnows/kook-ticket-bot   0.3.0         3033f09a7bb3   5 days ago      163MB
musnows/kook-ticket-bot   latest        75f153e944da   5 days ago      163MB
b3log/siyuan              v3.1.0        6498791aa636   2 weeks ago     225MB
bitnami/minio             latest        02f75f2c3432   2 weeks ago     271MB
neosmemo/memos            latest        5ddfb6978c7f   6 weeks ago     62.7MB

另外,可以使用docker images prune快速删除所有未被容器使用且没有被tag的镜像层,如果想删除所有未被使用的镜像层,可以在这个命令后加上-a选项。

为什么需要清理呢?如果本地存在镜像层损坏,可能会影响新容器的构建和创建操作。可以尝试使用这个命令清理一下本地的镜像层。镜像层文件一般存放在/var/lib/docker/overlay2中。

注意,prune选项只是删除没有被使用的镜像层,但有些镜像的tag为none,但本身会和其他镜像共用镜像层,此时使用prune是不会清理掉这些镜像的。如果你想清理掉tag为none的镜像,可以使用如下命令快速清除。

docker images -f "dangling=true" -q | xargs docker rmi

docker tag

该命令用于给一个已有的镜像设置一个tag(设置镜像的名字)

docker tag 镜像id 命名镜像

每个docker镜像都有个标识(镜像的完整名字),通常由仓库名、镜像名和标签组成。

仓库名/镜像上传者名/镜像本身名字:tag

且为了区分镜像的上传者,镜像名中通常以斜杠来分割镜像上传者和镜像本身的名字。默认情况下,使用的仓库都是官方的docker hub,所以镜像的仓库名会被省略

musnows/ImagesName:tag 

如果你使用了docker的镜像源(比如南京大学的镜像源),那么拉取下来的镜像中就会有仓库的名字。

docker.nju.edu.cn/jellyfin/jellyfin:latest

docker rmi

可以使用docker rmi命令来删除某个镜像,需要提供镜像的名字:tag或者镜像的ID。

docker rmi 镜像ID
docker rmi 镜像名:tag

如果要删除某个镜像,这个镜像必须没有关联的容器(需要先把关联的容器删除),才能被删除。否则删除请求会被拒绝。当然,可以使用-f选项来强制删除某个镜像。

另外,如果使用镜像名:tag的方式删除某个镜像时,并不一定会触发删除操作。因为同一个镜像可能会被打上多个tag,这时候只删除其中一个tag,相当于取消tag的操作。如果确定需要删除这个镜像,直接使用镜像的ID来删除是更好的办法。

如下所示,可以看到同一个镜像有两个不同的tag

REPOSITORY   TAG       IMAGE ID       CREATED        SIZE
t            1         fa725ab19121   4 hours ago    432MB
t            2         fa725ab19121   4 hours ago    432MB

此时我们删除其中一个tag,可以看到返回的说明是Untagged,相当于是取消了对这个镜像的t:1这个tag。

$ docker rmi t:1
Untagged: t:1

t:2这个tag也给删除,才会真正删除镜像

$ docker rmi t:2 -f
Untagged: t:2
Deleted: sha256:fa725ab19121bd9c5628757049f5da5d4002f1ee10e41c4a87c33ab343d4ff28

docker inspect

这个命令用于查询某个容器/镜像的元数据,会以json格式返回元数据

docker inspect [OPTIONS] NAME|ID [NAME|ID...]

docker save/load

docker save和docker load命令相对应,用于将一个镜像打包成tar格式的文件,方便在不同主机上进行传输。其他主机可以用load命令加载一个导出的镜像

# 打包本地镜像
docker save linux:monitor -o linux-monitor.tar
# 在其他主机上加载镜像
docker load -i linux-monitor.tar

为了减少导出镜像的文件大小,还可以用gzip命令来压缩导出的镜像包的体积

# 通过管道,将docker save的结果传输给gzip工具,进行压缩
docker save <myimage>:<tag> | gzip > <myimage>_<tag>.tar.gz
# gzip解压之后,通过管道传输给docker load命令
gunzip -c <myimage>_<tag>.tar.gz | docker load

【重点】docker build

docker build命令用于从docker file中构建一个docker的镜像,参考菜鸟教程

docker build [OPTIONS] PATH | URL | -

OPTIONS说明:

  • –build-arg=[] :设置镜像创建时的变量;
  • –cpu-shares :设置 cpu 使用权重;
  • –cpu-period :限制 CPU CFS周期;
  • –cpu-quota :限制 CPU CFS配额;
  • –cpuset-cpus :指定使用的CPU id;
  • –cpuset-mems :指定使用的内存 id;
  • –disable-content-trust :忽略校验,默认开启;
  • -f :指定要使用的Dockerfile路径;
  • –force-rm :设置镜像过程中删除中间容器;
  • –isolation :使用容器隔离技术;
  • –label=[] :设置镜像使用的元数据;
  • -m :设置内存最大值;
  • –memory-swap :设置Swap的最大值为内存+swap,"-1"表示不限swap;
  • –no-cache :创建镜像的过程不使用缓存
  • –pull :尝试去更新镜像的新版本;
  • –quiet, -q :安静模式,成功后只输出镜像 ID;
  • –rm :设置镜像成功后删除中间容器;
  • –shm-size :设置/dev/shm的大小,默认值是64M;
  • –ulimit :Ulimit配置。
  • –squash :将 Dockerfile 中所有的操作压缩为一层。
  • –tag, -t: 镜像的名字及标签,通常 name:tag 或者 name 格式;可以在一次构建中为一个镜像设置多个标签。
  • –network: 默认 default。在构建期间设置RUN指令的默认网络模式;

示例1:使用.当前路径下的dockerfile构建镜像,tag为runoob/ubuntu:v1

docker build -t runoob/ubuntu:v1 .

示例2:使用指定路径/path/to/a/Dockerfile中的dockerfile,从.当前目录中指定上下文,【重点】Docker需要拷贝的内容是以命令中指定的.当前目录为PWD进行dockerfile内相对路径计算的,构建镜像。

docker build -f /path/to/a/Dockerfile .

示例3:使用-f手动指定dockerfile的名字为base.dockerfile,并设置了docker镜像的默认网络模式是host,这个网络模式下docker容器会直接使用宿主机的端口。

如果没有指定dockerfile文件,默认会忽略大小写在当前目录下搜索名为dockerfile的文件。

docker build --network host -f base.dockerfile .

构建过程中可能遇到一些问题,比较常见的是和构建缓存还有上下文相关的,示例如下,报错中提到了/install/grpc文件不存在,这是因为当前指定的docker build上下文中没有办法被COPY到这个文件,需要检查你指定的docker构建上下文以及dockerfile中的相对路径是否正确。

ERROR: failed to solve: failed to compute cache key: failed to calculate checksum of ref 15c2f5bc-d5d7-4c81-9b8d-35af99494b3e::iuik026yg20qwxl8dajjkigru: "/install/grpc": not found

还有另外一个问题是我在构建一个新镜像时遇到的,出现的场景在于上一次构建被我手动CTRL+C终止了,再次构建就会出现错误(即便build命令加上--no-cache选项也会失败)。这种大概率就是缓存损坏了,可以用如下方式清理一下本地的构建缓存。

# 删除损害的构建缓存
docker builder prune
# 删除所有未被使用的中间容器
docker container prune
# 删除所有未被使用的镜像层
docker image prune
# 删除所有tag为none的镜像
docker images -f "dangling=true" -q | xargs docker rmi

容器相关命令

docker ps

查看当前正在运行的容器。

docker ps

image.png

❯ docker ps    
CONTAINER ID   IMAGE                   COMMAND                  CREATED        STATUS          PORTS                                                                                      NAMES
04fec1b6c345   b3log/siyuan:v3.1.0     "/opt/siyuan/kernel …"   2 weeks ago    Up 16 minutes   0.0.0.0:10060->6806/tcp, :::10060->6806/tcp, 0.0.0.0:10061->6808/tcp, :::10061->6808/tcp   siyuan
69328f37ac26   bitnami/minio:latest    "/opt/bitnami/script…"   2 weeks ago    Up 16 minutes   0.0.0.0:9000-9001->9000-9001/tcp, :::9000-9001->9000-9001/tcp                              minio
612786ac157c   neosmemo/memos:latest   "./memos"                5 weeks ago    Up 16 minutes   0.0.0.0:14710->5230/tcp, :::14710->5230/tcp                                                memos
ffbdfb02af22   gitea/gitea:1.21.4      "/usr/bin/entrypoint…"   5 months ago   Up 16 minutes   127.0.0.1:2222->22/tcp, 0.0.0.0:30000->3000/tcp, :::30000->3000/tcp                        gitea                 

使用-a选项可以看到所有容器,包括创建了但没有运行的容器(停止状态的容器)。

image.png

❯ docker ps -a
CONTAINER ID   IMAGE                          COMMAND                  CREATED        STATUS                      PORTS                                                                                      NAMES
940156496e93   musnows/linux-monitor:latest   "/bin/bash"              24 hours ago   Exited (255) 13 hours ago                                                                                              linux_monitor
04fec1b6c345   b3log/siyuan:v3.1.0            "/opt/siyuan/kernel …"   2 weeks ago    Up 16 minutes               0.0.0.0:10060->6806/tcp, :::10060->6806/tcp, 0.0.0.0:10061->6808/tcp, :::10061->6808/tcp   siyuan
69328f37ac26   bitnami/minio:latest           "/opt/bitnami/script…"   2 weeks ago    Up 16 minutes               0.0.0.0:9000-9001->9000-9001/tcp, :::9000-9001->9000-9001/tcp                              minio
612786ac157c   neosmemo/memos:latest          "./memos"                5 weeks ago    Up 16 minutes               0.0.0.0:14710->5230/tcp, :::14710->5230/tcp                                                memos
e4c3decfa29d   halohub/halo:2.11.3            "sh -c 'java ${JVM_O…"   5 months ago   Exited (255) 5 months ago   0.0.0.0:18000->8090/tcp, :::18000->8090/tcp                                                halo
ffbdfb02af22   gitea/gitea:1.21.4             "/usr/bin/entrypoint…"   5 months ago   Up 16 minutes               127.0.0.1:2222->22/tcp, 0.0.0.0:30000->3000/tcp, :::30000->3000/tcp                        gitea
642c1a6c90d2   mysql:5.7                      "docker-entrypoint.s…"   5 months ago   Exited (255) 5 months ago   33060/tcp, 0.0.0.0:13306->3306/tcp, :::13306->3306/tcp                                     mysql57

所有使用容器名操作的命令,都可以使用容器的CONTAINER ID进行操作,使用容器的container id是更好的选择,因为它是每个容器唯一的,不会重复。

docker start/stop/restart

用于对某个容器进行操作,启动、停止、容器容器。

docker start 容器名   # 运行
docker stop 容器名    # 停止
docker restart 容器名 # 重启

docker rm

这个命令用于删除某个容器。容器必须是停止状态才能被删除。同样可以使用-f选项强制删除某个正在运行的容器。

docker rm 容器名
docker rm 容器ID

docker stats

这个命令可以查看当前正在运行的容器状态,包括容器占用的内存/CPU百分比等性能信息

docker stats       # 查看所有容器的运行状态
docker stats 容器名 # 查看某个容器的运行状态

docker exec

这个命令用于进入某个正在运行的容器的终端,或者说是在某个容器中执行命令,-it选项代表以命令行交互与容器通信。

docker exec -it 容器名 需要执行的命令

比如我们想进入linux_monitor容器的终端,使用的是如下命令。这个命令本质上是在容器内执行/bin/bash命令,相当于启动了一个容器内的bash终端。

docker exec -it linux_monitor /bin/bash

如果我们想进入mysql容器内的mysql命令行,可以使用如下命令,相当于在名为mysql57的容器的终端中执行了mysql -uroot -p123456命令,这样能直接进入容器内的mysql终端。

docker exec -it mysql57 mysql -uroot -p123456

如下所示,我们使用这个命令直接进入了mysql容器内的终端

❯ docker exec -it mysql57 mysql -uroot -p123456
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.7.44 MySQL Community Server (GPL)

Copyright (c) 2000, 2023, Oracle and/or its affiliates.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> 

进入容器后,执行exit命令即会退出容器内的终端,回到宿主机的终端中。

注意,只有一个容器处于运行状态,才能使用 docker exec 进入到容器内终端中。

docker attach

想直接进入容器终端,还有另外一个命令。这个命令会直接进入容器内的终端。

docker attach 容器名

对比一下attach和exec命令

  • attach 不会在容器中创建进程执行额外的命令,只是附着到容器上。
  • exec 会在运行的容器上创建进程执行新的命令

如果docker容器是使用/bin/bash作为shell启动的,则可以使用attach来直接访问它。如果不是,则需要在容器内创建一个bash的进程。

docker cp

从容器内拷贝文件到宿主机上,也可以从宿主机拷贝文件到容器内。

docker cp 容器id:容器内路径 宿主机上的目的路径
docker cp 宿主机上的目的路径 容器id:容器内路径

【重点】docker run

docker run 命令用于从镜像中创建一个容器,命令行参数参考菜鸟教程。

docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

OPTIONS说明:

  • -a stdin: 指定标准输入输出内容类型,可选 STDIN/STDOUT/STDERR 三项;
  • -d: 后台运行容器,并返回容器ID;
  • -i: 以交互模式运行容器,通常与 -t 同时使用;
  • -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
  • -P: 随机端口映射,容器内部端口随机映射到主机的端口
  • -p: 指定端口映射,格式为:主机(宿主)端口:容器端口
  • –name=“nginx-lb”: 为容器指定一个名称;
  • –dns 8.8.8.8: 指定容器使用的DNS服务器,默认和宿主一致;
  • –dns-search example.com: 指定容器DNS搜索域名,默认和宿主一致;
  • -h “mars”: 指定容器的hostname;
  • -e username=“ritchie”: 设置环境变量;
  • –env-file=[]: 从指定文件读入环境变量;
  • –cpuset=“0-2” or --cpuset=“0,1,2”: 绑定容器到指定CPU运行;
  • -m:设置容器使用内存最大值;
  • –net=“bridge”: 指定容器的网络连接类型,支持 bridge/host/none/container: 四种类型
  • –link=[]: 添加链接到另一个容器;
  • –expose=[]: 开放一个端口或一组端口;
  • –volume , -v: 绑定一个卷
  • –rm:当容器内程序退出的时候,自动删除容器,用于测试运行。不能和-d一起使用。

示例:使用nginx镜像创建一个容器,并在后台运行。

docker run -d \
	--name mynginx 
	nginx:latest

当默认创建一个容器的时候,docker会给这个容器创建一个卷(volumes),就好比虚拟机的虚拟磁盘。当某个容器被删除,和它关联的卷也就失效了。所以,如果你在容器内部对容器运行的程序做了配置上的修改,删除这个容器后就会失效。

为了避免这种情况,我们一般都会将容器中的某个存放配置文件和数据的路径给映射到宿主机,这样容器对这个路径的修改就会直接写入到宿主机的文件系统中(持久化),即便容器删除也不会影响。

比如nginx的配置文件都在/etc/nginx中,我们可以把这个目录映射到宿主机的/root/docker/nginx路径中(冒号左侧是宿主机的路径,冒号右侧是容器内的路径),这样就可以直接通过修改宿主机中的路径来修改容器中nginx的配置,同时nginx容器的配置也实现了持久化,即便容器删除也不会丢失。

docker run -d \
	--name mynginx \
	-v /root/docker/nginx:/etc/nginx
	nginx:latest

当前状态下我们没有设置这个容器的网络环境,一般情况下,容器都会以默认的bridge桥接网络链接到宿主机中,即容器是通过宿主机的网卡做桥接(类似于虚拟机的NAT模式)上网的。

比如上方配置的nginx容器,它并不会对宿主机的80/443端口收到的请求做任何操作,因为它监听的是容器内的80和443端口,而这两个端口并没有映射到宿主机上。如果我们想让容器能处理宿主机收到的数据,则需要进行容器的端口映射

如下所示,我们使用了两个-p选项,分别映射了80端口和443端口到宿主机的80和443端口(冒号左侧是宿主机的端口,右侧是容器内的端口),此时使用的是默认的bridge桥接方式接通了容器和宿主机的网络端口。

docker run -d \
	--name mynginx \
	-v /root/docker/nginx:/etc/nginx \
	-p 80:80 \
	-p 443:443 \
	nginx:latest

当然,也可以直接用host网络模式运行nginx容器,这样nginx默认绑定的80和443就是直接绑定的宿主机的端口了。

docker run -d \
	--name mynginx \
	-v /root/docker/nginx:/etc/nginx \
	--net="host" \
	nginx:latest

关于docker run中-v命令和--mount命令以及绑定数据卷的说明,请参考docker volume中的介绍。

docker volume

volume是docker中的数据卷,可以用下方的命令来操作这些数据卷。

docker volume ls               # 查看所有数据卷
docker volume rm 数据卷ID       # 删除某个卷
docker volume inspect 数据卷ID  # 查看某个数据卷的详细信息
docker volume prune            # 删除没有使用的数据卷
docker volume create 数据卷名字  # 创建卷

关于数据卷的知识,可以看docker volume的介绍。

docker logs

docker logs可以查看某个容器的日志输出,用于定位容器运行产生的问题。

docker logs 容器ID
docker logs 容器名

比较常用的选项就是--tail,用于显示最新的几行命令,避免容器内的日志过长,打印耗时太久。

# 只显示最新20行的日志
docker logs 容器ID --tail=20

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

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

相关文章

内存之RAM、SRAM、DRAM、ROM、FLASH、SDRAM、DDR*(一篇文章就懂)

内存之RAM、SRAM、DRAM、ROM、FLASH、SDRAM、DDR* 内存 内存&#xff08;Memory&#xff09;指的是内存存储器&#xff0c;又称为主存&#xff0c;是CPU用来直接寻址和存储的空间&#xff0c;它相当于一座桥梁&#xff0c;用以负责诸如硬盘、主板、显卡等硬件上的数据与处理器…

高性价比开放式运动耳机有哪些?五大高性价比开放式耳机分享

作为一名数码爱好者&#xff0c;从93年入坑耳机、音响等各类电子产品以来&#xff0c;一直在测试不同品牌、不同价位的产品。现在开放式耳机比较热门&#xff0c;我自然也是不能错过的&#xff0c;开放式耳机拥有很多优点&#xff0c;很多采用人体工学设计&#xff0c;能够更加…

UE5打包iOS运行查看Crash日志

1、查看Crash 1、通过xCode打开设备 2、选择APP打开最近的日志 3、选择崩溃时间点对应的日志 4、选择对应的工程打开 5、就能看到对应的Crash日志 2、为了防止Crash写代码需要注意 1、UObject在RemoveFromRoot之前先判断是否Root if (SelectedImage && Selecte…

fl studio mobile2024最新官方版V4.6.8安卓版+iOS苹果版

fl studio mobile&#xff0c;一款非常好用的音乐制作软件。该软件具有丰富多样的音乐类型让大家选择&#xff0c;内置多个好用的编辑工具、渲染工具、特效工具等可以使用。用户可以自由使用软件中的任何道具&#xff0c;直接在手机上编曲&#xff0c;进行音乐创作&#xff0c;…

买超声波清洗机什么牌子好?好用的超声波清洗机推荐

尽管超声波清洗机对不少人而言较为新鲜&#xff0c;尤其是对非眼镜佩戴者&#xff0c;但它其实并不陌生&#xff0c;常现身于眼镜店作为专业清洁工具。有人或许认为&#xff0c;拂去眼镜尘埃仅需一擦即可&#xff0c;实际上&#xff0c;长时间佩戴后&#xff0c;镜片与框架累积…

【日常总结】阿里云:windows server 过一段时间登录不进去,或提示:出现身份验证错误。 无法连接到本地安全机构

场景 阿里云 : ESC系统&#xff1a;windows server 2022 问题 无法登录&#xff0c;或者登录浸提提示密码已过期 原因 密码设置了过期时间 解决方案 修改密码策略&#xff1a;密码设置永不过期 打开“本地安全策略”编辑器&#xff1a;运行 secpol.msc。 导航至“账户…

leetcode 2461.长度为k子数组的最大和

目录 题目描述 示例1&#xff1a; 示例2&#xff1a; 提示&#xff1a; 解题思路 滑动窗口法 概念 应用场景及特点&#xff1a; 思路 流程展示 代码 复杂度分析 题目描述 给你一个整数数组nums和一个整数k。请你从nums中满足下述条件的全部子数组中找出最大子数组…

开放式耳机别人能听到吗?不堵耳、不入耳的设计才舒服

开放式耳机的设计允许空气自由流通&#xff0c;这通常意味着它们在播放音乐时会有声音泄露到外部环境。因此&#xff0c;与封闭或半封闭的入耳式耳机相比&#xff0c;开放式耳机在一定程度上是可以让周围的人听到你正在播放的音乐的。声音泄露的程度取决于多种因素&#xff0c;…

【卡码网C++基础课 11.句子缩写】

目录 题目描述与分析一、字符大小的比较二、代码编写三、函数的使用四、形参和实参五、引用 题目描述与分析 题目描述&#xff1a; 输出一个词组中每个单词的首字母的大写组合。 输入描述&#xff1a; 输入的第一行是一个整数n&#xff0c;表示一共有n组测试数据。&#xff0…

[数据集][目标检测]电力场景输电线悬垂线夹检测数据集VOC+YOLO格式2538张2类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;2538 标注数量(xml文件个数)&#xff1a;2538 标注数量(txt文件个数)&#xff1a;2538 标注…

照片逼真肖像动画的音频驱动合成——AniPortrait翻译与调试

文章目录 AniPortrait翻译AbstractIntroduction2 Method2.1 Audio2Lmk2.2 Lmk2Video 3 Experiments3.1 Implementation Details3.2 Results 代码调试1 下载github项目2 配置环境3 下载包4 下载权重5 推断 AniPortrait翻译 AniPortrait&#xff1a;照片逼真肖像动画的音频驱动合…

解决使用matplotlib不显示中文的问题

某季度某城市某天11点到12点气温变化图 import random x range(60) y_BeiJing [random.uniform(15,18) for i in x] plt.figure(figsize(20,8),dpi80) plt.plot(x,y_BeiJing) x_label ["11点{}分".format(i) for i in x] plt.xticks(x[::5],x_label[::5]) plt.yt…

【网络】网络层协议-IP协议

网络层协议-IP协议 文章目录 IP协议1.网络层 & IP协议基本概念2.IP协议格式2.1报头各字段简介2.2IP如何将报头与有效载荷进行分离&#xff1f;2.3IP如何决定将有效载荷交付给上层的哪一个协议&#xff1f;2.4源IP与目的IP2.5八位生存时间2.6分片与组装 3.网段划分3.1IP地址…

嵌入式Qt移植前期准备-思维导图-学习笔记-基于正点原子阿尔法开发板

嵌入式Qt移植前期准备 概述 Qt官方在哪些平台/系统有支持&#xff1f; Windows Ubuntu IOS 为什么要进行Qt移植? 自制系统&#xff0c;如BusyBox简易系统&#xff0c;希望能运行Qt 厂家提供的Qt库太大&#xff0c;太全&#xff0c;占空间 版本升级&#xff0c;想用其它…

蒙特卡洛应用:RTX 光线追踪算法 ReSTIR 原理

接上文&#xff1a;蒙特卡洛方法相关论文&#xff1a;《Spatiotemporal reservoir resampling for real-time ray tracing with dynamic direct lighting: 2020》 ReSTIR 算法全称为 GIalgorithm based on Spatiotemporal Reservoir Resampling&#xff0c;是一种在实时路径追…

面试利器:产品经理必备的40+高频面试题集,收藏这一篇就够了

产品经理的面试&#xff0c;一般会问什么问题&#xff1f; 作为公司的产品负责人&#xff0c;大小也面了不下 100 个产品&#xff0c;产品经验横跨了 0~3 年、3~5 年。 我罗列了一些常用的产品面试问题&#xff0c;主要有“开始、产品、中级、考察、结束”等五类&#xff0c;…

【C++ 面试 - 面向对象】每日 3 题(十二)

✍个人博客&#xff1a;Pandaconda-CSDN博客 &#x1f4e3;专栏地址&#xff1a;http://t.csdnimg.cn/fYaBd &#x1f4da;专栏简介&#xff1a;在这个专栏中&#xff0c;我将会分享 C 面试中常见的面试题给大家~ ❤️如果有收获的话&#xff0c;欢迎点赞&#x1f44d;收藏&…

区间预测|基于灰狼优化最小二乘支持向量机的多变量回归区间预测Matlab程序GWO-LSSVM-ABKDE

区间预测|基于灰狼优化最小二乘支持向量机的多变量回归区间预测Matlab程序GWO-LSSVM-ABKDE 文章目录 前言区间预测|基于灰狼优化最小二乘支持向量机的多变量回归区间预测Matlab程序GWO-LSSVM-ABKDE 一、GWO-LSSVM-ABKDE模型1. 灰狼优化算法&#xff08;GWO&#xff09;2. 最小二…

vue.js - 看板娘 Live2d

文中的资源文件在这里&#xff1a;我的资源中&#xff0c;打好包了已经&#xff0c;地址&#xff1a;live2d资源 1、在项目的 src/assets 文件夹中&#xff0c;添加 live2d 的资源文件 2、在 src/components 文件中&#xff0c;编写 live2d的index.vue组件 3、在 App.vue 中…

AI在医学领域:在软组织和骨骼肿瘤放射学成像中的应用综述

软组织和骨骼肿瘤&#xff08;Soft-tissue and bone tumours&#xff0c;STBT&#xff09;是人体中较为罕见的肿瘤&#xff0c;包括良性和恶性病变。恶性STBT&#xff0c;约占所有肿瘤的1%。这些肿瘤可以发生在任何年龄和几乎所有解剖部位&#xff0c;起源于包括肌肉、脂肪、血…