Hi 游客

更多精彩,请登录!

比特池塘 区块链前沿 正文
以太坊作为单片区块链在用户与应用发展到一定体量后,受区块链“不可能三角”的制约,缺点日渐凸显。
9 v1 c6 c2 |, F+ L* j9 A" \, G; x3 X+ o5 R
为解决困境衍生出链上扩容与链下扩容两个方向。Optimism是一种链下扩容解决方案,将交易数据放在链上,在链下运行计算,增加以太坊TPS的同时降低gas费用。' x  e0 v- w9 v( G
: }: u  y6 K: `. R; X2 c1 s! e% [
虽然交易发生在Optimism上,但数据会发送至以太主网进行验证,因此这种方案不会牺牲以太坊的去中心化程度与安全性。同时Optimism在EVM兼容度方面的进展较为显著,是目前L2中唯一实现EVM等效性的rollup。7 J( a# `* k; h. Q7 H& y, S: ]; {9 T
2 A, d$ B) d6 h
Optimism是如何解决以太坊扩容问题的?
- V! S, h- e6 i* ?2 K
- ~% m* B. C  [9 K4 H3 L8 WOptimism网络中有两种节点:sequencer与verifier。sequencer与verifier都会运行L2Geth,L2Geth是由Optimism创建的改良版轻量级Geth(基于Go语言开发的以太坊客户端)。所以,Optimism网络与以太坊网络非常相似。上线之初,Optimism只有一个由团队管理的sequencer,计划在稳定运行后进行去中心化。
  y1 ?1 R( ]- c( ?( K' |$ r% k: [/ V$ \" H0 v( t& x  K! u+ }
网络的运行流程大致如下:+ |& l( Z1 A" s) N( e

3 v- J$ c( S; [3 H· 用户将交易发送至sequencer,sequencer会对在L2中的交易副本进行处理;1 k2 h' P9 K  \1 M  a/ [' F4 G
2 p: N5 d, \) }, X
· 处理完成后,sequencer将交易数据与更新后的L2 stateRoot提交至L1;8 Q3 I( n  W  m6 `) ?- o0 ^
# ]+ R% N* v" S# U6 i
· 上面提到的其它节点开始处理L2副本中的交易;
/ B. X% D$ R9 @/ |, ^+ K# R3 z0 R4 F$ W: W( K8 K6 P
· 为确保提交至L1的新stateRoot的正确性,verifier会将其新的stateRoot与sequencer提交的stateRoot进行对比;
; R, ~" l; N! R6 E9 V& ^3 S0 T( s, O# \; l& o% V% J
· 若存在差异,便会进入欺诈证明(Fraud Proof)流程,即在L1中执行L2的交易,确保stateRoot结果的真实性;: K/ a7 h' n  a& v

7 x4 p, }6 y$ `% E. _· 若欺诈证明的stateRoot结果与sequencer提交的stateRoot结果不同,那么sequencer的初始质押会被削减,前一笔交易的stateRoot会被删除,sequencer将重新计算失去的stateRoot;
! `+ y: k, y0 c3 k3 }$ _& ]
/ Z- K7 U# O% v* \, y; M' W· sequencer完成去中心化后,若其质押被削减,会有新的sequencer将其取代。
+ X' ]$ M6 w( y! N$ P
) k) h, v$ w( f: u3 Y 1670924887654257.jpg
; Z& V# L9 E" b
. o' Q) Y' z$ C8 |交易# b$ h" r; G# g, A$ u) v

; U" |# e4 x5 Y' I! e7 |" N在Optimism中有两种交易类型至关重要:L2中两个地址间发生的交易、L1与L2之间的跨链交易
6 O- P+ s1 K' ~& C& e, b- A' g8 [* c) o1 k+ H2 U3 J* r
L2交易流程
6 ]" U$ N/ U6 G# g% S0 n: e  @' ^5 p  U+ Y
· 用户将交易发送至sequencer,若为有效交易,sequencer会立即将其添加至L2(注:此时只有sequencer将此交易添加至其L2的副本当中)。L2的块大小仅为1笔交易,因此新的区块与交易会被立即添加到链中,在L2中矿工无需争夺挖掘新区块,sequencer取代了矿工的角色;
2 ~4 |/ y) e' Z" h' n) R8 y' C6 u. H3 K2 v' s
· sequencer向L2添加交易后,会调用L1合约并将所有数据发送至L1,数据包含所有L2交易以及执行交易后的L2的新stateRoot;
& n/ F/ F% E2 e4 m, x* E8 J1 A1 Y# s
· L1将交易数据与stateRoot保存至另一个专为存储而设计的合约中;
" t+ R: G. S- W, I. n
. D, x; F3 K6 f. i· 一旦交易数据成功在L1上存储,verifier就会把交易储存在其在L2的副本中。+ f) U% [6 J4 _: V0 n

% Y4 s" a6 N; T4 @( s2 ?7 R若sequencer在对某一特定用户进行审查,那么该用户可提交数据并自行调用合约。然后,sequencer会在特定时间范围内强制处理该笔交易。若sequencer未执行,那么其质押可能会被削减。) i; a1 t- U) U; x$ M; n
# ]5 I) s5 C0 S: T  K% D
上面阐述了verifier核实sequencer发布至L1数据的过程。verifier也可选择直接从L2进行数据同步,也就是说verifier可以在数据被发送至L1之前直接从sequencer获得新的数据。从L2直接同步可以减少延迟,但这种方法不能保证sequence仍会将此交易发送至L1。
5 A4 ]% K' s, \- x7 A
2 ]( O, \5 R: x8 b+ W& u* X跨链交易
0 T1 h7 o; w( r' _% z3 |+ q* L8 ~8 m% |( A8 P, ]
为方便调用其它链上的合约或者将token从一条链发送至另一条链,跨链在Optimism的地位不可忽视。由于涉及多链,其整体流程与L2交易略有不同。) w: U: c( a7 f9 h* t9 m; j
; w4 W  S) n; H* e& m/ n$ N
L1 -> L2交易* X. w, W; v2 u, S& q

' P) C7 H% `, nOptimism从L1至L2交互的速度很快,只需sequencer将信息发送至L2。用户将交易数据发送到L1的bridge合约中,合约会在一定时间范围内将交易添加至sequencer必须发送至L2的交易队列中,然后sequencer会将该交易发送至L2。8 A( @. ~" q- r4 L2 F

5 Z) M% G' _0 l, ^! l( W* g. ?举个例子,如果用户想将L1的10 ETH发送至L2的地址进行交互,流程如下:
4 _  j/ c! ~: }/ I1 m* w9 |
. c0 K* H2 I: ]) c8 k·用户向L1中的bridge合约发送10 ETH;
% k' d: a; C9 T+ h5 _
( W& K* d4 C2 K+ U' A·bridge合约将ETH在L1中锁定;
* e+ c5 f. C4 T! T# |5 A2 d. D
& @; ]/ O  l1 }8 N6 u  G·bridge合约同时将用户的交易添加到sequencer必须添加至L2的交易的队列中;+ P/ K. G! \8 L! E1 f; W( M6 u
1 N4 e( ?; U* F5 U, g7 N: p
·sequencer开始处理此笔交易,ETH被成功存入用户的L2地址。* u- _" j# P- y

/ ~, @( R3 W" X' s, l& C7 h/ a& t 1670924887671207.jpg
+ Y% r; B! j8 h; O+ n! U- Y4 Q7 V
L2 -> L1交易5 i+ ?8 w0 x; R, d" K6 e4 D

, _* z) {1 f. j0 v# w- ]: qL2至L1的交易相对复杂,L1必须确保交易后的L2 stateRoot具备有效性。用户将交易发送至L2的指定合约,然后中继器进行读取并将交易发送至L1。Optimism应用JavaScript服务运行中继器,使用sequencer和verifier与L2进行交互。0 z$ a& ?# Z" a# Y( K
: n" t1 Y6 q! F* G7 V
举个例子,如果用户想将L2的10 WETH转回至L1,流程如下:9 N# N! f6 q* s/ o9 }* n3 E! w9 c

. L' \2 F8 _% V' G/ d! |·用户将10 WETH发送至L2的bridge合约;
0 l; D: B. L2 F8 e3 {
5 y1 L7 q+ P# d4 h8 f" y· bridge合约销毁WETH并将交易信息发送至L2ToL1MessagePasser的智能合约中,合约记录了需要从L2发送至L1的交易数据;1 D; R+ N1 ~& U- L) U
# V. d/ \: y. k- l! Z
·中继节点从L2ToL1MessagePasser读取交易数据,等待欺诈证明窗口(7 天)完成,然后将交易发送至L1;% o0 [# t: |: w( T; _; d
' U" T; f8 }$ q" M/ ]" K: v$ `
·交易在L1中进行处理,用户此时可从首次发送至L2时锁定ETH的bridge合约中取出ETH。
* W  F) z; k1 `! {6 q: ]  w! N2 J  r+ M" N6 a
欺诈证明窗口为verifier预留了充足的时间来证明sequencer发布的stateRoot对这个交易来说是否准确。
9 r5 [3 Z0 }1 w! t5 r  N
3 }" W, y5 N& K7 I 1670924887631709.jpg ( Z) M0 W& v4 i- y) l

% k3 f- R" [* j  X2 IL1中存储的交易与stateRoot  h  D# h: N" d& J7 t
. O+ V2 K/ Q# [0 f( D: V
由于每笔交易的数据与stateRoot的结果必须保存至L1中,那么降低数据所占空间对于降低系统存储成本来说至关重要,以下过程阐述了L2数据是如何被保存至L1的:
4 M1 y# X( r- \7 [& _, z2 @1 y) j8 m+ w% e' @8 ~' p
·sequencer获取多个L2连续交易的calldata并将它们组合为一个批次;
- O; I% H6 k% Y" c* b4 u' u- j0 a) L/ N) k& ^- o4 x' m
·sequencer将这个批次发送至CanonicalTransactionChain合约中;
* h4 `. q* S& e1 \! W3 O
) j* v5 @( T- `·智能合约对每笔交易的calldata进行散列处理,为这些哈希值创建默克尔树;3 d+ p% ?( p1 Y* |  v, D

  J. w& }9 \8 [7 F·CanonicalTransactionChain合约收到该批次的默克尔根并将其发送至专门用于存储的合约中。5 v% f/ e5 n: t

+ K  {6 W5 r! [7 S+ U$ P上述过程将交易汇总,创建了默克尔树,保存了默克尔根。stateRoot的存储方式与以上流程类似,只不过汇总stateRoot的合约变为StateCommitmentChain。在这种情况下,L2的交易在L1中的状态更改是将新的默克尔根添加至用于存储的合约中,这种方式要比将每笔交易都保存至存储合约中更为高效。( n- w9 {5 Y! C- ?5 }

- a$ Q2 Q% l3 b+ e. n* B 1670924887665233.jpg
+ s/ J, u* c+ o. I# Q
% F) [/ n3 F# l) ?& L欺诈证明(Fraud Proof)
3 y2 _+ m- Z- e# m7 ]$ q. |
, Y7 E  A9 m; u1 y欺诈证明是Optimism生态中非常重要的部分,其主要目的是保证sequencer输出结果的真实性。若sequencer将虚假的stateRoot发布至L1,那么verifier就可以启动欺诈证明程序并在L1上执行对应的L2交易。然后将欺诈证明的stateRoot结果与sequencer提交至L1的stateRoot进行比较。若结果不同,sequencer的质押会被削减,前一笔交易的stateRoot会被清除并重新进行计算。因此,所有的L2交易可以保证在L1中完成运行。% k) v2 A9 Q* S

+ a" n5 L) S- ~/ I& O: p欺诈证明可以由任何人发起,但通常是由verifier发起的,因为它们会检查sequencer提交的每个stateRoot的有效性。欺诈证明的整个流程由Optimism提供的一套L1合约管理,使用合约时,用户可以在L1中重新执行L2的交易,生成正确的stateRoot。如果生成的stateRoot与sequencer发布的stateRoot不匹配,合约就会削减sequencer的质押,还会删除上一笔交易所对应的stateRoot。
3 R/ ~: e" i3 C
$ w1 X) A! M2 l; a) hOptimism的出现极大地提高以太坊网络的可扩展性,在吞吐量不变的基础上,降低了gas成本。L1网络中的以太坊全节点承担着处理交易的职责,由于网络包含节点的数量众多,使计算成本变得非常昂贵。Optimism将交易交由一小组节点(sequencer与verifier)处理,使交易的计算从L1中脱离出来,而交易的calldata仍在L1上得以保留,这样为L1上的节省了大量区块空间,使其可以处理更多交易。9 O& r) x* ~+ M2 w: B

( C7 U% m9 e5 i3 ?% F% H% {8 tOptimism的技术更新与进展
) Z9 d% J7 U1 U0 ~4 w& c. a) Z0 ]5 j  M
Optimistic Virtual Machine(OVM)
8 S/ F! k$ P7 C/ i* o7 H7 {, g- j! W# ?7 D# c; a3 u3 h; p
OVM是一个功能完善且与EVM兼容的执行环境,是专为Optimism L2的使用而创建的,通过Web3 API与以太主网交互。总体来看,OVM与EVM其实非常相似,但进行了优化与改进,方便修改或删除上下文相关的操作码(如TIMESTAMP或ORIGIN)。操作码在不同的链执行时,输出的结果不同。但在OVM中进行优化后,所有的交易都可以在不同的链上重新执行,输出相同的结果。OVM本质上是一个沙盒环境,可使L2交易在其它链上被重新执行与确定。这样verifier就可以创建欺诈证明并在L1上重新执行交易,输出正确的stateRoot。+ j( P* S6 @6 C
% H8 ~0 k1 Q+ l. z" f
Optimism Bedrock- ^) t; i8 I4 h7 c/ z7 z- M' x6 d

* _1 o. h2 Z. Z' _Bedrock是由Optimism设计并开发的rollup基础设施,通过模块化与极限分割的方式实现对交易费用、网络性能以及生成区块过程的优化。Bedrock中包含一个新的L2衍生流水线,这个流水线也是唯一一个在发送交易数据至以太坊网络的过程中可以最大限度节省gas费用的rollup基础设施。Bedrock也是唯一一个将以太坊引擎API作为分隔共识客户端或执行客户端的rollup。待以太坊扩容方案EIP-4844 (proto-danksharding)上线后,Optimism可以与data blob无缝集成,大幅降低gas费用。作为rollup客户端,Bedrock在对rollup proof的选择上非常灵活,目前使用的是Optimistic proof(Cannon),就当前情况来看Optimistic rollups的优势较为明显,后续可根据需要转换为ZK proof。Bedrock的结构与以太坊的post-Merge十分相近,分为consensus layer(CL)与execution layer(EL),具体如下:
8 b$ m3 P1 z8 c" T7 u: \' O# ?8 ]' K: r% g( t
L1 Ethereum:
1 c4 G  P" Q4 u! e% A9 \& W6 K% g- Y9 N1 ]6 N+ M! O4 l% @
CL: Beacon Node - E.g. Prysm
/ }3 Q! y7 o) M0 z( Z4 a+ {: ]3 g! B, Z" b8 {
EL: Execution Engine - E.g. Geth
9 N# l/ \" E& y% I5 z; ]2 G  [. U& |# y3 l% I2 Q$ U5 r( }7 A
L2 Bedrock:" }" o- ^' @# x& z  j* l! l0 j' T, ^

" |1 R- ?1 c* F/ ICL: Rollup Node - OP-node- J5 G7 ?3 {: F8 Q: a

7 W+ H# d) X1 P& Q! tEL: Execution Engine - OP-Geth
/ O  O, R& S: W
/ V0 G8 ^! O$ H2 j& A/ b2 JOP Stack& E8 c# I3 m- ?# K
( e6 h% S! g/ b- V" |8 L* L
在介绍OP Stack之前有必要先了解一下Optimism Collective。Optimism Collective是由Optimism推出的治理系统,成员为社区、公司与公民,由Citizens' House和Token House 共同治理,以推动去中心化系统发展。OP Stack就是为Optimism Collective创建的开源软件栈,为其生态系统赋能,主要包含以下两部分:
, u6 {& ~" }/ B: `3 ]
: f: S5 i8 X& B/ k1.链式栈(Chain Stack):运行去中心化应用,分为Consensus Layer、Execution Layer、Settlement Layer;
9 v) e) K8 l' i# l2 h4 T% }  @5 B' ~: F% Y7 Q# ]
1670924887631254.jpg 7 a: d- i! ?+ g; E3 r

% H+ P7 }( h5 {( \2.治理栈(Governance Stack):确认产品定位,为其提供资金。1 ^" L5 ]' k( c; ^/ s' I. S" W/ X5 r

% c) o3 r) ^7 d* p以实现:( p; \% c& [) U' o1 b8 V; V

& d2 q. e% f) Y6 z# \" w( r$ Z- G- l· op-chcin安全的标准化
+ k$ \! O6 F/ ?9 A" g8 T8 T! K* K1 Y- I
· op-chain工具的标准化
# @; b% n3 S5 y- M9 l5 R0 m
, r5 A! }+ h$ j8 m· op-chain治理的标准化
' L4 p% T+ [/ [, b5 t, r" Q9 m2 A' V* v7 o1 R
· op-chain可组合性最大化  u% Z% {% o2 E& i% m# }
' [+ N: M0 b8 z+ D6 P+ o; k8 p
最终成为一个可无限组合与扩展的“Superchain”。
3 X( W5 W+ L1 s9 X- b2 q3 R& V( S; l- S0 V* }" V* K; q& }
1670924887635581.jpg ( o" u* E: q  X2 m% E/ T8 _
' H3 q# Z1 [$ C4 W) S
Optimism生态发展数据
3 I4 @; M" I% b1 S3 c4 C) z
# c4 V& o' g' C9 l协议收入
& J7 a3 s! f; s8 Z3 t8 G  @
  t; w$ S* J* M9 ~6 R7 u1 YOptimism的网络收入总体呈小幅震荡上升的状态,9月的震荡区间为$1.0k至$8.9k美元;10月的震荡区间为$2.9k至$11.3k;11月的震荡区间为$5.9k至$14.3k,11月8日至11日四天出现大幅攀升,最高至$61.2k后回落至正常状态。6 Y5 K0 y/ L, a- D  Q5 {

' I, U9 ?* Q6 A/ I  `3 S  U5 J7 y 1670924887697758.jpg 8 @4 L: ~( ?% B4 E
6 e' Y4 t1 t7 [; |. h/ O
独立地址
5 ]6 v" |  L2 T7 Z6 i( s( u, K1 r" w. o8 _8 G; J9 M
Optimism的独立地址数呈稳步上升趋势。4月27日当天由于空投发放新增地址45.6万余个,后进入缓慢增长状态。9月后独立地址表现为阶梯式增长,日均新增从2.7k稳步过渡至10k。
6 b; Y) y4 R. L# G8 q
! ^" P3 h% H" `2 j 1670924887702301.jpg
4 \! C/ H+ J8 t/ s* A' s$ ?1 P" U. ~: P: \9 k7 e
日交易量
$ ~6 G! L* f6 @  @  E' b
' W# {# E0 ]9 E! j) Y- _' u随着独立地址数的上涨,Optimism的日交易量呈现出相似的增长趋势,进入9月后日交易量由126.1k逐步攀升至347.1k,上涨约175%,11月9日日交易量迎来近期高点达492k。
# p/ T4 R0 ^' ?/ A* w
5 P1 `( h( }% L/ b* s$ U 1670924887705138.jpg
6 r! }5 h( P; D0 r" _9 w/ i0 n; Z. R: I! ^# O
日活跃用户- I3 P1 ]: V3 c
5 {2 |& X5 ^* y" ?5 N
Optimism的日活跃用户量整体来看呈震荡上升状态。由9月初的阶段性低点8.5k到12月初的34.8k,增幅为309.4%。
' C1 S* K" \8 [  m: G9 |6 `; M. G( F. F: s6 z( s
1670924887686471.jpg 1 y: w8 B; }. V, H, F* V/ x7 [
9 A7 n& I5 D9 a
TVL7 n' }# p( ?) F& }" i$ b8 l1 Q

2 p8 D6 e% E5 P$ }Optimism的TVL从9月到10月之间保持在9亿美金上下,直至FTX事件之后出现断崖式下跌,触及5.17亿美金,下降了42.55%,所受影响较大,目前稳定在5.56亿美金左右。, v; {, L9 \0 \, Q" `4 j+ Z8 @

& e8 h" D' g- a0 T+ {' f# d 1670924887681800.jpg
* Y" D4 L$ U! E  _5 Z0 ?( f  A0 q1 y! V) `2 P
链上应用( i5 V9 V0 m: B2 h) R

, ^; [7 ?7 S# C' x: v$ L* r2 QOptimism生态中TVL排名前十的应用分别是:AAVE V3、Synthetix、Velodrome、Curve、Uniswap V3、Beefy、PoolTogether、Star gate、Perpetual Protocol、Beethoven X。不难看出,Optimism网络中非原生应用在TVL中所占比例较大,唯一的原生应用Velodrome的TVL仅占前十应用总TVL的14.64%。* j0 Y- H8 L" c* }! D" f

, h3 ?$ p6 q, N- r 1670924887688883.jpg " {; X+ \/ U7 @* S  u+ r
$ ?" N1 e$ _! \9 p+ P; H& I- w' k
项目交互
& o6 Y, w8 s5 u$ d, G
; v- ?1 ^' I" T( j从生态内部产品整体交互的情况看(图1)原生应用Velodrome、Pika Protocol、Rubicon交互数量仅占生态内排名前七应用交互总量的24.87%,这说明原生应用的用户粘性有待加强,可推测现阶段用户使用Optimism主要目的是节约在以太L1使用的gas成本。而导致近7天交互应用排名(图2)与整体交互情况有不同的主要原因是由于用户参与OP版“奥德赛”活动的刷量行为,导致短时间内原生产品的交互增加。
1 {3 v+ ]- ?0 e. [! u! f, U2 Z/ V# g) O2 @9 {: d
1670924887702155.jpg
) T( h4 s3 M( T# `. p6 g/ l  {
* e: D: @, Q9 t/ O+ L$ @图1
2 a& I/ X" \; G  W. ~% t- {9 r" g8 P; e
1670924887704561.jpg & O  Q2 A5 F% ~: t; C

0 F/ D' k" [7 z图2" v* Y  l; S4 ?; d. Y9 p7 c' L

) I$ L- W0 `& ?% n0 l6 B跨链
7 T  Q' R9 \' g1 z( X# G$ P. k# g- k) u1 A5 C  f0 ?- K! Z, `
截止至目前,使用Optimism进行跨链的用户约为27.2万人,跨链总金额约为44.8万枚ETH(按市价折算约为5.5亿美元);七日内存款人数为10.6万人,七日内跨链总金额接近1.1万枚ETH。与其它L2协议Arbitrum、zkSync、StarkNet 相比,除七日内存款人数排名第一外,其余三个维度的数据均处于第二的位置。
5 q2 H7 n2 F9 @  g7 a# _- U- U& u6 s2 U8 P) M% W0 k+ }
1670924887685860.jpg ; O; J4 S1 S+ ?+ K$ f
+ b, R  B( U0 b$ N8 A* d
Gas: o, y3 M' e+ e" i$ `3 K+ Q# \% o
0 N- x* C5 L; ]8 r4 r+ A" m6 X8 k
从gas费用来看,Optimism在众多L2协议中转账费用排名第六,比以太坊L1的转账成本低了83%。Swap的费用在L2协议中排名第四,比在以太坊L1进行swap的成本低95%。(注:下图中所显示的费用是浮动的,但变化幅度相对较小)& A$ X; i. Z  b7 R  R
6 u' X3 T' m! f& k7 X2 x
1670924887696930.jpg
6 }, p# W; `9 j4 e% F, ]  H. _" n1 t* S+ C
Optimism未来展望4 b' r* a- o' l- a: P) t3 d
. z2 Q; v  x) I/ r& f9 _( S
Optimism生态内现有应用240余款,但大多数为非原生产品的生态扩张与迁移。若从将其视为一个独立生态的角度看,原生应用的开发与获客仍然有很大的上升空间。随着Bedrock的逐步成熟,Optimism与以太坊基础设施的集成协议值得关注;其次,OP Stack所带来的Superchain概念是否会衍生出跳脱于现有rollup的新概念L2也需进一步的探讨。此外,待EIP-4844上线之后在Optimism的gas成本继续降低的条件下是否有机会超过同类型的rollup因而获得竞争优势也是一个值得观察的部分。( T$ O! B- P; W" s) R, p3 ]% s

% X3 t5 J: @0 P5 R0 M! n6 ?
BitMere.com 比特池塘系信息发布平台,比特池塘仅提供信息存储空间服务。
声明:该文观点仅代表作者本人,本文不代表比特池塘立场,且不构成建议,请谨慎对待。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

成为第一个吐槽的人

梦的衣裳323 小学生
  • 粉丝

    0

  • 关注

    0

  • 主题

    5