【Docker-13】Docker Container容器

Docker Container(容器)

一、什么是容器?

通俗地讲,容器是镜像的运行实体。镜像是静态的只读文件,而容器带有运行时需要的可写文件层,并且容器中的进程属于运行状态。即容器运行着真正的应用进程。容器有初建、运行、停止、暂停和删除五种状态。

虽然容器的本质是主机上运行的一个进程,但是容器有自己独立的命名空间隔离和资源限制。也就是说,在容器内部,无法看到主机上的进程、环境变量、网络等信息,

这是容器与直接运行在主机上进程的本质区别。

容器是基于镜像创建的可运行实例,并且单独存在,一个镜像可以创建出多个容器。运行容器化环境时,实际上是在容器内部创建该文件系统的读写副本。 这将添加一个

容器层,该层允许修改镜像的整个副本。

QQ_1742387333677

容器生活案例?

镜像与容器就相当于同样是开发商提供的毛坯房,但是两家人装修出来的完全不一样。

QQ_1742387354717

或者我们都学习了 Java 或者 C++之类的面向对象的语言,可以理解为镜像为基础类,

容器是实例化出来的一个个对象,没有用户需要的不一样,里面的内容也就不一样了。

QQ_1742387370030

为什么需要容器?

镜像是静态的文件,并不能提供服务,就像我拿了个 Linux 或者 Windows 的光盘一样,只有安装到主机里面运行起来才能对外提供服务,我们才能使用。

容器带来哪些收益呢,参考我们之前讲解的为什么要虚拟化、容器化。

二、容器的生命周期

容器的生命周期是容器可能处于的状态。

  1. created:初建状态
  2. running:运行状态
  3. stopped:停止状态
  4. paused: 暂停状态
  5. deleted:删除状态

各生命周期之间的转换关系如图所示:

QQ_1742387812010

docker create : 创建容器后,不立即启动运行,容器进入初建状态;

docker run : 创建容器,并立即启动运行,进入运行状态;

docker start : 容器转为运行状态;

docker stop : 容器将转入停止状态;

docker kill : 容器在故障(死机)时,执行 kill(断电),容器转入停止状态,这种操作容易丢失数据,除非必要,否则不建议使用;

docker restart : 重启容器,容器转入运行状态;

docker pause : 容器进入暂停状态;

docker unpause : 取消暂停状态,容器进入运行状态;

docker rm : 删除容器,容器转入删除状态。

killed by out-of-memory(因内存不足被终止) :宿主机内存被耗尽,也被称为 OOM:非计划终止 这时需要杀死最吃内存的容器

container process exitde(异常终止):出现容器被终止后,将进入 Should restart?选择操作:

• yes 需要重启,容器执行 start 命令,转为运行状态。

• no 不需要重启,容器转为停止状态。

容器 OOM

Docker 在处理 OOM 事件时分为三种情况

(1)如果容器中的应用耗尽了主机系统分配给容器的内存限额,就会触发 OOM 事件。例如,在容器当中,部署了一个 web 服务。假设主机分配给此容器的内存上限为 1G,当脚本申请的内存大于 1G 时,此容器就会触发 OOM 事件。而在这种情况下,此容器将会被强制关闭。

但需要注意的是,此时关闭容器的并非是 Docker Daemon,而是宿主机操作系统。因为一个容器其实就是一组运行在宿主机操作系统当中的进程,宿主机操作系统通过cgroups 对这组进程设定资源上限,当这些进程申请的资源到达上限时,触发的是宿主机操作系统的内核 OOM 事件,因此最终是由宿主机内核来关闭这些进程.

(2) 如果用户不想关闭这个容器,那么可以选择–oom-kill-disable 来禁用 OOM-Killer。使用此参数时,仍需要注意,如果使用-m 设置了此容器内存上限,那么当容器到达内存资源上限时,主机不会关闭容器,但也不会继续向此容器继续分配资源,此时容器将处于 hung 状态。只需要将最坏的情况封闭在一定范围之内,而不至于蔓延出去。

(3)如果用户使用了–oom-kill-disable,但也没有使用-m 来设定上限,因而此时此容器将会尽可能多地使用主机内存资源。换言之,主机内存有多大,它就将用多大。

容器异常退出

