当前位置: 首页 > news >正文

Layer2区块链扩容方案(1)——总述

写在前面

这篇文章作为一个简单介绍,很多技术只是大致提及或者引用,之后会在详细学习后逐项解释。

补充知识

在了解扩容方案之前,我们最好了解一些相关的知识概念

EVM

“EVM” 是“Ethereum Virtual Machine”(以太坊虚拟机)的缩写。

EVM是什么?

  1. EVM是由成千上万台计算机(节点)组成的一台云计算机,每台计算机上运行一个软件,该软件基本上只是计算智能合约交易的输出

  2. EVM这台虚拟机一般用来处理Defi交易(EVM是专门为了处理Defi交易设计的),可以读取编译过的智能合约。如果两条链均适用EVM,那么他们之间进行的资产转移和交互就比较方便,而这种转移的合约一般使用的是Solidity语言编写的(cardona和solana是用rust语言编写的,这是区块链开发的另一种常见语言)

  3. EVM和正常的计算机一样,读的是ByteCode(0 1组成的机器码);开发人员一般使用的Solidity书写智能合约,这种合约需要通过编译器(比如常见remix)编译后才能被EVM读懂。除了这两种语言,再讲一下Opcode(操作码),类似于CPU读的汇编代码,操作码是一种开发人员不写、EVM不读的代码;但是我们可以借助这个概念理解汽油费的计算方式,常说的汽油费就是 每个操作*该操作所需的费用最后求和得到的。

EVM的运行

  1. EVM处理交易时,每个交易依次运行,不会同时执行

  2. 完成一笔交易,称作EVM的状态被更新了

  3. EVM持有状态与数据集合,交易前和交易后的状态都被记录(可以借此实现回滚),而这些交易的列表组成了区块链

PoS权益证明

关于Pos的一些内容,我们在以太坊的文章中谈到过,这里简单的提一下。PoS,即Proof of Staking通常指使用代币质押来获得出块权的方案。

运行流程

  1. 区块提议:在 PoS 网络中,验证者(或烘焙者、出块者)会在获得区块生成权利时,提议一个新区块。这个过程通常是随机的,系统会根据验证者的质押数量、网络的共识算法等因素来确定哪个验证者可以提议一个新区块。

  2. 区块验证:提议的区块需要经过其他验证者的验证,以确保区块中的交易和数据是有效的,并符合网络协议的规则。这一步骤是为了防止恶意行为和保证区块的正确性。

  3. 区块确认:经过验证的区块会被添加到区块链中,成为新区块链的一部分。验证者会根据网络的共识规则获得一定的奖励,作为他们参与区块生成和验证的回报。

  4. 奖励发放:生成和验证区块的验证者会收到区块奖励,这通常包括新生成的代币和交易手续费。

优势

  1. 在PoS中,质押一定代币的节点才有出块权(或者说是验证交易的权力),这样使得能源得到节约以及使得区块链被破坏的风险降低(本质上是增加了造假者的代价)

  2. PoS实现了“No one runs with no reward”,使得大家参与区块链的成本降低(不会无缘无故的浪费电力)

  3. 使得去中心化程度加深,一定程度上降低了矿场矿池对于算力垄断而达到的危害区块链的风险(相交于PoW而言)

选择验证者(矿工)的规则

  1. 往往是质押金额多的节点更优先得到出块权

  2. 同时,引入了随机数选择器的方法

质押者的风险与奖励

风险

  1. 质押的Staking中的代币在质押期无法参与交易

  2. 对于没有审核交易经验的人,往往需要雇佣技术人员来验证,这就需要承担验证错误带来的质押金丢失的风险(这是疏忽、和恶意节点的故意破坏动机不同),以及支付一定数额的佣金

  3. 不良行为一旦被发现,就会扣除所有押金

  4. 验证者的奖励发放有一定延时:

    1. 区块生成时:验证者在成功生成一个新区块后,通常会获得该区块的奖励。这包括区块奖励(通常是新生成的代币)以及交易手续费。

    2. 奖励周期:在一些PoS系统中,奖励可能不是即时发放的,而是在一定的奖励周期后集中发放。例如,奖励可能会按照预定的时间间隔(如每周、每月)进行发放。

    3. 结算期:某些PoS网络还可能设置一个结算期或延迟期,以确保奖励的准确性和避免潜在的欺诈行为。在此期间,奖励会暂时被锁定,直到结算完成。

奖励

