پرش به محتوای اصلی
Change page

راهکار های ذخیره‌سازی داده در بلاک‌چین

آخرین ویرایش: @sipbikardi(opens in a new tab), ۲۹ خرداد ۱۴۰۳

راه‌های مختلفی وجود دارد تا داده‌ها را چه به‌صورت مستقیم در بلاک‌چین و چه با روشی که امنیت آن از طریق بلاک‌چین تأمین شود، ذخیره‌سازی کرد:

  • بلاب‌های EIP-4844
  • داده‌ی فراخوانی (calldata)
  • خارج از زنجیره ولی بهره گرفته از مکانیزم بلاک‌چین لایه 1
  • "کد" قرارداد
  • رویدادها
  • حافظه ابدی ماشین مجازی اتریوم (EVM storage)

انتخاب روش مورد استفاده بر اساس چندین معیار است:

  • منبع اطلاعات. اطلاعات موجود در داده‌ی فراخوانی (calldata) مستقیماً از خود بلاک‌چین نشأت نمی‌گیرند.
  • مقصد اطلاعات. Calldata فقط در تراکنشی که شروع می کند در دسترس است. رویدادها به هیچ وجه به صورت زنجیره ای قابل دسترسی نیستند.
  • چقدر دردسر قابل قبول است؟ رایانه‌هایی که یک گره در مقیاس کامل اجرا می‌کنند می‌توانند پردازش بیشتری نسبت به یک کلاینت سبک در برنامه‌ای که در مرورگر اجرا می‌شود انجام دهند.
  • آیا تسهیل دسترسی آسان به اطلاعات از هر گره ضروری است؟
  • الزامات امنیتی.

الزامات امنیتی

به طور کلی امنیت اطلاعات شامل سه ویژگی است:

راه حل های مختلف در اینجا همه یکپارچگی عالی دارند، زیرا هش ها در L1 ارسال می شوند. با این حال، آنها دارای ضمانت های مختلف در دسترس بودن هستند.

پیش نیازها

شما باید درک خوبی از [اصول بلاکچین] (/developers/docs/intro-to-ethereum/) داشته باشید. این صفحه همچنین فرض می‌کند که خواننده با blocks، تراکنش‌ ها و سایر موضوعات مرتبط آشنا است.

حباب های EIP-4844