每个容器内部都存在一个 Init 进程,容器中其他所有进程都是此进程的子进程。运行的容器是因为 Init 进程在运行,如果一个子进程因为某种原因造成了退出,那么其父进程也会同步退出,直至 Init 进程也退出。当 Init 进程退出时,也就代表着此容器被关闭。ocker 目前没有办法知道此时的进程退出属于正常退出还是异常退出。当出现容器关闭情况时,Docker Daemon 会尝试再次重新将此容器由 Stopped 状态转为 Running状态。只有设置了–restart 参数的容器,Docker Daemon 才会去尝试启动,否则容器会保持停止状态。

容器暂停

Docker“剥夺”了此容器的 CPU 资源。而其他资源,如 Memory 资源、Network 资源等还保留未动。如此一来,失去了 CPU 资源的进程,是不会被主机内核系统所调度的,所以此容器就处于“冰封”状态。

三、容器命令

1.容器命令清单

QQ_1742387945429

image-20250319204001127

QQ_1742388168242

2.容器命令详解

1.docker create

功能:创建一个新的容器但不启动它

语法
docker create [OPTIONS] IMAGE [COMMAND] [ARG...]别名
docker container create关键参数
○ -i: 以交互模式运行容器,通常与 -t 同时使用;
○ -P: 随机端口映射,容器内部端口随机映射到主机的端口
○ -p: 指定端口映射,格式为:主机(宿主)端口:容器端口
○ -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
○ --name="nginx-lb": 为容器指定一个名称;
○ -h "mars": 指定容器的 hostname;
○ -e username="ritchie": 设置环境变量;
○ --cpuset-cpus="0-2" or --cpuset-cpus="0,1,2": 绑定容器到指定 CPU 运行;
○ -m :设置容器使用内存最大值;
○ --network="bridge": 指定容器的网络连接类型;
○ --link=[]: 添加链接到另一个容器;
○ --volume , -v: 绑定一个卷
○ --rm :shell 退出的时候自动删除容器
○ --restart:自动重启

示例

QQ_1742389159712

QQ_1742389285309

2.docker run

功能:创建一个新的容器并运行一个命令

语法:
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]别名
docker container run关键参数
○ -d: 后台运行容器,并返回容器 ID;比 create 多了这个参数 (**********)
○ -i: 以交互模式运行容器,通常与 -t 同时使用;
○ -P: 随机端口映射,容器内部端口随机映射到主机的端口
○ -p: 指定端口映射,格式为:主机(宿主)端口:容器端口
○ -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
○ --name="nginx-lb": 为容器指定一个名称;
○ -h "mars": 指定容器的 hostname;
○ -e username="ritchie": 设置环境变量;
○ --cpuset-cpus="0-2" or --cpuset-cpus="0,1,2": 绑定容器到指定 CPU 运行;
○ -m :设置容器使用内存最大值;
○ --network="bridge": 指定容器的网络连接类型;
○ --link=[]: 添加链接到另一个容器;
○ --volume , -v: 绑定一个卷
○ --rm :shell 退出的时候自动删除容器
○ --restart:自动重启

示例

使用 docker 镜像 nginx:1.23.4 以后台模式启动一个容器,将容器的 8051 端口映射到主机的 80 端口,并将容器命名为 mywebsite4root@Nanyiroot:~# docker run -d -p 8051:80 --name mywebsite4 nginx:1.23.4
9c9cbafea7f42491eef80e9238829eecd5db48b292d39f7e0c447c62c93c56d3
root@Nanyiroot:~# docker ps | grep 8051
9c9cbafea7f4   nginx:1.23.4   "/docker-entrypoint.…"   32 seconds ago   Up 31 seconds   0.0.0.0:8051->80/tcp, [::]:8051->80/tcp   mywebsite4
3.docker ps

功能:列出容器

语法
docker ps [OPTIONS]别名
docker container ls, docker container list, docker container ps关键参数
○ -a :显示所有的容器,包括未运行的。
○ -f :根据条件过滤显示的内容。
○ --format :指定返回值的模板文件。如 json 或者 table
○ -l :显示 latest 的容器。
○ -n :列出最近创建的 n 个容器。
○ --no-trunc :不截断输出。
○ -q :静默模式,只显示容器编号。
○ -s :显示总的文件大小。