下面举的是常见代币的方式,至于奖励的细节可以看一下以太坊的文章

  1. Tezos代币:6%(每年) 实际收益大约4.6%

  2. Cardano代币:4-5%(每年)

  3. Algo代币:8-10%(每年)

  4. Eth:4-7%(每年)

缺点

没有原始资产(coin)的节点可能无法参与

总述

区块链扩容受到 Vitalik 提出的不可能三角的限制,不可能三角是指区块链系统设计无法同时兼顾可扩展性,去中心化和安全性,三者只能取其二。这是一个很让人失望的结论,但我们必须知道,一切事物都有自己的边界,公链不应该做所有的事情,公链应该做它该做的事情:“公链是以最高效率达成共识的工具,能够以最低成本来构建信任”。作为共识的工具,信任的引擎,公链不应该为了可扩展性放弃去中心化与安全性。

拓展的常见思路(方案)

方案一:拓展基础层(Layer1)

方案二:将工作外包给新层(Layer2)

下面是详细的拓展层表格信息:

Layer内容
layer 2:链下扩展可编程应用层
堆栈脚本 算法 智能合约合约层
layer 1:链上扩展分配机制 发行机制激励层
PoA Raft PoW PoS共识层
P2P网络 传播机制 验证机制网络层
区块数据 链式结构 时间戳哈希函数 Merkle树 非对称加密数据层
layer0:第0层OSI模型中传输层与网络层

在底层区块链( Layer1 )上构建一个扩展层( Layer2 ), Layer1 来保证安全和去中心化,绝对可靠、可信;它能做到全球共识,并作为“加密法院”,通过智能合约设计的规则进行仲裁,以经济激励的形式将信任传递到 Layer2 上,而 Layer2 追求极致的性能,它只能做到局部共识,但是能够满足各类商业场景的需求。

这篇文章要简要介绍的是Layer2的拓展方案

Layer2方案

很喜欢有人对Layer2的一个例比:Layer2的拓展方案就像是公路上的车,客车、货车、轿车、摩托车都可以运行,都有发动机这一机动车的特性;但是,针对特定的运输任务,往往只选择某一种特殊的车辆,比如运送大型货物用货车、单人驾驶一般使用轿车和摩托车......

这就像Layer2的拓展方案,常见的Layer2拓展方案有以下五种:Rollup(打包)、sidechain(副链)、Plasma(子链)、channel(交易合并),下面我将逐条介绍。

Layer2的拓展,不是通过代码直接影响主链的状态,而是允许网络通过他们拓展外部因素或工具

Rollup

rollup很形象的一种解释就是“打包”,比如你想发送几封信给到同一个地点,往往可以将这几封信打包到一个大信封里面,而不是分别发出,这和Rollup的原理不谋而合;再比如为了解决一道填空题,它可能有很多步骤和过程,但是这些都在演草纸上进行,只是将最终的答案写在答题卡上。Rollup是在以太坊之外执行交易的方案,之后将交易的最终数据发布到主链上

也就是,将一系列交易汇总起来,最终以一个数据的形式汇总到区块链上。

Rollup总述

  1. Rollup 本质上是一条独立的区块链

  2. 和以太坊一样,Rollup 协议也使用 “虚拟机” 来执行智能合约代码。Rollup 的虚拟机独立于以太坊自己的虚拟机(EVM)运行,但是由以太坊上的智能合约管理;这种联系可以让 Rollup 和以太坊之间进行通信。

  3. Rollup 负责执行事务并处理数据,以太坊负责接收并存储结果

  4. 不同于以太坊的区块是由多数节点认可来实现其合法性的,监控 Rollup 状态的一方可以将 “断言” 发送至以太坊,来说明交易是如何处理的;以太坊将决定是否接受这个断言,无论这个断言是否获得了 Rollup 上多数参与方的支持在 Rollup 上,实际只有一方负责处理交易和生成区块,这样的出块方式具有中心化的特性

ZkRollup

zkRollup就是基于零知识证明的二层扩容方案(layer2)zkRollup的原理一句话就可以讲清楚:链下进行复杂的计算和证明的生成,链上进行证明的校验并存储部分数据保证数据可用性。zkRollup数据可用性可以让任何人都能根据链上存储的交易数据,还原出账户的全局状态,从而消除由于数据可用性带来的安全风险。

工作原理

zkRollup在链下利用Merkle tree存储账户状态,由Operator收集用户的交易,交易收集完成后Operator会执行每个交易(校验余额,校验nonce,校验签名,执行状态转换),当交易执行完成后会产生一个新的Merkle tree Root,为了证明链下状态转移是正确的,Operator会在交易执行完成后生成一个零知识证明的proof

