Casting out Primes: Bignum Arithmetic for Zero-Knowledge Proofs学习笔记

news2025/1/16 3:30:30

1. 引言

Polygon zero团队 Daniel Lubarov 和 Polygon zkEVM团队 Jordi Baylina 2022年10月联合发表的论文 《Casting out Primes: Bignum Arithmetic for Zero-Knowledge Proofs》。

受“casting out nines” 技术——做对9取模运算并提供概率性结果,启发,本论文核心思想为:

  • 对bignum运算的非确定方案

即:【详细参看Optimizations of zkEVM with Daniel and Jordi】
在这里插入图片描述
即,若某identity在moduli set M M M中每个 m i ∈ M m_i\in M miM均有:

  • f ( x ⃗ ) = 0 m o d    m i f(\vec{x})=0\mod m_i f(x )=0modmi

则有:

  • f ( x ⃗ ) = 0 m o d    lcm ( M ) f(\vec{x})=0\mod \text{lcm}(M) f(x )=0modlcm(M),其中 lcm ( M ) \text{lcm}(M) lcm(M)表示 M M M中的最小公倍数。

若已知 ∣ f ( x ⃗ ) ∣ < lcm ( M ) |f(\vec{x})|<\text{lcm}(M) f(x )<lcm(M),则有:

  • f ( x ⃗ ) = 0 f(\vec{x})=0 f(x )=0

1.1 相关约定

[ b ] [b] [b]表示集合: { 0 , ⋯   , b − 1 } \{0,\cdots,b-1\} {0,,b1},某bignum可表示为 n n n limbs in base b b b,即 [ b ] n [b]^n [b]n

[ b ] n [b]^n [b]n [ b n ] [b^n] [bn]之间具有canonical isomorphism:
σ b ( x ) = ∑ i = 0 n − 1 b i x i \sigma_b(x)=\sum_{i=0}^{n-1}b^ix_i σb(x)=i=0n1bixi

已知一组bignum x , y ∈ [ b ] n x,y\in [b]^n x,y[b]n,乘积 σ b ( x ) σ b ( y ) \sigma_b(x)\sigma_b(y) σb(x)σb(y)可表示为某函数 ( [ b ] n , [ b ] n ) → [ b 2 n ] ([b]^n,[b]^n)\rightarrow [b^{2n}] ([b]n,[b]n)[b2n],即:
π b ( x , y ) = ∑ i = 0 n − 1 ∑ j = 0 n − 1 b i + j x i y j \pi_b(x,y)=\sum_{i=0}^{n-1}\sum_{j=0}^{n-1}b^{i+j}x_iy_j πb(x,y)=i=0n1j=0n1bi+jxiyj

  • Partially reduced summations:
    某identity 对 m m m 取模,可表示为对每个系数取模,即:
    σ b m ( x ) = ∑ i = 0 n − 1 ( b i m o d    m ) x i \sigma_b^{m}(x)=\sum_{i=0}^{n-1}(b^i\mod m)x_i σbm(x)=i=0n1(bimodm)xi
    类似的,也有:
    π b ( x , y ) ( m ) = ∑ i = 0 n − 1 ∑ j = 0 n − 1 ( b i + j m o d    m ) x i y j \pi_b(x,y)^{(m)}=\sum_{i=0}^{n-1}\sum_{j=0}^{n-1}(b^{i+j}\mod m)x_iy_j πb(x,y)(m)=i=0n1j=0n1(bi+jmodm)xiyj
    注意其中: σ b ( x ) = σ b m ( x ) \sigma_b(x)=\sigma_b^{m}(x) σb(x)=σbm(x) 以及 π b ( x , y ) = π b ( x , y ) ( m ) \pi_b(x,y)=\pi_b(x,y)^{(m)} πb(x,y)=πb(x,y)(m)

从而可推导出如下定理1:

  • 已知 x ∈ [ b ] n x\in [b]^n x[b]n,有 σ b m ( x ) < n m b \sigma_b^{m}(x)<nmb σbm(x)<nmb
  • 已知 x , y ∈ [ b ] n x,y\in [b]^n x,y[b]n,有 π b ( x , y ) ( m ) < n 2 m b 2 \pi_b(x,y)^{(m)}<n^2mb^2 πb(x,y)(m)<n2mb2