示例:

QQ_1742389636477

4.docker logs

功能:查看容器日志

语法:
docker logs [OPTIONS] CONTAINER别名
docker container logs关键参数
○ -f ,--follow: 跟踪日志输出
○ --since :显示某个开始时间的所有日志
○ -t,--timestamps : 显示时间戳
○ -n,-tail :仅列出最新 N 条容器日志

示例1:跟踪查看容器 mywebsite4 的日志输出

QQ_1742390064848

示例2:查看容器 mynginx 从 2025 年 3 月 17 日后的最新 10 条日志

QQ_1742390141089

5.docker attach

功能:连接到正在运行中的容器。

语法
docker attach [OPTIONS] CONTAINER别名
docker container attach关键参数
--sig-proxy:是否将所有信号代理,默认是 true,如果设置为 false,退出的话不会影响容器,否则退出会导致容器退出

示例:

此处按了 Ctrl + C 后会把容器杀死。

QQ_1744716525880

QQ_1744716575716

带上参数 重新启动 mywebsite4 并且ctrl + c

此时按了 Ctrl + C 并没有把容器杀死

QQ_1744716729731

显示报文为:CONTAINER ID:容器 ID。
IMAGE:使用的镜像。
COMMAND:启动容器时运行的命令。
CREATED:容器的创建时间。
STATUS:容器状态。
PORTS:容器的端口信息和使用的连接类型(tcp \ udp)。
NAMES:自动分配的容器名称。
6.docker exec

功能:在容器中执行命令

语法:
docker exec [OPTIONS] CONTAINER COMMAND [ARG...]别名:
docker container exec关键参数:
○ -d :分离模式: 在后台运行
○ -i :即使没有附加也保持 STDIN 打开
○ -t :分配一个伪终端
○ -e :设置环境变量
○ -u,--user :指定用户 "<name|uid>[:<group|gid>]"
○ -w,--workdir:指定工作目录

示例1:在容器 mynginx 中以交互模式执行 echo

QQ_1744717294039

示例2:在容器 mynginx 中以交互模式打开 shell

QQ_1744717327320

示例3:通过 id 进去,docker ps 可以看到容器 id

QQ_1744717399868

7.docker start

功能:启动停止的容器

语法:
docker start [OPTIONS] CONTAINER [CONTAINER...]别名:
docker container start

示例:

QQ_1744717560504

8.docker stop

功能:停止运行的容器

语法:
docker stop [OPTIONS] CONTAINER [CONTAINER...]别名:
docker container stop关键参数
○ -s :发送的信号

QQ_1744717669602

9.docker restart

功能:重启容器

语法:
docker restart [OPTIONS] CONTAINER [CONTAINER...]别名:
docker container restart关键参数
○ -s :发送信号

QQ_1744717740332

10.docker kill

功能:强制退出容器

语法:
docker kill [OPTIONS] CONTAINER [CONTAINER...]别名:
docker container kill关键参数:
-s :发送的信号注意事项:
○ docker stop 发送的是 SIGTERM 信号,docker kill 发送的是 SIGKILL 信号

QQ_1744717825659

11.docker top

功能:查看容器中运行的进程信息,支持 ps 命令参数

语法:
docker top CONTAINER [ps OPTIONS]别名:
docker container top注意事项:
容器运行时不一定有/bin/bash 终端来交互执行 top 命令,而且容器还不一定有top 命令,可以使用 docker top 来实现查看 container 中正在运行的进程。

示例:查看容器进程信息

QQ_1744717927344

12.docker stats

功能:显示容器资源的使用情况,包括: CPU 、内存、网络 I/O 等

语法:
docker stats [OPTIONS] [CONTAINER...]别名:
docker container stats关键参数:
○ --all , -a :显示所有的容器,包括未运行的。
○ --format :指定返回值的模板文件。如 table,json
○ --no-stream :展示当前状态就直接退出了,不再实时更新。
○ --no-trunc :不截断输出。返回报文
CONTAINER ID 与 NAME: 容器 ID 与名称。
CPU % 与 MEM %: 容器使用的 CPU 和内存的百分比。
MEM USAGE / LIMIT: 容器正在使用的总内存,以及允许使用的内存总量。
NET I/O: 容器通过其网络接口发送和接收的数据量。
BLOCK I/O: 容器从主机上的块设备读取和写入的数据量。
PIDs: 容器创建的进程或线程数。

