前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >浅谈容器网络

浅谈容器网络

原创
作者头像
rxg456
发布于 2025-03-31 16:46:35
发布于 2025-03-31 16:46:35
8301
代码可运行
举报
运行总次数:1
代码可运行

030_动态控制断点_breakpoints_debug_调试290 播放 · 0 赞同视频

点击可播放视频
点击可播放视频

设置断点_break_point_continue_运行到断点 🥋

回忆上次内容

  • py文件 是
  • 按照顺序一行行执行的
  • 可以通过until命令
  • 直接跳转到某行
  • 也可以通过continue命令
  • 一路到底

添加图片注释,不超过 140 字(可选)

  • 还可以使用breakpoint()
  • 在程序中 设置断点
  • 然后配合continue
  • 一下子跳到断点位置
  • 断点breakpoint 位置
  • 是需要提前设置好的
  • 可以 在调试过程中
  • 动态地设置 或者 取消断点吗?🤔

恢复环境

  • 我们要把一行行执行的代码
  • 变成一段段执行的代码
  • 如果 上次运行的 guido.py 没有了
  • 就复制 下面这个
  • 然后放到网上系统的剪贴板上
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
print("1982------Guido in cwi")


print("1995------Guido in cnri")


print("2000------Guido in beopen")


print("2005------Guido in google")


print("2012------Guido in dropbox")


print("2020------Guido in microsoft")
  • 注意其中第4行
  • 没有breakpoint()
  • 如果有的话需要删除

添加图片注释,不超过 140 字(可选)

  • vi guido.py
  • 进入底行命令模式
  • "+p
  • 从系统剪贴板粘贴

编辑、调试一条龙

  • 这次 在vim里面
  • 直接运行pdb3

添加图片注释,不超过 140 字(可选)

  • :w|!pdb3 %
  • : 进入底行命令模式
  • w 保存
  • | 并且
  • !pdb3 %
  • 用 外部命令pdb3
  • 运行 % 当前文件
  • 就像 :w|!python3 %
  • 保存并运行
  • 很像
  • 连调试带修改 一条龙 了

回忆命令

  • 进入pdb3之后
  • 可以用help查看已经学习的命令

添加图片注释,不超过 140 字(可选)

  • h(elp)
  • 查询帮助
  • q(uit)
  • 退出debug环境
  • n(ext)
  • 执行本行
  • 跳转到下一行
  • l(ist)
  • 列出当前执行位置
  • 一行行执行代码 太慢
  • 如何快速跳转

快速跳转

  • unt(il)
  • 跳转到某行
  • c(ont(inue))
  • 一直向前
  • 直到遇到断点
  • breakpoint

添加图片注释,不超过 140 字(可选)

  • 如何动态 打断点 呢?

查询帮助

  • 查询帮助
  • 找到 有分段作用的命令

添加图片注释,不超过 140 字(可选)

  • break在英文中是打断的意思
  • 可以用这个break命令
  • 把代码打成一段段的吗
  • 去查查 break的帮助
  • h break

设置断点

  • break 的缩写 是 b

添加图片注释,不超过 140 字(可选)

  • 可以 对于py文件的行号
  • 设置断点

动手

  • 给第5行
  • 添加了一个断(break)点(point)

添加图片注释,不超过 140 字(可选)

  • next 一下
  • 向下执行了一行
  • 那怎么 快速让流程 流到断点 呢?
  • 不会了 就查帮助
  • 看看哪个命令好使

求助帮助

  • 不同于next
  • 一行行地执行
  • 回忆上次的命令
  • continue
  • continue 可以缩写为
  • cont
  • c

添加图片注释,不超过 140 字(可选)

  • 真的可以
  • 让 流程快速流转 到 断点 吗?
  • continue一下

continue

  • continue 本该
  • 直接流到 程序结尾
  • 但是第5行
  • 有断点
  • continue 让程序
  • 直接流到 断点处

添加图片注释,不超过 140 字(可选)

  • 为什么流程
  • 不往下 继续流 了呢?

断(break)点(point)

  • 因为断点
  • 就是 截断流程的 点
  • 流程流到这里 必须断开 的 点