在本文中,已知 x ∈ [ b ] n x\in [b]^n x[b]n,则 x x x σ b ( x ) \sigma_b(x) σb(x)这二者表示等价。

2. Widening multiplication

首先考虑2个bignum的乘法运算, x , y ∈ [ b ] n x,y\in [b]^n x,y[b]n

  • 不同于对 x y xy xy进行确定性运算,而是将其乘积 z ∈ [ b ] 2 n z\in[b]^{2n} z[b]2n作为witness,转为检查identity x y − z xy-z xyz
  • 不同于直接验证该identity,转为检查其在一组模 M = { m 0 , ⋯   , m k − 1 } M=\{m_0,\cdots, m_{k-1}\} M={m0,,mk1}下均成立。
    假设对于每个 m i m_i mi x y = z m o d    m i xy=z\mod m_i xy=zmodmi均成立,或者等价为 m i ∣ ( x y − z ) m_i | (xy-z) mi(xyz)。则有 lcm ( M ) ∣ ( x y − z ) \text{lcm}(M) | (xy-z) lcm(M)(xyz),其中 lcm \text{lcm} lcm表示the least common multiple function。
    由于 x y < b 2 n xy<b^{2n} xy<b2n z < b 2 n z<b^{2n} z<b2n,使得 ∣ x y − z ∣ < b 2 n |xy-z|<b^{2n} xyz<b2n
    若选择的模集合 M M M满足 lcm ( M ) ≥ b 2 n \text{lcm}(M) \geq b^{2n} lcm(M)b2n,则 ∣ x y − z ∣ < lcm ( M ) |xy-z|<\text{lcm}(M) xyz<lcm(M),因此 x y − z = 0 xy-z=0 xyz=0 lcm ( M ) ∣ ( x y − z ) \text{lcm}(M) | (xy-z) lcm(M)(xyz)成立的唯一解,从而有 x y = z xy=z xy=z

Remark 1:

  • M M M选择pairwise coprime sets是很自然的选择,因其具有 lcm ( M ) = ∏ i = 0 k − 1 m i \text{lcm}(M)=\prod_{i=0}^{k-1}m_i lcm(M)=i=0k1mi属性。

2.1 Congruence mod m i m_i mi

仍需检查 x y = z m o d    m i xy=z \mod m_i xy=zmodmi,更准确来说,是仍需检查 π b ( x , y ) = σ b ( z ) m o d    m i \pi_b(x,y)=\sigma_b(z)\mod m_i πb(x,y)=σb(z)modmi。等式两边同时reduce,将该检查reduce为:
π b ( x , y ) ( m i ) = σ b m i ( z ) m o d    m i \pi_b(x,y)^{(m_i)}=\sigma_b^{m_i}(z)\mod m_i πb(x,y)(mi)=σbmi(z)modmi
不同于对等式两边进行确定性reduce,引入witness s ∈ Z s\in \mathbb{Z} sZ使得:
π b ( x , y ) ( m i ) − σ b m i ( z ) = s m i \begin{equation} \pi_b(x,y)^{(m_i)}-\sigma_b^{m_i}(z)=sm_i \end{equation} πb(x,y)(mi)σbmi(z)=smi

根据定理1,可推导出定理2—— ∣ s ∣ |s| s的上限值进行了约定:

  • s s s为对方程式(1)有效解,则有 ∣ s ∣ < n 2 b 2 |s|<n^2b^2 s<n2b2

2.2 避免wrap-around

基于素数域进行运算的计算模型,无法对上述方程式(1)进行直接检查,我们仅能检查其 m o d    p \mod p modp是否成立,或等价为,存在某 t t t,使得:
π b ( x , y ) ( m i ) − σ b m i ( z ) − s m i = t p \pi_b(x,y)^{(m_i)}-\sigma_b^{m_i}(z)-sm_i=tp πb(x,y)(mi)σbmi(z)smi=tp

为避免因包含wrap-around引入的无效解,必须对上述等式左侧进行限制,使得 t = 0 t=0 t=0为唯一可能解,即必须确保:
∣ π b ( x , y ) ( m i ) − σ b m i ( z ) − s m i ∣ < p |\pi_b(x,y)^{(m_i)}-\sigma_b^{m_i}(z)-sm_i|<p πb(x,y)(mi)σbmi(z)smi<p