示例1:列出所有在运行的容器信息

QQ_1744718104444

示例2: json 格式显示

QQ_1744718211358

示例3:定制化的表格显示

docker stats --format "table {{.Container}}\t{{.CPUPerc}}\t{{.MemUsage}}"

QQ_1744718298353

13.docker container inspect

功能:查看容器详细信息

语法:
docker container inspect [OPTIONS] CONTAINER [CONTAINER...]关键参数:
○ -f :指定返回值的模板文件。如 table、json
○ -s :显示总的文件大小。注意事项:
docker inspect 会自动检查是镜像还是容器然后显示相信信息

示例:

QQ_1744718428460

14.docker port

功能:用于列出指定的容器的端口映射,或者查找将 PRIVATE_PORT NAT 到面向公众的端口。

语法:
docker port CONTAINER [PRIVATE_PORT[/PROTO]]别名:
docker container port 

示例:

QQ_1744718492207

15.docker cp

功能:在容器和宿主机之间拷贝文件。

语法:
docker cp [OPTIONS] CONTAINER:SRC_PATH DEST_PATH|-
docker cp [OPTIONS] SRC_PATH|- CONTAINER:DEST_PATH别名:
docker container cp样例
#将主机/www/目录拷贝到容器mynginx 的/www目录下。
docker cp /www/ mynginx:/www/
#将容器/www/目录拷贝到主机的/wwwbak目录下。
docker cp mynginx:/www/ /wwwbak/

示例

QQ_1744718662731

16.docker diff

功能:检查容器里文件结构的更改。

语法:
docker diff CONTAINERC表示change
A表示add

示例

QQ_1744718785220

17.docker commit

功能:从容器创建一个新的镜像。

语法:
docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]] 参数:
○ -a :提交的镜像作者;
○ -c :使用 Dockerfile 指令来创建镜像;可以修改启动指令
○ -m :提交时的说明文字;
○ -p :在 commit 时,将容器暂停。

示例:基于已有的 nginx:1.23.4 容器,创建一个新镜像 mywebsite4:v1.0,并验证是否能保存你在容器中做的改动

关键:把正在运行的容器 快照成一个新的镜像,叫做 mywebsite4:v1.0

QQ_1744719549988

Docker 镜像版本迭代和验证修改是否保留的过程

🔁 场景:在 mywebsite4forcommit 容器中修改了文件,然后通过 docker commit 生成新的镜像 mywebsite4:v2.0,并验证修改是否成功保存。

启动镜像 v2.0,进入容器交互式终端,并设置 --rm 表示退出后自动删除容器(只是为了测试,不留垃圾)

QQ_1744719900216

18.docker pause

功能:暂停容器中所有的进程

语法:
docker pause CONTAINER [CONTAINER...]  别名:
docker container pause

示例:

QQ_1744720502849

19.docker unpause

功能:恢复容器中所有的进程

语法:docker unpause CONTAINER [CONTAINER...]别名:
docker container unpause

QQ_1744720582045

20.docker rm

功能:删除停止的容器

语法:
docker rm [OPTIONS] CONTAINER [CONTAINER...]别名:
docker container rm关键参数:
-f :通过 SIGKILL 信号强制删除一个运行中的容器。

示例1:删除 mywebsite5 容器

QQ_1744720759114

示例二:删除所有停止的容器

docker rm $(docker ps -a -q)
21.docker export

功能:导出容器内容为 tar 文件 – 导出的时候会丢失数据

语法:
docker export [OPTIONS] CONTAINER别名:
docker container export关键参数:
○ -o:写入到文件。

示例:导出 mywebsite6 为tar

QQ_1744721019024

其中docker export docker import是对应的,之前我们也学过docker import 在镜像里

QQ_1744721133115

22.docker wait

功能:阻塞运行直到容器停止,然后打印出它的退出代码。

语法:
docker wait CONTAINER [CONTAINER...]别名:
docker container wait

示例:
QQ_1744721803944

QQ_1744721814331

23.docker rename

功能:重命名容器。

语法:
docker rename CONTAINER NEW_NAME别名:
docker container rename

示例:

QQ_1744722002099

