Debug 日志:CPython GH-120437
和 SRE 日志 系列一样,Debug 日志用来复盘我一些可以公开的调试经历,希望能帮助到大家。 这篇是 Python 3.13 Beta 下 JIT/Tier 2 优化器的一个 Bug ,前后历时五天,最终修改点很小,非常有趣 开篇13号的时候,用户反馈了一个 Bug,编号 GH1204371 ,具体的行为是这样 Python 3.13 引入了实验性的 JIT 优化器,具体的细节可以参考我之前的文章 简单聊聊 Python 3.13 的 JIT 方案2,用户可以在构建的时候选择性的开启 ./configure —enable-experimental-jit —with-pydebug && make -j 用户在开启 JIT 的情况下,发现了一个非常奇怪的问题,执行 ./python -m ensurepip 会抛出异常 1subprocess.CalledProcessError: Command '['/home/jglass/Documents/cpython/python', '-W',...
实现 NES 中的一些笔记:nametable 的 mirror 计算
随便记录一些写 NES 中的笔记,这次写一下关于 nametable 的 mirror 计算。 正文NES 红白机的渲染过程相对来说比较复杂,为了讲今天的 mirror 计算,大致科普一下一些信息 首先我们屏幕显示的分辨率为 256240,然后我们最基本的渲染单元为 tile,一个 tile 为8个像素,意味着我们一个屏幕上有 3230 个 tile 我们屏幕上显示的背景图案是存放在 Pattern Table 中的,Pattern Table 映射到 CHR 中,可能是 RAM 也可能是 ROM,取决于 Mapper 的实现 我们为了在屏幕上显示合理的图案,我们需要一个 Index 去索引每个 Tile 的图案在 Pattern Table 中的位置。现在 3230 个 tile,我们需要 3230 个 8bit 的 Index,也就是 960 Byte 的数据。然后我们用剩下的 64 Byte 的数据来存放 Attribute Table,Attribute Table 用来存放每个 tile 的属性,比如颜色,是否翻转等等 通常来说,我们 NES 里面设计了四个...
SRE 日志:我的包去哪了?
这算是新开的一个系列,主要是记录一些 SRE 日常帮自己/帮人调试问题的经历。会完整的记录排查的过程。希望能帮上大家的忙 这篇是一个非常常见的问题,我的包去哪了? 开篇群里的的一个小伙伴提出了一个问题,他在用 dind (Docker in Docker)的时候,A 容器往 B 容器发送的 UDP 包,B 容器能收到,但是 A 容器收不到返回的值。 OK, 是个很经典的“我的包去哪了“的问题。 我们先来构建一下本地的环境看能不能复现 本机的 IP 为 192.168.0.239 我们单独隔离出一个 network ,CIDR 为 172.18.0.0/16 我们先跑一个 dind 容器,name 为 dind1, IP 为 172.18.0.2, 暴露 UDP 4000 端口至 Host 我们再跑一个 dind 容器,name 为 dind2, IP 为 172.18.0.3 dind1 中启动一个容器运行一段简单的 UDP 服务,监听 4000 端口,IP 为 172.17.0.2,暴露 UDP 4000 端口至 dind1 dind2 中启动一个容器,IP 为...
简单聊聊奥特曼中很有趣的细节
ヒーロが必要なんだよ,金城君。ヒーローが必要なんだ!
简单聊聊 CVE-2024-21626
本来这篇文章应该在初一凌晨发的,但是拖延癌晚期,所以到现在才发,得反思下了 背景众所周知,容器逃逸并不是什么令人稀奇的问题了(不被逃逸的容器才是稀奇),2月初,runc 社区正式公布了一个船新的逃逸 CVE,参见 https://github.com/opencontainers/runc/security/advisories/GHSA-xr7r-f8xq-vfvv,版本横跨 1.0 到 1.1.11 这个 CVE 的核心特性在于“可以通过镜像分发的方式,成本很低的进行逃逸” 我们先来复现一下这个问题 我自己的环境是这样 看这篇博客的同学可以参考下面方式进行环境准备, 按照自己的发行版确保安装了,Docker, libseccomp, golang 按照下面方式进行环境安装 1234567891011git clone https://github.com/opencontainers/runcgit checkout v1.1.0-rc.1makesudo rm -rf $(which runc)sudo make installsudo systemctl...
简单聊聊 Python 3.13 的 JIT 方案
Python 3.13 的 JIT 方案最终确定了,我觉得可以说又新又好。所以深夜水一篇水文,来聊聊这个 JIT 方案 这篇文章可能会有些枯燥,所以如果对此不感兴趣的同学可以直接 x 掉 基础知识在聊 Python 3.13 具体的实现之前,我们需要来了解下它所采用的 JIT 方案的基础知识 JIT 本身的定义我相信阅读这篇文章的同学已经非常了解了,所以此处不再赘述。JIT 核心分为两大块 代码的 profile,以确定热点路径,尽可能的减少 JIT 的 fallback 汇编代码的生成 本文主要会聊代码的生成部分 在此之前,Python 生态里一个 JIT 的实现,Pyston/Pypy,他们所采取的方案其实是和 LuaJIT 的方式类似,开发者手写汇编来完成代码的特化,然后依赖 DynASM 执行相关的代码 这种方式主要的缺陷在于 手写汇编带来的心智负担 对于平台的兼容性 为了给大家一个直观的感受,我给出一个我之前写过的汇编的例子来作为演示 首先,我需要实现的功能很简单,用 C 来描述应该是这样的 123456int main(int argc, char...
Per aspera, Ad astra
外星人一定很奇怪,本星际云本地泡银河系猎户悬臂边缘的太阳系第三行星的人类,怎么又在开始为他们庆祝行星绕行一圈开始忙碌了呢? 开篇如果要说要说今年最让我记忆犹新的瞬间,那么毫无疑问是今年8月,月初的某一天,我毫无征兆的突然情绪爆发,冲到窗口边打开窗户,试图从十八楼一跃而下。不过可能我没法有游戏里的主角这一样的光环,落地,转身,拍拍屁股走人。可能只是在繁华的街道上徒留一地碎肉。 所以,妹子不知道为啥发觉了我的异常,在我一只脚迈出窗外的时候,死命将我拉了回来。我从没想过她的力气会那么大,会那样的无畏的拉着我。 所以我有些闲暇坐在这,写下这篇文章。 生活从试图跳楼往前回溯,是连续几周的同一个噩梦,梦回到了自己被强奸的现场,每一次都是同样的真实。可能我想我的一些坚守的防线在不知不觉中被打破了吧。 如果说2023的关键词第一个是爱,那么第二个应该就是 tough 了 无数的噩梦,自我的怀疑,各种不如意的琐事,最喜爱的演员的离世,最惨的时候两周去了六次急诊缝了5针,打了三针,这一些 tough...
家庭 Homelab 升级计划: v2
人生嘛,Homelab 图个乐子
Python 3.12:一个被人忽略的史诗级版本
Python 3.12 已经发布了一段时间,所以写篇水文来聊一聊这个常常被人忽略的史诗级版本。 正文Python 3.12 绝对是一个史诗级版本,在我心目中,它对于 Python 的意义,大于 “async/await” 的 Python 3.5 和 “Type Hint” 的 Python 3.6 对于 Python 的意义。 或者我们可以这么说在未来数年的时间里,Python 后续的很多意义重大的变更,其都能上溯到 Python 3.12。 理解我这一个观点,我们来说一下 Python 的几大痛点: Python 的可调试性,可观测性问题。历史上 Python 中做 Cost 的消耗极大,同时没有足够的手段可以从旁路去观察 Python 的运行时行为 Python GIL 问题,这个老生长谈了,不多说 Python 的 C API/ABI 问题,之前暴露的 C API/ABI 通常和 CPython VM 实现细节耦合,导致跨版本兼容性会是一个问题 而这样一些问题,Python 3.12 上都有了极大的进步 PEP 669, GH-96143 极大提升了 Python...
开源可能没你想的那么难
去参与社区?难吗?其实不难,只是你想的很难,或者说难是你给自己找的借口 正文很多人觉得参与进开源社区很难,无外乎几个原因 觉得自己技术栈不符合 觉得没啥事可以做 觉得太难了 我自己对于这个观点表示不太认可,所以我从九月中旬开始,用了一个月时间,利用 incubator-opendal 做了一个实验,为什么会选择这个项目?原因以下几点 Rust 对于我来说是一门我非常不熟悉的语言,相当于我跨技术栈去做一些事情 我自己之前是做网关和容器相关的偏多,存储方面对于我来说不是在我的好球区 所以我想看一下,我自己作为 fresh man 能在这个社区里面做什么事 截止到今天,我整体的提交记录如下 整体的花费的时间接近34h 整体工作内容横跨了几个方面 多个 Service 的支持(MySQL/Sqlite/MongoDB) 拾掇拾掇了 CI,参与 Action 的重构 把整体 Layer 的文档覆盖了 把可观测性的部分做了不少改进 而截止到目前,还有很多工作需要去继续跟进,比如 基于 DTrace 的进程调试支持 可观测性的几个 Layer 的完善 Layer...