下图表示Operator工作过程,黄色的表示用户发送的交易,绿色的表示Operator中维护的merkle treeOperator执行交易后本地的merkle tree root会由prev state root转换成post state root,图中蓝色的表示Operator生成证明账户状态转移有效的零知识证明。

img

Operatorprev state rootpost state root,交易数据和proof证明提交至链上合约,合约校验proof通过后会将来新的状态写入到链上,合约不需要单独校验每笔交易的合法性,只需要校验proof是否有效,降低了链上gas消耗,其中交易数据是存储在较便宜的位置CALLDATA上。链下每一次的状态转变都需要提供零知识证明,由主链上的合约进行验证,只有验证通过才能更改状态。即每一次状态转变都严格依赖密码学证明。

zkRollup生成的证明大小(很小),验证时间(很快基本上是常数),不会随着交易数量的增长而变大,所以zkRollup可以极大地提高TPS。影响zkRollup链上性能的只有链上CALLDATA存储数据的成本,随着以太坊Istanbul升级,CALLDATA使用成本降为原来的1/4zkRollup的性能则获得4倍提升,TPS可达到近2000左右。

img

上链的数据中prve state rootpost state rootproof基本上是不会随着交易增长变化的,只有上图中黄色交易部分会随着交易增长变大,所以为了能在一个区块链中容纳更多的交易,需要对上链的交易进行压缩。zkRollup使用merkle tree来记录地址,这样地址就可以表示成merkle tree的索引值,地址数据的大小就从原本的20 bytes减少到3 bytes,在以太坊上金额用32个字节256位的大整型来表示,这里压缩到6个字节,货币最小单位从wei变成Mwei=10^6 wei,手续费压缩到1个字节,nonce压缩到2个字节,nonce的范围0~65535,也就是说一个账户最多可以发送65535笔交易,交易的签名直接删除了,不出现交易中,因为每笔交易的合法性在链下都通过零知识证明的电路约束校验过了。

(关于工作原理的简要介绍来自登链社区)

OptimisticRollup

发展历史

增强比特币可扩展性的最早举措之一是侧链。侧链是与父链共同运行的区块链,但具备不同的特点:出块时间更短、区块大小更大、智能合约的表达性更强等。然而,普通的侧链有个致命的缺点:如果一条侧链上的绝大多数矿工/验证者都是不诚实的,用户资金就会被盗。这些年来,有很多技术都在尝试增强侧链的安全性,来保证在绝大多数参与者不诚实的情况下,用户资金也不会被盗(这被称为信任最小化的双向锚定)。更早一点的例子有合并挖矿(merged mining)、影子链(shadow chain),之后又出现了 Plasma 和 ZK rollup。有趣的是,在 ORU 出现之前,一个类似的方案是分片机制下的延迟状态执行(我们很快会讲到这点!)。这些研究的集大成者就是我们如今所知的 Optimistic Rollup。2019 年 6 月,《最小可行合并共识》首次阐述了这一技术。从那时起,以太坊社区就开始大力支持 ORU,将其作为以太坊式智能合约执行的可扩展性方案。(该段落引自登链社区)

执行过程

Optimistic Rollup 可视化

  1. 聚合者将 rollup 上的交易收集起来,打包进 rollup 区块,并将该 rollup 区块连同保证金(我们很快就会解释为什么需要保证金)一起发送到以太坊(或另一条类似以太坊的区块链,上面运行着具有大量状态的智能合约)上的智能合约中。这个 rollup 区块不会被翻译或执行——智能合约只记录区块哈希,并追踪所有 rollup 区块的哈希。rollup 区块本身不存储在智能合约内,但是所有人都可以在以太坊的历史交易中找到它们。

  2. rollup 区块包含一个状态根,即,该 rollup 区块的状态树的根。如果该状态根是无效的,则任何人都可以在挑战期内使用欺诈证明来证明它是无效的。这可能是因为这个 rollup 区块中有一笔交易是无效的,或者因为状态根是无效的。如果一个 rollup 区块被证明是无效的,合约就会将 rollup 链回滚,这个无效区块后面的所有的 rollup 区块都会变成孤块。一旦欺诈证明成功,保证金中的一部分会支付给证明者,剩余部分则销毁。

  3. 如果直到挑战期结束都没有人提交欺诈证明,合约会敲定 rollup 区块,允许聚合者取回保证金。用户将款项从 rollup 链上取回到主链上时,需要在 rollup 链上发起取款请求,只有当合约敲定该 rollup 区块后,款项才能取回。