针对以上不等式,并利用 π b ( x , y ) ( m i ) \pi_b(x,y)^{(m_i)} πb(x,y)(mi) − σ b m i ( z ) -\sigma_b^{m_i}(z) σbmi(z)为符号相反的2个数的事实,足以确保:
max ⁡ { π b ( x , y ) ( m i ) , σ b m i ( z ) } + ∣ s m i ∣ < p \max\{\pi_b(x,y)^{(m_i)},\sigma_b^{m_i}(z)\}+|sm_i|<p max{πb(x,y)(mi),σbmi(z)}+smi<p

或应用以上定理1和定理2,有:

  • 2 n 2 m i b 2 ≤ p 2n^2m_ib^2\leq p 2n2mib2p

从而可选择一组能满足该条件的参数。

Remark 2:

  • M M M中包含 p p p自身是很自然的选择,因为,这样可“原生”检查an identity m o d    p \mod p modp。显然 p p p自身并不满足上面 2 n 2 m i b 2 ≤ p 2n^2m_ib^2\leq p 2n2mib2p的限定,因此,当检查某identity m o d    p \mod p modp时,wrap-around并不是an issue。

3. Modular multiplication

对某固定模 q < b n q<b^n q<bn进行modular multiplication计算,即为:

  • x , y ∈ [ b ] n x,y\in [b]^n x,y[b]n为输入, z ∈ [ b ] n z\in [b]^n z[b]n为witness,检查 x y = z m o d    q xy=z\mod q xy=zmodq。(不同于上面的检查 x y = z xy=z xy=z

为此,引入witness r r r,使得 π b ( x , y ) − σ b ( z ) = r q \pi_b(x,y)-\sigma_b(z)=rq πb(x,y)σb(z)=rq。不过,可将该问题进一步reduce为:

  • 存在witness r r r,使得 π b ( q ) ( x , y ) − σ b q ( z ) = r q \pi_b^{(q)}(x,y)-\sigma_b^{q}(z)=rq πb(q)(x,y)σbq(z)=rq

根据定理1,意味着 ∣ r ∣ < n 2 b 2 |r|<n^2b^2 r<n2b2——可引入range check来强化该限制。

跟之前的方案类似,引入模集合 M M M,根据定理1和不等式,有:

  • ∣ π b ( x , y ) ( q ) − σ b ( q ) ( z ) − r q ∣ < 2 n 2 q b 2 |\pi_b(x,y)^{(q)}-\sigma_b^{(q)}(z)-rq|<2n^2qb^2 πb(x,y)(q)σb(q)(z)rq<2n2qb2

因此,可选择 M M M使得 lcm ( M ) ≥ 2 n 2 q b 2 \text{lcm}(M)\geq 2n^2qb^2 lcm(M)2n2qb2。为此,若不执行partial reduction m o d    q \mod q modq,我们需要大一点的 lcm ( M ) \text{lcm}(M) lcm(M)

3.1 Congruence mod m i m_i mi

small-moduli checks形式为:

  • π b ( q ) ( x , y ) − σ b ( q ) ( z ) = r q m o d    m i \pi_b^{(q)}(x,y)-\sigma_b^{(q)}(z)=rq \mod m_i πb(q)(x,y)σb(q)(z)=rqmodmi

对所有的常量进行partial reductions m o d    m i \mod m_i modmi,从而有:

  • π b ( q ) ( m i ) ( x , y ) − σ b ( q ) ( m i ) ( z ) = r ( q m o d    m i ) m o d    m i \pi_b^{(q)(m_i)}(x,y)-\sigma_b^{(q)(m_i)}(z)=r(q\mod m_i) \mod m_i πb(q)(mi)(x,y)σb(q)(mi)(z)=r(qmodmi)modmi

其中 ( q ) ( m i ) (q)(m_i) (q)(mi)表示为一系列的partial reductions,即:

  • σ b ( q ) ( m i ) = ∑ i = 0 n − 1 ( ( b i m o d    q ) m o d    m i ) x i \sigma_b^{(q)(m_i)}=\sum_{i=0}^{n-1}((b^i\mod q)\mod m_i)x_i σb(q)(mi)=i=0n1((bimodq)modmi)xi
  • π b ( q ) ( m i ) = ∑ i = 0 n − 1 ∑ j = 0 n − 1 ( ( b i + j m o d    q ) m o d    m i ) x i y j \pi_b^{(q)(m_i)}=\sum_{i=0}^{n-1}\sum_{j=0}^{n-1}((b^{i+j}\mod q)\mod m_i)x_iy_j πb(q)(mi)=i=0n1j=0n1((bi+jmodq)modmi)xiyj

引入witness s s s,使得:

  • π b ( q ) ( m i ) ( x , y ) − σ b ( q ) ( m i ) ( z ) − r ( q m o d    m i ) = s m i \pi_b^{(q)(m_i)}(x,y)-\sigma_b^{(q)(m_i)}(z)-r(q\mod m_i)=sm_i πb(q)(mi)(x,y)σb(q)(mi)(z)r(qmodmi)=smi

成立。根据定理1,意味着 ∣ s ∣ < 2 n 2 b 2 |s|<2n^2b^2 s<2n2b2——可借助range check来强化该限制。

3.2 避免wrap-around

与2.2节思路类似,必须选择特定的参数,使得当对以上约束进行 m o d    p \mod p modp check时,wrap-around不可能发生。采用类似的分析可知,要求:

  • 4 n 2 m i b 2 ≤ p 4n^2m_ib^2\leq p 4n2mib2p

3.3 举个例子

假设“原生”field为 F p \mathbb{F}_p Fp,其中 p = 2 64 − 2 32 + 1 p=2^{64}-2^{32}+1 p=264232+1。当需要基于secp256k1 base field F q \mathbb{F}_q Fq(其中 q = 2 256 − 2 32 − 2 9 − 2 8 − 2 7 − 2 6 − 2 4 − 1 q=2^{256}-2^{32}-2^9-2^8-2^7-2^6-2^4-1 q=225623229282726241)进行乘法运算时,且 n = 16 , b = 2 16 n=16,b=2^{16} n=16b=216
为避免wrap-around,要求每个 m i m_i mi p p p自身除外——根据Remark 2)满足:

  • m i ≤ p 4 n 2 b 2 m_i\leq \frac{p}{4n^2b^2} mi4n2b2p