24.docker container prune

功能:删除所有停止的容器

语法:
docker container prune [OPTIONS]关键参数:
-f,--force:不提示是否进行确认。

示例:

QQ_1744722207442

QQ_1744722239498

25.docker update

功能:更新容器配置。

语法:
docker update [OPTIONS] CONTAINER [CONTAINER...]别名:
docker container update 关键参数
○ --cpus:cpu 数量
○ --cpuset-cpus :使用哪些 cpu
○ --memory :内存限制
○ --memory-swap:交换内存
○ --cpu-period :是用来指定容器对 CPU 的使用要在多长时间内做一次重新分配
○ --cpu-quota:是用来指定在这个周期内,最多可以有多少时间用来跑这个容器

示例:

QQ_1744722376669

QQ_1744722517909

QQ_1744722545895

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

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

相关文章

Spring Cache(笔记)

简介&#xff1a; 常用注解&#xff1a;

大模型Qwen32b(FP16精度)部署所需的显存大小和并发数计算分析

大家好&#xff0c;我是微学AI&#xff0c;今天给大家介绍一下大模型Qwen32b(FP16精度)部署所需的显存大小和并发计算分析。 文章目录 1. 大模型显存需求分析1.1 模型参数与显存占用1.2 不同精度对显存的影响 2. 不同显卡配置下的并发能力2.1 80G显卡并发能力2.2 64G显卡并发能…

【euclid】10.2 2D变换模块(transform2d.rs)Arbitrary trait

源码 #[cfg(feature "arbitrary")] impl<a, T, Src, Dst> arbitrary::Arbitrary<a> for Transform2D<T, Src, Dst> whereT: arbitrary::Arbitrary<a>, {fn arbitrary(u: &mut arbitrary::Unstructured<a>) -> arbitrary::Res…

MAC Mini M4 上测试Detectron2 图像识别库

断断续续地做图像识别的应用&#xff0c;使用过各种图像识别算法&#xff0c;一开始使用openCV 做教室学生计数的程序。以后又使用YOLO 做医学伤口检测程序。最近&#xff0c;开始使用meta 公司的Detectron2.打算做OCR 文档结构分析 Detectron2 的开发者是 Meta 的 Facebook AI…

一天时间,我用AI(deepseek)做了一个配色网站

前言 最近在开发颜色搭配主题的相关H5和小程序&#xff0c;想到需要补充一个web网站&#xff0c;因此有了这篇文章。 一、确定需求 向AI要答案之前&#xff0c;一定要清楚自己想要做什么。如果你没有100%了解自己的需求&#xff0c;可以先让AI帮你理清逻辑和思路&#xff0c;…

机器视觉用消色差双合透镜

光学系统案例&#xff1a;机器视觉用消色差双合透镜 一、设计规格 1. 应用场景&#xff1a;专为工业相机成像而设计&#xff0c;工作于可见光波段&#xff0c;旨在满足该领域对高精度成像的需求。 2. 核心参数&#xff1a; • 焦距&#xff1a;精确要求达到 50 mm 1%&#…

批量归一化(Batch Normalization)原理与PyTorch实现

批量归一化&#xff08;Batch Normalization&#xff09;是加速深度神经网络训练的常用技术。本文通过Fashion-MNIST数据集&#xff0c;演示如何从零实现批量归一化&#xff0c;并对比PyTorch内置API的简洁实现方式。 1. 从零实现批量归一化 1.1 批量归一化函数实现 import t…

feedback

这个文件 lib/pages/feedback/index.dart 是一个反馈/留言表单页面的实现&#xff0c;主要功能是&#xff1a; 表单收集功能&#xff1a; 真实姓名&#xff08;必填&#xff09;联系电话&#xff08;必填&#xff0c;需要验证手机号格式&#xff09;电子邮箱&#xff08;选填&a…

数据仓库标准库模型架构相关概念浅讲

数据仓库与模型体系及相关概念 数据仓库与数据库的区别可参考&#xff1a;数据库与数据仓库的区别及关系_数据仓库和数据库-CSDN博客 总之&#xff0c;数据库是为捕获数据而设计&#xff0c;数据仓库是为分析数据而设计 数据仓库集成工具 在一些大厂中&#xff0c;其会有自…

适用于 HAL 的 AIDL

