2024 年了,是 Gevent 还是选择 asyncio Part 1?
Gevent 还是 asyncio 这一直是个经典的问题,在这里我们直接用数据来帮助大家做一下决策
开篇Lin Wei 老师珠玉在前
给出了 asyncio 和 Gevnet 的极限性能。 在这里我们看到了 asyncio 配合 uvloop 基本上是 Gevent 的 double 了
那么在在 Web 框架下是否如此呢?
我们来做一下实验吧
首先说一下负载机器的配置,这里我选用了 Azure 上 D8as_v5 的机器,该机器配置如下:
8Core32G 的配置
底座硬件基于 EPYC 7763 系列处理器
共计4个节点,分配给 Django/Flast/FastAPI/Starlette 四个不同的框架
我们压测框架选择 locust,同样基于 Kuberntes 集群,因为我账户的 D8as_v5 机器的 Quota 不太够,所以压测框架我们选了不同机器的混合部署
4个 D8as_v5,共计 32 Core 算力
4个 D8as_v3,共计 32 Core 算力
4个 D4as_v2,共计 16 Core 算力
我们测试的主要目的是模拟在生产环境下的吞吐,所以我选择 ...
In 2024, Gevent or asyncio? Part 1
The choice between Gevent and asyncio has always been a classic question. Here, we’ll use data to help you make a decision.
IntroductionProfessor Lin Wei has set a high standard:
This graph shows the extreme performance of asyncio and Gevent. We can see that asyncio with uvloop is basically double the performance of Gevent.
But is this the case under web frameworks?
Let’s conduct an experiment.
First, let’s talk about the configuration of the load machine. I chose a D8as_v5 machine on Azure wi ...
Debug 日志:CPython GH-121528
Debug 日志系列第二篇,CPython 的 GH-121528,也是很有趣的调试和讨论过程,写出来希望帮助大家
太长不看的版:Python 3.13 Beta 版本中,因为 PEP 683 的实现+周边的改动,导致低版本下编译的一些扩展无法在 Python 3.13 中运行
开篇7月9日的时候,PyO3 社区提出了一个 Bug , 编号为 GH-1215281。这个 Bug 可以做这样的表示
假设我们有一个 C 扩展文件
12345678910111213141516171819202122232425262728#include <Python.h>static PyObject *foo_bar(PyObject *self, PyObject *args){ Py_INCREF(PyExc_TypeError); PyErr_SetString(PyExc_TypeError, "foo"); return NULL;}static PyMethodDef foomethods[] = { {" ...
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 里面设计了四个 namet ...
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 为 172.17.0 ...
简单聊聊奥特曼中很有趣的细节
ヒーロが必要なんだよ,金城君。ヒーローが必要なんだ!
简单聊聊 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 restart ...
简单聊聊 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 *argv[] ...
Per aspera, Ad astra
外星人一定很奇怪,本星际云本地泡银河系猎户悬臂边缘的太阳系第三行星的人类,怎么又在开始为他们庆祝行星绕行一圈开始忙碌了呢?
开篇如果要说要说今年最让我记忆犹新的瞬间,那么毫无疑问是今年8月,月初的某一天,我毫无征兆的突然情绪爆发,冲到窗口边打开窗户,试图从十八楼一跃而下。不过可能我没法有游戏里的主角这一样的光环,落地,转身,拍拍屁股走人。可能只是在繁华的街道上徒留一地碎肉。
所以,妹子不知道为啥发觉了我的异常,在我一只脚迈出窗外的时候,死命将我拉了回来。我从没想过她的力气会那么大,会那样的无畏的拉着我。
所以我有些闲暇坐在这,写下这篇文章。
生活从试图跳楼往前回溯,是连续几周的同一个噩梦,梦回到了自己被强奸的现场,每一次都是同样的真实。可能我想我的一些坚守的防线在不知不觉中被打破了吧。
如果说2023的关键词第一个是爱,那么第二个应该就是 tough 了
无数的噩梦,自我的怀疑,各种不如意的琐事,最喜爱的演员的离世,最惨的时候两周去了六次急诊缝了5针,打了三针,这一些 tough ,负面的词一直环绕着我。某种意义上今年是我内心猛兽更被释放的一年。我某种意义上一度陷落十来岁那种暴戾的状 ...