对其向下取整为 4194303 4194303 4194303,即约为 2 22 2^{22} 222

此外, M M M还需满足 lcm ( M ) ≥ 2 n 2 q b 2 \text{lcm}(M)\geq 2n^2qb^2 lcm(M)2n2qb2——约为 2 297 2^{297} 2297
满足以上条件的 M M M可为:

  • M = { p , 4194272 , 4194273 , 4194275 , 4294277 , 4294281 , 4194283 , 4194287 , 4194289 , 4194293 , 4194299 , 419430 } M=\{p,4194272,4194273,4194275,4294277,4294281,4194283,4194287, 4194289, 4194293, 4194299, 419430\} M={p,4194272,4194273,4194275,4294277,4294281,4194283,4194287,4194289,4194293,4194299,419430}

为pairwise coprime set,满足以上约束。

4. Probabilistic method

不同于上面的固定模集合 M M M,可将其从某更大的pariwise coprime set M \mathbb{M} M中随机选择subset。
已知bound ∣ x y − z ∣ < b 2 n |xy-z|<b^{2n} xyz<b2n,可argue that M \mathbb{M} M中仅有小部分可整除 x y − z xy-z xyz,因此若 x y ≠ z xy\neq z xy=z,则不可能对所有 m ∈ M m\in M mM该identity都成立。
取决于具体的安全参数,可能可采用比之前方案中相对更小的 M M M集合。

4.1 举个例子

M \mathbb{M} M为pairwise coprime subset of [ 2 15 , ⋯   , 2 16 ] [2^{15},\cdots,2^{16}] [215,,216]——可发现该集合内可包含3802个整数。
x y xy xy z z z均不超过512 bits,则 x y − z xy-z xyz最多可整除34个 m i ∈ M m_i\in\mathbb{M} miM,任意subset size为35或更多时,相应的product将超过 2 512 2^{512} 2512。因此,若 x y ≠ z xy\neq z xy=z,则对于随机的 m i ∈ M m_i\in \mathbb{M} miM x y = z m o d    m i xy=z\mod m_i xy=zmodmi成立的概率最高为 32 / 3069 32/3069 32/3069