در شروع با [هاردفورک دنکان] (https://github.com/ethereum/consensus-specs/blob/dev/specs/deneb/beacon-chain.md)،(opens in a new tab) بلاک چین اتریوم شامل [EIP-4844] است (https:// eips.ethereum.org/EIPS/eip-4844)، که به حباب های داده اتریوم با طول عمر محدود (در ابتدا حدود [18 روز]) اضافه می کند (https://github.com/ethereum/consensus-specs/blob/dev/specs(opens in a new tab)) /deneb/p2p-interface.md#configuration)). این حباب ها جدا از گس اجرا قیمت گذاری می شوند، اگرچه از مکانیزم مشابهی استفاده می کنند. آنها یک راه ارزان برای ارسال داده های موقت هستند.

مورد استفاده اصلی برای حباب های EIP-4844 این است که رول‌‌آپ ها تراکنش های خود را منتشر کنند. رول‌آپ‌های خوش‌بینانه باید تراکنش‌ها را روی بلاک‌چین‌های خود منتشر کنند. این تراکنش‌ها باید در طول دوره چالش(opens in a new tab) در دسترس همه باشند تا اگر ترتیب‌دهنده(opens in a new tab) رول‌آپ یک ریشه وضعیت نادرست را ارسال کند، اعتبارسنج‌ها(opens in a new tab) را قادر می‌سازد تا اشتباه را برطرف کنند.

با این حال، هنگامی که دوره چالش سپری شد و ریشه حالت نهایی شد، هدف باقی مانده برای دانستن این تراکنش ها تکرار وضعیت فعلی زنجیره است. این حالت از گره های زنجیره ای نیز در دسترس است و به پردازش بسیار کمتری نیاز است. بنابراین، اطلاعات تراکنش همچنان باید در چند مکان، مانند [کاوشگران بلوک] (/developers/docs/data-and-analytics/block-explorers) حفظ شود، اما نیازی به پرداخت هزینه برای سطح مقاومت سانسوری که اتریوم ارائه می کند نیست.

رول‌آپ‌های دانش-صفر همچنین داده‌های تراکنش خود را ارسال می‌کنند تا دیگر گره‌ها بتوانند وضعیت موجود را تکرار کنند و اثبات اعتبار را تأیید کنند، اما باز هم این یک نیاز کوتاه مدت است.

هنگام نوشتن پست در EIP-4844 یک وی (10-18 ETH) در هر بایت هزینه دارد، که در مقایسه با 21000 گس اجرا که هر تراکنش، از جمله تراکنشی که حباب‌ها را پست می‌کند، هزینه دارد، ناچیز است(opens in a new tab). می‌توانید قیمت فعلی EIP-4844 را در [blobscan.com] (https://blobscan.com/blocks(opens in a new tab)) ببینید.

در اینجا آدرس هایی برای مشاهده حباب های ارسال شده توسط برخی از مجموعه های معروف وجود دارد.

رول‌‌آپآدرس Mailbox
Optimism(opens in a new tab)0xFF00000000000000000000000000000000000010(opens in a new tab)
Arbitrum(opens in a new tab)0x1c479675ad559DC151F6Ec7ed3FbF8ceE79582B6(opens in a new tab)
Base(opens in a new tab)0xFF00000000000000000000000000000000008453(opens in a new tab)

کال‌دیتا

Calldata به بایت های ارسال شده به عنوان بخشی از تراکنش اشاره دارد. به عنوان بخشی از رکورد دائمی بلاکچین در بلوک که شامل آن تراکنش است، ذخیره می شود.

این ارزان‌ترین روش برای قرار دادن دائمی داده ها در بلاکچین است. هزینه هر بایت یا 4 گس اجرا (اگر بایت صفر باشد) یا 16 گس (هر مقدار دیگر) است. اگر داده ها فشرده شوند، که یک روش استاندارد است، هر مقدار بایت به یک اندازه محتمل است، بنابراین میانگین هزینه تقریباً 15.95 گس در هر بایت است.

در نوشتن قیمت ها 12 جی‌وی/گس و 2300 دلار/اتر است، که به این معنی است که هزینه تقریباً 45 سنت در هر کیلوبایت است. از آنجایی که این ارزان‌ترین روش قبل از EIP-4844 بود، این روشی است که برای ذخیره اطلاعات تراکنش استفاده می‌شود، که باید برای [چالش‌های خطا] در دسترس باشد (https://docs.optimism.io/stack/protocol/overview#(opens in a new tab) اثبات عیب)، اما نیازی به دسترسی مستقیم روی زنجیره نیست.

در اینجا آدرس هایی برای مشاهده تراکنش های ارسال شده توسط چند مجموعه معروف وجود دارد.

رول‌‌آپآدرس Mailbox
Optimism(opens in a new tab)0xFF00000000000000000000000000000000000010(opens in a new tab)
Arbitrum(opens in a new tab)0x1c479675ad559DC151F6Ec7ed3FbF8ceE79582B6(opens in a new tab)
Base(opens in a new tab)0xFF00000000000000000000000000000000008453(opens in a new tab)

خارج از زنجیره با مکانیسم های لایه 1

بسته به دوراهی های امنیتی شما، ممکن است قابل قبول باشد که اطلاعات را در جای دیگری قرار دهید و از مکانیزمی استفاده کنید که تضمین کند داده ها در صورت نیاز در دسترس هستند. دو شرط برای این کار وجود دارد:

  1. یک [هش] (https://en.wikipedia.org/wiki/Cryptographic_hash_function(opens in a new tab)) از داده‌ها را روی بلاکین پست کنید، که به آن input commitment می‌گویند. این می تواند یک کلمه 32 بایتی باشد، بنابراین گران نیست. تا زمانی که تعهد ورودی در دسترس باشد، یکپارچگی تضمین می‌شود، زیرا یافتن داده‌های دیگری که به همان مقدار هش شوند امکان‌پذیر نیست. بنابراین اگر داده های نادرست ارائه شود، می توان آن را شناسایی کرد.

  2. مکانیزمی داشته باشید که در دسترس بودن را تضمین کند. برای مثال، در Redstone(opens in a new tab) هر گرهی می تواند یک چالش در دسترس بودن ارسال کند. اگر ترتیب‌دهنده در مهلت مقرر به زنجیره پاسخ ندهد، تعهد ورودی کنار گذاشته می‌شود، بنابراین در نظر گرفته می‌شود که اطلاعات هرگز پست نشده است.

این برای یک رول‌آپ خوش‌بینانه قابل قبول است زیرا ما در حال حاضر به داشتن حداقل یک تأیید کننده صادق برای ریشه حالت تکیه می کنیم. چنین تأیید کننده صادقی همچنین مطمئن می شود که داده هایی برای پردازش بلوک ها دارد و اگر اطلاعات در خارج از زنجیره در دسترس نباشد، چالش در دسترس بودن را صادر می کند. این نوع رول‌آپ خوش‌بینانه، پلاسما نامیده می‌شود.

کد قرارداد

اطلاعاتی که فقط باید یک بار نوشته شوند، هرگز بازنویسی نمی شوند و باید در زنجیره در دسترس باشند، می توانند به عنوان کد قرارداد ذخیره شوند. این بدان معنی است که ما یک "قرارداد هوشمند" با داده ها ایجاد می کنیم و سپس از EXTCODECOPY(opens in a new tab) برای خواندن اطلاعات استفاده می کنیم. مزیت این است که کپی کردن کد نسبتاً ارزان است.

به غیر از هزینه گسترش حافظه، «EXTCODECOPY» برای اولین دسترسی به قرارداد 2600 گس و برای نسخه های بعدی از همان قرارداد 100 گس به همراه 3 گس در هر کلمه 32 بایتی هزینه دارد. در مقایسه با calldata که 15.95 در هر بایت هزینه دارد، در آغاز حدود 200 بایت ارزان‌تر است. بر اساس [فرمول هزینه های گسترش حافظه] (https://www.evm.codes/about#memoryexpansion)،(opens in a new tab) تا زمانی که به بیش از 4 مگابایت حافظه نیاز ندارید، هزینه گسترش حافظه کمتر از هزینه افزودن calldata است.

البته این فقط هزینه خواندن داده هاست. برای ایجاد قرارداد تقریباً 32000 گس + 200 گس برای هر بایت هزینه می شود. این روش تنها زمانی مقرون به صرفه است که اطلاعات یکسان در معاملات مختلف بارها خوانده شود.

کد قرارداد تا زمانی که با '0xEF' شروع نشود می تواند بی معنی باشد. قراردادهایی که با «0xEF» شروع می‌شوند به عنوان [فرمت شی اتریوم] (https://notes.ethereum.org/@ipsilon/evm-object-format-overview(opens in a new tab)) تفسیر می‌شوند که الزامات بسیار سخت‌تری دارد.

رویدادها

[رویدادها] (https://docs.alchemy.com/docs/solidity-events(opens in a new tab)) توسط قراردادهای هوشمند منتشر می‌شوند و توسط نرم‌افزار خارج از زنجیره خوانده می‌شوند. مزیت آنها این است که کدهای آفلاین می توانند به رویدادها گوش دهند. هزینه [گس] (https://www.evm.codes/#a0?fork=cancun)،(opens in a new tab) 375 به اضافه 8 گس در هر بایت داده است. در 12 گیگاوی/گس و 2300 دلار/اتر، این به یک سنت به اضافه 22 سنت در هر کیلوبایت ترجمه می‌شود.

ذخیره‌سازی

قراردادهای هوشمند به [حافظه های دائمی] (https://docs.alchemy.com/docs/smart-contract-storage-layout#what-is-storage-memory(opens in a new tab)) دسترسی دارند. با این حال، بسیار گران است. نوشتن یک کلمه 32 بایتی در یک اسلات از حافظه که قبلاً خالی بود، می‌تواند [22100 گس هزینه داشته باشد] (https://www.evm.codes/#55?fork=cancun(opens in a new tab)). در 12 گیگاوی/گس و 2300 دلار/اتر،این حدود 61 سنت در هر عملیات نوشتن یا 19.5 دلار در هر کیلوبایت است.

این گران‌ترین شکل ذخیره‌سازی در اتریوم است.

خلاصه

این جدول تفاوت گزینه ها، مزایا و معایب آنها را خلاصه می کند.

نوع ذخیره‌سازیمنبع دیتاتضمین دسترسی‌پذیریدسترسی‌پذیری آنچینمحدودیت‌های دیگر
بلاب‌های EIP-4844آفچینضمانت اتریوم برای حدود 18 روز(opens in a new tab)فقط هش موجود است
داده‌ی فراخوانی (calldata)آفچینتضمین اتریوم برای همیشه (بخشی از بلاکچین)فقط در صورت نوشته شدن در قرارداد و در آن معامله در دسترس است
خارج از زنجیره ولی بهره گرفته از مکانیزم بلاک‌چین لایه 1آفچینتضمین "یک تایید کننده صادق" در طول دوره چالشفقط هشتضمین شده توسط مکانیسم چالش، فقط در طول دوره چالش
کد قراردادآنچین یا آفچینتضمین اتریوم برای همیشه (بخشی از بلاکچین)بلهنوشته شده در یک آدرس "تصادفی"، نمی تواند با "0xEF" شروع شود
رویدادهاآنچینتضمین اتریوم برای همیشه (بخشی از بلاکچین)خیر
ذخیره‌سازیآنچینتضمین اتریوم برای همیشه (بخشی از بلاکچین و وضعیت فعلی تا زمانی که بازنویسی شود)بله

آیا این مقاله مفید بود؟