缺点

  1. 在默认情况下,由于与以太坊上的智能合约交互本身存在延迟,欺诈证明的挑战期会很长(长达数周),还会因此导致提款延迟。客户端执行可以大幅缩短挑战期。但是,我们只需要让流动性提供者通过原子交换来提供提款服务,并收取少量费用,就可以轻松解决延迟问题。实际上,这是一种新的 DeFi 元件:流动性提供者可以通过提供服务,利用其流动性来赚取收益。

  2. ORU 的吞吐量以以太坊的数据可得性吞吐量为上限。在这种情况下,我们可以将 ORU 视为伪分片。多个 ORU 可以在同一个数据可得性层上并行运行。幸运的是,数据可得性相比执行更容易扩展。LazyLedger 等项目经过专门优化,可以提供具备高度可扩展性的通用数据可得性层,让所有 rollup 项目都能充分发挥其潜力。

sidechain

sidechain借助主链数据,使用自己的EVM进行交易的处理,最后将其拥有的数据同步给主链。Sidechain使用的方案以安全性为代价换取速度。Sidechain里面的有趣的地方有“双重挖矿”和”双向锚定“,双向锚定结合一个代币交换项目来理解。在同专栏的另一篇文章中以Polygon跨链桥(MATIC网络)作为例子进行讲解。

Plasma

Plasma即子链方案,就是一条链的子链通过Plasma网络,将自己的重要消息通知到主链上。

Plasma之所以不能称为主流的扩容方案,在于Plasma的数据并没有提交到链上,所以在Plasma上退出一笔资产的周期会长达一周左右(争议期),如果在争议期间没有人提交欺诈证明,那么资产才可以安全退出到主链。(这里不做详细介绍,等我学习差不多之后再写一篇文章介绍)

channel

我对于channel的理解为“多笔交易化作一笔交易”,就是将主链上的资产转换为虚拟币,在所有交易完成后结算虚拟币并等比例换回主链资产。channel的典型案例是lighting network(闪电网络),我们下面就以其为例进行讲解。值得注意的是,channel没有自己的EVM,因此无法运行合约,只能用来处理交易。

闪电网络

通俗理解,闪电网络的支付方式可以理解为“欠条版比特币”,即用户将BTC存在一个多签钱包中,创建一个支付通道并进行互相的交易,如果用户想要回比特币,就可以将自己现有在这个网络中的资产换成BTC。

相关文章:

Layer2区块链扩容方案(1)——总述