若独立sample每个 m i ∈ M m_i\in \mathbb{M} miM,则可能存在重复取值的情况,若做20次sample,提供128-bit securit: ( 32 / 3069 ) 20 < 2 − 128 (32/3069)^{20}<2^{-128} (32/3069)20<2128。若整个sample过程中避免重复情况,则19次sample就足够了,因为:
∏ i = 0 18 ( 34 − i 3069 − i ) < 2 − 128 \prod_{i=0}^{18}(\frac{34-i}{3069-i})<2^{-128} i=018(3069i34i)<2128

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

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

相关文章

RocketMQ 的存储模型

文章目录1.整体概览2.数据文件3.消费文件4.索引文件1.整体概览 Producer &#xff1a;消息发布的角色&#xff0c;Producer 通过 MQ 的负载均衡模块选择相应的 Broker 集群队列进行消息投递&#xff0c;投递的过程支持快速失败并且低延迟。 Consumer &#xff1a;消息消费的角…

如何应用人工智能和机器学习来预测消费者的行为

应用AI和机器学习来预测消费者行为 在这篇文章中&#xff0c;我们将学习和分析一般的消费者行为。我们还将了解人工智能是如何帮助发现有价值的见解的&#xff0c;从而使公司做出正确的决定&#xff0c;以实现提供更好的价值和创造更好的收入的愿景。 我们还将通过一个案例进…

6.2 参数传递

文章目录传值参数指针形参传引用参数使用引用避免拷贝使用引用形参返回额外信息const形参和实参指针或引用形参与const尽量使用常量引用数组形参使用标记指定数组长度使用标准库规范显式传递一个数组的长度数组形参和const数组引用形参传递多维数组main&#xff1a;处理命令行选…

142.环形链表II

给定一个链表的头节点 head &#xff0c;返回链表开始入环的第一个节点。 如果链表无环&#xff0c;则返回 null。 如果链表中有某个节点&#xff0c;可以通过连续跟踪 next 指针再次到达&#xff0c;则链表中存在环。 为了表示给定链表中的环&#xff0c;评测系统内部使用整数…

java开发社区活动预约系统

简介 本系统主要是社区活动预约系统网站&#xff0c;社区管理员可以发布活动&#xff0c;社区居民和游客均可进行活动预约&#xff0c;管理员后台审核预约是否通过&#xff0c;居民可以填写活动感受&#xff0c;管理员查看感受后可以进行反馈。居民最多取消三次预约&#xff0…

我用Python做了个动图生成器,把一千个MM生成了GIF设置桌面,只为每天愉悦心情

文章目录序言代码实战序言 现在的年轻人都开始每天保温杯里泡枸杞&#xff0c;这怎么能行呢&#xff1f; 想要每天过的好&#xff0c;美女必然少不了&#xff0c;每天看美女&#xff0c;只为了愉悦心情&#xff0c;心情好了&#xff0c;才长寿。 于是怀揣着愉悦心情的想法&am…

【leetcode】剑指offer1

&#x1f308;1.Pow(x,n) -100.0 < x < 100.0-2^31 < n < 2^31-1n 是一个整数-10^4 < x^n < 10^4思路分析&#xff1a; 暴力求解直接一个for循环n个x相乘解决&#xff0c;但是你拿那代码怎么好意思拿高薪&#xff1f; 所以而且那个的时间复杂度是O(n),效率并…

[阿里云] 10分钟带你玩转阿里云ECS和云盘 (大数据上云必备)

前言 由于准备做一些离线计算和实时计算的模拟, 发现某些教程内的阿里云还挺好用的, 在这里把相关的经验分享给大家. 简单的心路历程: 起先笔者搭建了一套本地集群. 但是后来发现, 因为没用网络IP的反穿, 本地的集群的网络访问非常不便. 其次, 集群的启停, 网络和磁盘管理都非…

缓存原理的学习

在如今这个微服务分布式的大环境下,集群分布式部署 几乎 已经是我们每个人都熟知的了。 缓存也一样&#xff0c;对我们来说 &#xff0c;如果只是一个单体应用 &#xff0c; 那只要 有本地缓存就足以了&#xff0c;但是倘若分布式部署了很多台机器上&#xff0c;那我们该如何缓…

软考-操作系统

【考点梳理】 【进程管理】 考点1、进程的状态&#xff08;★★&#xff09; 【考法分析】 本考点主要考查形式主要是根据图示判断相关状态位置或状态变迁条件。 【要点分析】 操作系统三态模型如下图所示&#xff1a;操作系统五态模型&#xff1a;【备考点拨】 掌握操作…