添加图片注释,不超过 140 字(可选)

  • 断点 就像 一个阀门(valve) [vælv]或大坝
  • 会让水流停止
  • 如果 流到断点 后
  • 我想让 流程继续(continue)向下流
  • 该如何呢?🤔

continue

  • 由于 第五行后面
  • 没有断点

添加图片注释,不超过 140 字(可选)

  • continue 会 一直流到py程序结尾
  • 把 后面两行 都输出完成
  • 然后 重新开始
  • 又 圜道 了
  • 如果这个时候 再c 呢?

流到 断点

  • 从头开始后
  • 还是会 一直流到 断点
  • 只要 断点存在
  • continue 就会 流到断点

添加图片注释,不超过 140 字(可选)

  • 遇到断点
  • 必须要 停下来
  • 能否 取消断点 呢?
  • 求助一下help帮助

clear

  • clear 清除 断点
  • cl 是clear的缩写

添加图片注释,不超过 140 字(可选)

  • 有两种清除方法
  • clear 文件名:行号
  • clear 断点编号
  • 要删除哪些断点呢?

清除断点

  • b后面不加参数
  • 可以显示所有断点

添加图片注释,不超过 140 字(可选)

  • clear guido.py:5
  • 清除 guido.py第5行的 断点
  • 清除 之后
  • 原来的断点 消失了
  • 还有一种 清除断点的方式 是如何的 呢?
  • clear断点编号

清除某个断点

  • 再在guido.py第5行
  • 建立 一个断点
  • b 5
  • 这个断点 是2号断点

添加图片注释,不超过 140 字(可选)

  • 1号断点 已经被clear了
  • 现在 断点 从2开始 编号

添加图片注释,不超过 140 字(可选)

  • clear 2
  • 可以 清除 这个2号断点
  • 断点都清空了
  • q 命令退回到vim
  • 为什么 要有断点 呢?

断点的意义

  • 被调试程序(debug) 可能非常大
  • 可能 有 万行😏
  • 想要 找到程序中的问题
  • 一步一步next 太慢

添加图片注释,不超过 140 字(可选)

  • 所以 只有通过断点
  • 才能 直接跳到 某个位置

添加图片注释,不超过 140 字(可选)

  • 就像排除线路故障
  • 需要 在中间位置 建立观测点
  • 尽快对bug定位

设置3个断点

  • 这次 调试:!pdb3 %
  • 要设置 更多断点

添加图片注释,不超过 140 字(可选)

  • 1, 3, 6行
  • 各一个断点

更多断点

  • 断点 可以把万行程序 分几段
  • 从而 分段排查问题

添加图片注释,不超过 140 字(可选)

  • 尝试删除 第2个断点

删除第2个断点

  • 先 b 列出所有的断点
  • 要删除 2号断点
  • 位于guido.py的第3行

添加图片注释,不超过 140 字(可选)

  • 删除 成功
  • 还剩 两个断点
  • 断点就是 这样玩的
  • 可以依据行号删除断点吗?

依据行号删除度断点

  • 查看帮助

添加图片注释,不超过 140 字(可选)

  • 可以根据行号删除断点

添加图片注释,不超过 140 字(可选)

  • 现在 可以更快速地
  • 进行调试(debug)了!!😁