写在前面 这篇文章作为一个简单介绍,很多技术只是大致提及或者引用,之后会在详细学习后逐项解释。 补充知识 在了解扩容方案之前,我们最好了解一些相关的知识概念 EVM “EVM” 是“Ethereum Virtual Machine”(以太坊虚拟机&…...

AWS监控工具,监控性能指标

执行AWS监视是为了跟踪在AWS环境中主动运行的应用程序工作负载和资源,AWS监视器跟踪各种AWS云指标,以帮助提高在其上运行的应用程序的整体性能。 借助阈值突破警报系统,AWS应用程序监控在识别性能瓶颈来源方面起着至关重要的作用&#xff0c…...

义务外贸wordpress独立站主题

健身器材wordpress网站模板 跑步机、椭圆机、划船机、动感单车、健身车、深蹲架、龙门架、健身器材wordpress网站模板。 https://www.jianzhanpress.com/?p4251 农业机械wordpress网站模板 植保机械、畜牧养殖机械、农机配件、土壤耕整机械、农业机械wordpress网站模板。 …...

初等数论精解【4】

文章目录 算术基本定理基础理论整数运算规则1. 加法性质2. 减法性质3. 乘法性质4. 除法性质5. 其他性质 整数运算的性质整数构成域吗 参考文献 算术基本定理 基础 任何一个大于1的整数可以被分解为素因数的连乘积。 a p 1 p 2 . . . . p n ≥ 1 ap_1\times p_2....\times…...

MongoDB教程(二十二):MongoDB固定集合

💝💝💝首先,欢迎各位来到我的博客,很高兴能够在这里和您见面!希望您在这里不仅可以有所收获,同时也能感受到一份轻松欢乐的氛围,祝你生活愉快! 文章目录 引言一、固定集…...

20240724----idea的Java环境卸载与安装

1.删除旧有的jdk https://blog.csdn.net/weixin_42168713/article/details/112162099 (补充:我把用户变量和java有关的都删了) 2.下载新的jdk百度网盘链接 链接:https://pan.baidu.com/s/1gkuLoxBuRAtIB1IzUTmfyQ 提取码&#xf…...

C语言 ——— 函数指针数组的讲解及其用法

目录 前言 函数指针数组的定义 函数指针数组的使用 前言 数组是存放一组相同类型数据的存储空间 关于指针数组的知识请见:C语言 ——— 指针数组 & 指针数组模拟二维整型数组-CSDN博客 那么要将多个函数的地址存储到数组中,这个数组该如何定义…...

鸿蒙仓颉语言【cryptocj 库】(介绍与SHA、MD5、HMAC摘要算法)

cryptocj 库 介绍 cryptocj 是一个安全的密码库,包括常用的密码算法、常用的密钥生成和签名验证。 该库是对 C 语言的 openSSL 封装的仓颉加密算法 1 提供SHA、MD5、HMAC摘要算法。 前置条件:NA 场景: OHOS, Linux&#xff…...

设计App的后端接口分类以及环境依赖包详情

目录 App的后端接口分类 1. 用户登录与注册 2. 设备初始化 3. 广告与推广 4. 应用配置与功能 5. 支付系统 6. 内容分发 7. 资源下载 8. 视频内容 9. 用户行为分析 10. 安全与合规 设计建议 基于Easyswoole,可以在系统中引入需要的一些常见依赖包&#…...

接入百度文心一言API教程

然后,编辑文章。点击AI识别摘要,然后保存即可 COREAIPOWER设置 暂时只支持经典编辑器.古腾堡编辑器等几个版本后支持.在比期间,你可以自己写点摘要 摘要内容 AL识别摘要 清空 若有收获,就点个赞吧 接入文心一言 现在百度文心一言&…...

classfinal太强了,再也不怕被反编译了

这段时间在辛辛苦苦的编写一个算法程序,担心部署到客户服务器,客户反编译jar包,破解程序,那努力就白费了! 在网上查询,发现个好东东,classfinal可以加密jar包,防止反编译&#xff0…...

DP-适配器模式代码重新理解

package com.designpatterns.adapter;/*** 定义鸭子接口*/ public interface Duck {/*** 定义鸭子呱呱叫(quack)*/public void quack();public void fly(); }package com.designpatterns.adapter;/*** 实现一个绿头鸭*/ public class MallarDuck implements Duck{Overridepubl…...

minio安装小计一则

安装minio并且使用api方式对文件进行操作 本文使用docker安装 docker pull minio/minio docker pull minio/mc (mc为minio文件运行命令行工具) 使用如下命令运行Minio服务器容器: windwos powershell运行命令 docker run -p 9000:9000…...

# Redis 入门到精通(九)-- 主从复制(1)

Redis 入门到精通(九)-- 主从复制(1) 一、redis 主从复制 – 主从复制简介 1、互联网“三高”架构 高并发高性能高可用 2、你的“Redis”是否高可用? 1)单机 redis 的风险与问题 问题1.机器故障  现…...

SpringBoot整合ElasticSearch的elasticsearch-java出现jakarta.json.spi.JsonProvider报错问题

一、原因 报错内容如下 org.springframework.beans.factory.BeanCreationException: Error creating bean with name esClient defined in class path resource [com/elasticsearch/config/ElasticSearchConfig.class]: Bean instantiation via factory method failed; nes…...

git 操作汇总【迭代更新中】

文章目录 0x1初始化操作0x11 生成公钥0x12 配置账号和邮箱 0x20x21 拉取代码0x22 推送代码0x23 设置远端分支 0x30x31 提交mr 0x40x41 子模块0x42 子模块添加 0x1初始化操作 0x11 生成公钥 ssh-keygen0x12 配置账号和邮箱 git config --global user.name username git confi…...

看 Unity 组件的源码 —— ILSpy

ILSpy 是开源的 .NET 程序集浏览器和解编译器。 下载 ILSpy ILSpy Github 地址:icsharpcode/ILSpy: .NET Decompiler with support for PDB generation, ReadyToRun, Metadata (&more) - cross-platform! (github.com) 它有 Release 包可以下载 也提供 IDE 的…...

Axivion Suite 7.8现已发布

现已实现100%覆盖MISRA规则,并加入了高级功能来提高代码分析能力。 我们很高兴地宣布Axivion Suite 7.8发布。全新版本的Axivion Suite对编译器、配置、分析、仪表板 (WebUI)和IDE插件的架构验证和静态代码分析功能均进行了升级。 100%覆盖所有可测试的MISRA规则 …...

从零开始!JupyterNotebook的安装教程

安装 Anaconda 1、下载 Anaconda: 访问 Anaconda 官方网站 (https://www.anaconda.com/products/distribution/) 下载适合您操作系统的 Anaconda 发行版。 2、安装 Anaconda: Windows:运行下载的安装程序,选择“Just Me”…...

使用kali进行端口扫描

目录 一、使用nping工具向目标主机的指定端口发送自定义数据包 二、使用Nmap工具进行端口扫描 三、使用Zenmap工具进行扫描 一、使用nping工具向目标主机的指定端口发送自定义数据包 nping工具允许用户产生各种网络数据包(TCP,UDP,ICMP&am…...

OpenLayers 可视化之热力图

注:当前使用的是 ol 5.3.0 版本,天地图使用的key请到天地图官网申请,并替换为自己的key 热力图(Heatmap)又叫热点图,是一种通过特殊高亮显示事物密度分布、变化趋势的数据可视化技术。采用颜色的深浅来显示…...

Linux简单的操作

ls ls 查看当前目录 ll 查看详细内容 ls -a 查看所有的内容 ls --help 查看方法文档 pwd pwd 查看当前路径 cd cd 转路径 cd .. 转上一级路径 cd 名 转换路径 …...

python如何将word的doc另存为docx

将 DOCX 文件另存为 DOCX 格式(Python 实现) 在 Python 中,你可以使用 python-docx 库来操作 Word 文档。不过需要注意的是,.doc 是旧的 Word 格式,而 .docx 是新的基于 XML 的格式。python-docx 只能处理 .docx 格式…...

C++中string流知识详解和示例

一、概览与类体系 C 提供三种基于内存字符串的流&#xff0c;定义在 <sstream> 中&#xff1a; std::istringstream&#xff1a;输入流&#xff0c;从已有字符串中读取并解析。std::ostringstream&#xff1a;输出流&#xff0c;向内部缓冲区写入内容&#xff0c;最终取…...

Ascend NPU上适配Step-Audio模型

1 概述 1.1 简述 Step-Audio 是业界首个集语音理解与生成控制一体化的产品级开源实时语音对话系统&#xff0c;支持多语言对话&#xff08;如 中文&#xff0c;英文&#xff0c;日语&#xff09;&#xff0c;语音情感&#xff08;如 开心&#xff0c;悲伤&#xff09;&#x…...

LeetCode - 199. 二叉树的右视图

题目 199. 二叉树的右视图 - 力扣&#xff08;LeetCode&#xff09; 思路 右视图是指从树的右侧看&#xff0c;对于每一层&#xff0c;只能看到该层最右边的节点。实现思路是&#xff1a; 使用深度优先搜索(DFS)按照"根-右-左"的顺序遍历树记录每个节点的深度对于…...

【电力电子】基于STM32F103C8T6单片机双极性SPWM逆变(硬件篇)

本项目是基于 STM32F103C8T6 微控制器的 SPWM(正弦脉宽调制)电源模块,能够生成可调频率和幅值的正弦波交流电源输出。该项目适用于逆变器、UPS电源、变频器等应用场景。 供电电源 输入电压采集 上图为本设计的电源电路,图中 D1 为二极管, 其目的是防止正负极电源反接, …...

2.2.2 ASPICE的需求分析

ASPICE的需求分析是汽车软件开发过程中至关重要的一环&#xff0c;它涉及到对需求进行详细分析、验证和确认&#xff0c;以确保软件产品能够满足客户和用户的需求。在ASPICE中&#xff0c;需求分析的关键步骤包括&#xff1a; 需求细化&#xff1a;将从需求收集阶段获得的高层需…...

免费批量Markdown转Word工具

免费批量Markdown转Word工具 一款简单易用的批量Markdown文档转换工具&#xff0c;支持将多个Markdown文件一键转换为Word文档。完全免费&#xff0c;无需安装&#xff0c;解压即用&#xff01; 官方网站 访问官方展示页面了解更多信息&#xff1a;http://mutou888.com/pro…...

World-writable config file /etc/mysql/mysql.conf.d/my.cnf is ignored

https://stackoverflow.com/questions/53741107/mysql-in-docker-on-ubuntu-warning-world-writable-config-file-is-ignored 修改权限 -> 重启mysql # 检查字符集配置 SHOW VARIABLES WHERE Variable_name IN (character_set_server, character_set_database ); --------…...