vue2.0和vue3.0创建项目

由于vue项目依赖于nodejs&#xff0c;所以需要先安装它。没有nodejs去官网下载。 npm install --global vue-cli 国内npm网站很慢&#xff0c;可以使用淘宝镜像 npm install --registryhttps://registry.npm.taobao.org vue2.0创建项目&#xff1a; 进入到自己需要创建项目…

SAP给微信推送消息

导语&#xff1a;最近领导下发指令&#xff0c;要求研究SAP与微信&#xff0c;企业微信&#xff0c;钉钉&#xff0c;邮件推送消息的平台&#xff0c;类似于采购订单审批之后&#xff0c;可以通过以上软件给用户发消息&#xff0c;我认领了微信的部分。 整个研究过程是很痛苦的…

华为静态NAT、动态NAT、PAT端口复用

一、网络环境及TOP 1.1 R1 相当于内网的一台PC&#xff0c; IP&#xff1a;192.168.1.10 网关为 192.168.1.254 [R1]ip route-static 0.0.0.0 0 192.168.1.254 # R1配置默认路由&#xff08;网关&#xff09; 1.2 R2为出口路由器&#xff0c;分别连接内网R1及外网R3 1&…

7. 整数反转

题目链接&#xff1a;力扣 解题思路&#xff1a; 题目要求中有一句话&#xff1a;假设环境不允许存储 64 位整数&#xff08;有符号或无符号&#xff09;。 也就是说不能使用long类型来判断是否int溢出&#xff0c;只能使用int类型进行运算 首先对于一个整数的翻转比较简单…

学openCV,不会数字图像系统可不行

来源&#xff1a;投稿 作者&#xff1a;小灰灰 编辑&#xff1a;学姐 前言 在光照的情况下&#xff0c;通过成像系统将大自然中的物体拍摄出来&#xff0c;成像系统手机自带有&#xff0c;这里面我们关心的是分辨率&#xff0c;成像系统显示的点数越多&#xff0c;阵列越大&am…

HCIA静态试验(12.30-31复习)

目标实现&#xff1a; 2、首先进行子网划分 基于192.168.1.0 24划分 ‘一共7个路由器需要7个网段还有7个主干网 192.168.1.0/24 ----用于骨干 192.168.1.32/27 ----R1环回 192.168.1.32/28 192.168.1.48/28 192.168.1.64/27 --- R2环回 192.168.1.64/28 192.168.1.80/28 …

Java之网络相关概念

寒假又开始更新java了&#xff0c;之后更新的是b站教程韩顺平老师的课&#xff0c;编译器我从idea换成eclipse&#xff08;因为蓝桥杯只有eclipse&#xff0c;要先熟悉&#xff09; 1.网络相关概念 网络通信 网络 ip地址 1.简单来说ip地址是每一台主机的标识 类似于我们现…

Vue 疑难扎症(一)有时候取不到Vue对象中值怎么办?对象值发生改变了但是页面没有刷新怎么办?

目录 有时候取不到对象中值怎么办&#xff1f; 问题截图 问题代码 问题分析 情况1 情况2 情况3 问题解决 对象值发生改变了但是页面没有刷新怎么办&#xff1f; 为什么&#xff1f; 常见错误写法&#xff1a; 怎么办&#xff1f; 有时候取不到对象中值怎么办&…

Node.js--》如何在Node.js中使用中间件,看这一篇就足够了

目录 中间件 中间件函数使用 中间件的作用 中间件分类 使用中间件的注意事项 编写接口 跨域问题及其解决方案 中间件 中间件特指业务流程的中间处理环节。当一个请求到达 Express 的服务器之后&#xff0c;可以连续调用多个中间件&#xff0c;从而对这次请求进行预处理…

【网络排查】用于接口不通,mysql,kafka等数据库介质连不上的排查

这篇文章记录生产实践中遇到的网络不通的例子 文章目录前言1. 网络协议1.1 应用层找到有问题的服务端 IP总结前言 接口调用不同了了怎么办&#xff1f; 就找接口服务提供方&#xff0c;肯定是提供方的问题的&#xff0c;跟调用方有啥关系~ kafka&#xff0c;mysql等数据库介质…