目录 设计初衷 注意 编写AIDLHAL接口 查找AIDLHAL接口 扩展接口 将现有HAL从HIDL转换为AIDL AIDL与HIDL之间的主要差异 针对HAL的供应商测试套件(VTS)测试 Android 11 中引入了在 Android 中使用 AIDL 实现 HAL 的功能, 从而可以在不使用 HIDL 的情况下实现 Android 的部分…

leetcode0547. 省份数量-medium

1 题目&#xff1a;省份数量 官方标定难度&#xff1a;中 有 n 个城市&#xff0c;其中一些彼此相连&#xff0c;另一些没有相连。如果城市 a 与城市 b 直接相连&#xff0c;且城市 b 与城市 c 直接相连&#xff0c;那么城市 a 与城市 c 间接相连。 省份 是一组直接或间接相…

【专题刷题】双指针(一)

&#x1f4dd;前言说明&#xff1a; 本专栏主要记录本人的基础算法学习以及LeetCode刷题记录&#xff0c;按专题划分每题主要记录&#xff1a;1&#xff0c;本人解法 本人屎山代码&#xff1b;2&#xff0c;优质解法 优质代码&#xff1b;3&#xff0c;精益求精&#xff0c;…

WebSocket 技术详解

引言 在现代Web应用中&#xff0c;实时通信已经成为不可或缺的一部分。想象一下聊天应用、在线游戏、股票交易平台或协作工具&#xff0c;这些应用都需要服务器能够即时将更新推送给客户端&#xff0c;而不仅仅是等待客户端请求。WebSocket技术应运而生&#xff0c;它提供了一…

【redis】初识redis

初识redis Redis 是一种基于键值对&#xff08;key-value&#xff09; 的 NoSQL 的数据库&#xff0c;它与很多键值数据库不同&#xff0c; Redis 中的值可以是 string&#xff08;字符串&#xff09; 、hash&#xff08;哈希&#xff09;、list&#xff08;链表&#xff09;、…

UE5 制作方块边缘渐变边框效果

该效果基于之前做的&#xff08;https://blog.csdn.net/grayrail/article/details/144546427&#xff09;进行修改得到&#xff0c;思路也很简单&#xff1a; 1.打开实时预览 1.为了制作时每个细节调整方便&#xff0c;勾选Live Update中的三个选项&#xff0c;开启实时预览。…

基于springboot的“嗨玩旅游网站”的设计与实现(源码+数据库+文档+PPT)

基于springboot的“嗨玩旅游网站”的设计与实现&#xff08;源码数据库文档PPT) 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;springboot 工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 系统展示 系统功能结构图 局部E-R图 系统首页界面 系统注册…

grafana/loki 部署搜集 k8s 集群日志

grafana/loki 和 grafana/loki-stack 的区别 ​Grafana 提供了多个 Helm Chart 用于在 Kubernetes 集群中部署 Loki 及相关组件,其中主要包括 grafana/loki 和 grafana/loki-stack。​它们的主要区别如下:​ 1.grafana/loki Helm Chart: 专注于 Loki 部署: 该 Chart 专门…

Nacos-Controller 2.0:使用 Nacos 高效管理你的 K8s 配置

作者&#xff1a;濯光、翼严 Kubernetes 配置管理的局限 目前&#xff0c;在 Kubernetes 集群中&#xff0c;配置管理主要通过 ConfigMap 和 Secret 来实现。这两种资源允许用户将配置信息通过环境变量或者文件等方式&#xff0c;注入到 Pod 中。尽管 Kubernetes 提供了这些强…

python自动化浏览器标签页的切换

#获取全部标签页的句柄返回句柄的列表 handleswebdriver.window_handles#获取全部标签页的句柄返回句柄的列表 print(len(handles)) 切换标签页 handleswebdriver.window_handles webdriver.switch_to.window(handles[index])#切换到第几个标签页就写几 关闭标签页 关闭标…

微信小程序组件传参

微信小程序组件传参感觉和vue还是挺像的 父组件向子组件传参 在小程序中父组件子组件传参&#xff0c;主要使用properties属性。演示下&#xff1a; 创建组件文件夹component&#xff0c;创建组件demoComponent&#xff0c;记得创建的时候选择组件&#xff0c;不是page页面 …