总结

  • 这次 动态设置了 断点
  • 断点 可以把代码
  • 切成一段一段的
  • 可以 更快地调试
  • 调试的目的 是 去除 bug
  • 别害怕 bug
  • 一步步 总能找到 bug
  • 这 就是 程序员基本功
  • 调试 debug
  • 在bug出现的时候
  • 甚至还没有出现操作系统
  • 那操作系统
  • 是怎么开始有的呢??🤔
  • 我们下次再说!👋

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
理解Docker跨多主机容器网络
在Docker 1.9 出世前,跨多主机的容器通信方案大致有如下三种: 1、端口映射 将宿主机A的端口P映射到容器C的网络空间监听的端口P’上,仅提供四层及以上应用和服务使用。这样其他主机上的容器通过访问宿主机A的端口P实 现与容器C的通信。显然这个方案的应用场景很有局限。 2、将物理网卡桥接到虚拟网桥,使得容器与宿主机配置在同一网段下 在各个宿主机上都建立一个新虚拟网桥设备br0,将各自物理网卡eth0桥接br0上,eth0的IP地址赋给br0;同时修改Docker daemon的DOCKER_OPTS
Rainbond开源
2018/05/31
1.6K0
Docker 网络
Docker 服务启动时会首先在主机上自动创建一个 docker0 的虚拟网桥,网桥可以理解为一个软件交换机,负责挂载其上的接口之间进行包转发。
张哥编程
2024/12/07
750
容器网络基础(一)
我们一定听过容器的基础原理,namespace做隔离,Cgroups做限制,rootfs做文件系统,容器本质上是linux的一个进程,那么为什么大多数场景下,容器不直接使用宿主机上的网络,而要是通过network namespace隔离出一组专属的网络空间呢?(容器的基础原理,可参考:https://coolshell.cn/articles/17010.html)
智零办法就是多
2022/04/13
1.5K0
解密Docker容器网络
一个Linux容器能看见的“网络栈”,被隔离在它自己的Network Namespace中。
JavaEdge
2023/07/09
3600
解密Docker容器网络
容器网络实践
本文通过docker的网络介绍容器网络的原理以及一些实践,通过实践一遍相信大家会对网络底层的原理有个更深的理解,最后给出对接ovs的教程,这对下一篇k8s对接ovn的原理理解打下一个基础。
sealyun
2019/07/25
7400
18 Sep 2019 容器网络(一)
所以,当容器不能上网时,首先ping docker0网桥,看是否能正常连接docker0网桥,然后查看docker0及相应的veth pair设备的iptables规则是否有异常,一般就能解决容器不能上网的问题了。
俊采
2023/10/17
2220
Docker 网络模式详解及容器间网络通信
Docker本身在它创建之初,它就有自己的网络驱动器,叫Container Network Manager,简称CNM。本身这个CNM会支持多种模式,本节来看一看这些模式的区别,然后去了解一下,要让一个容器网络真正地配置好,让容器真正地模拟成一个虚拟机,我们最终要做哪些配置。
贾维斯Echo
2024/03/20
2.7K0
Docker 网络模式详解及容器间网络通信
Docker容器网络-基础篇
Docker的技术依赖于Linux内核的虚拟化技术的发展,Docker使用到的网络技术有Network Namespace、Veth设备对、Iptables/Netfilter、网桥、路由等。接下来,我将以Docker容器网络实现的基础技术来分别阐述,在到真正的容器篇章节之前,能形成一个稳固的基础知识网。
民工哥
2020/09/17
2.1K0
Docker容器网络-基础篇
K8s面试系列: Flannel VS Calico 基于 L2 与 L3 的 CNI 之战(一)
在童年期,我们更多是处于认知,而不是意欲的状态。—— 《作为意欲和表象的世界》第二卷第三十一章
山河已无恙
2025/02/25
1220
K8s面试系列: Flannel VS Calico 基于 L2 与 L3 的 CNI 之战(一)
一文读懂 Kubernetes 容器网络
在Kubernetes中要保证容器之间网络互通,网络至关重要。而Kubernetes本身并没有自己实现容器网络,而是通过插件化的方式自由接入进来。在容器网络接入进来需要满足如下基本原则:
iMike
2021/02/07
6600
干货 | 手把手带你搞定4大容器网络问题
一直以来,网络都是容器中令人头疼的问题。本文的主要目的是带你解决容器网络问题,让你不再对它恐惧。
CloudBest
2021/03/29
1K0
干货 | 手把手带你搞定4大容器网络问题
036.集群网络-K8S网络模型及Linux基础网络
  Kubernetes网络模型设计的一个基础原则是:每个Pod都拥有一个独立的IP地址,并假定所有Pod都在一个可以直接连通的、扁平的网络空间中。所以不管它们是否运行在同一个Node(宿主机)中,都要求它们可以直接通过对方的IP进行访问。设计这个原则的原因是,用户不需要额外考虑如何建立Pod之间的连接,也不需要考虑如何将容器端口映射到主机端口等问题。
不会飞的小鸟
2020/03/22
7430
Docker单机网络模型动手实验
容器的本质就是一个进程,只不过对它进行了Linux Namesapce隔离,让它看不到外面的世界,用Cgroups限制了它能使用的资源,同时利用系统调用pivot_root或chroot切换了进程的根目录,把容器镜像挂载为根文件系统rootfs。rootfs中不仅有要运行的应用程序,还包含了应用的所有依赖库,以及操作系统的目录和文件。rootfs打包了应用运行的完整环境,这样就保证了在开发、测试、线上等多个场景的一致性。
mazhen
2023/11/24
2960
Docker单机网络模型动手实验
说说linux容器的隔离
说到docker,大家都懂。但是LXC可能就比较陌生。Docker的起源于LXC。LXC的英文全称是Linux Container,相比较其他虚拟机而言,是一种轻量级虚拟化技术,它介于Chroot(linux的一个改变根目录挂载点的机制)和完整开发的虚拟机之间。LXC不使用单独的内核资源,但是可以创建一个类似的Linux操作系统环境。
mariolu
2020/02/13
3.2K0
Docker容器学习梳理--容器间网络通信设置(Pipework和Open vSwitch)
自从Docker容器出现以来,容器的网络通信就一直是被关注的焦点,也是生产环境的迫切需求。容器的网络通信又可以分为两大方面:单主机容器上的相互通信,和跨主机的容器相互通信。下面将分别针对这两方面,对容器的通信原理进行简单的分析,帮助大家更好地使用docker。前面已经在Docker容器学习梳理--基础知识(2)这一篇中详细介绍了Docker的网络配置以及pipework工具。 docker单主机容器通信 基于对net namespace的控制,docker可以为在容器创建隔离的网络环境,在隔离的网络环境下,
洗尽了浮华
2018/01/23
3.5K0
Docker容器学习梳理--容器间网络通信设置(Pipework和Open vSwitch)
云原生时代必须具备的核心技能之Docker高级篇(Docker网络详解)
  前面给大家项目的介绍了Docker的基础内容 Docker基础篇 接下来给大家系统的介绍下Docker高级篇的内容:网络核心、Docker实战、DockerCompose、Harbor以及Swarm。欢迎关注收藏哦
用户4919348
2022/01/06
6860
云原生时代必须具备的核心技能之Docker高级篇(Docker网络详解)
面试官:Docker 有几种网络模式?5 年工作经验都表示答不上来。。
Docker在安装后自动提供3种网络,可以使用docker network ls命令查看
Java技术栈
2023/02/27
8050
面试官:Docker 有几种网络模式?5 年工作经验都表示答不上来。。
Kubernetes网络模型
在Kubernetes中设计了一种网络模型,要求无论容器运行在集群中的哪个节点,所有容器都能通过一个扁平的网络平面进行通信,即在同一IP网络中。需要注意的是:在K8S集群中,IP地址分配是以Pod对象为单位,而非容器,同一Pod内的所有容器共享同一网络名称空间。
mikelLam
2022/10/31
1.2K0
Kubernetes网络模型
【重识云原生】第六章容器6.1.12节——Docker网络模型设计
        先来简要回顾一下前面的内容,namespace和cgroup是Linux 内核的两大特性,namespace的诞生据说就是为了支持容器技术,那么这俩特性到底干了啥呢?
江中散人_Jun
2022/09/28
4660
【重识云原生】第六章容器6.1.12节——Docker网络模型设计
使用 Linux 网络虚拟化技术探究容器网络原理
在 使用 Go 和 Linux Kernel 技术探究容器化原理 一文中,我们揭秘了容器的本质就是一个特殊的进程,特殊在为其创建了 NameSpace 隔离运行环境,并用 Cgroups 为其控制资源开销。
gopher云原生
2022/11/22
1.7K0
使用 Linux 网络虚拟化技术探究容器网络原理
推荐阅读
相关推荐
理解Docker跨多主机容器网络
更多 >
LV.3
这个人很懒,什么都没有留下~
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验