یک بلاک (Block) در بلاکچین از چه اجزایی تشکیل شده است؟

یک بلاک (Block) در بلاکچین از چه اجزایی تشکیل شده است؟

فهرست مطالب

بلاکچین، فناوری‌ای که در پس ارزهای دیجیتالی مانند بیت‌کوین و اتریوم قرار دارد، انقلابی در نحوه ذخیره‌سازی و انتقال داده‌ها ایجاد کرده است. قلب این فناوری، بلاک است؛ یک بسته دیجیتالی که اطلاعات تراکنش‌ها را به صورت امن و غیرقابل تغییر در خود جای می‌دهد. اما یک بلاک واقعاً از چه چیزی ساخته شده است؟ درک اجزای داخلی یک بلاک برای فهم کامل امنیت، شفافیت و کارایی بلاکچین ضروری است.

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

آناتومی یک بلاک: دو بخش اصلی

هر بلاک در یک زنجیره بلوکی (Blockchain) را می‌توان به دو جزء اصلی و مجزا تقسیم کرد که هر یک وظایف حیاتی خود را بر عهده دارند:

  1. هدر بلاک (Block Header): این بخش مانند شناسنامه یا کارت هویت بلاک عمل می‌کند. هدر شامل فراداده‌های (Metadata) کلیدی است که بلاک را شناسایی کرده و آن را به بلاک قبلی در زنجیره متصل می‌کند. این اطلاعات برای فرآیندهای حیاتی مانند استخراج (Mining) و تأیید بلاک‌ها ضروری هستند.

  2. بدنه بلاک (Block Body): این بخش، محتوای اصلی بلاک یعنی لیستی از تمام تراکنش‌هایی که در آن بلاک گنجانده شده‌اند را در خود جای داده است. این تراکنش‌ها پیش از اضافه شدن به بلاک، توسط شبکه تأیید شده‌اند.

در ادامه، هر یک از این بخش‌ها و اجزای داخلی آن‌ها را با جزئیات کامل بررسی خواهیم کرد.

کالبدشکافی هدر بلاک (Block Header): شناسنامه دیجیتال بلاک

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

هش بلاک قبلی (Previous Block Hash)

این جزء، مهم‌ترین عنصری است که بلاک‌ها را به یکدیگر متصل کرده و زنجیره را تشکیل می‌دهد. هش بلاک قبلی، در واقع یک اثر انگشت دیجیتال منحصر به فرد از هدر بلاک پیشین است. با گنجاندن هش بلاک قبلی در هدر بلاک فعلی، یک پیوند رمزنگاری‌شده و ناگسستنی ایجاد می‌شود.

  • چرا این پیوند مهم است؟ اگر یک مهاجم تلاش کند تا اطلاعات یک تراکنش در یک بلاک قدیمی (مثلاً بلاک شماره ۱۰۰) را تغییر دهد، این تغییر باعث می‌شود هش آن بلاک (بلاک ۱۰۰) کاملاً عوض شود. از آنجایی که هش بلاک ۱۰۰ در هدر بلاک ۱۰۱ ذخیره شده است، این عدم تطابق فوراً شناسایی می‌شود و زنجیره از آن نقطه به بعد نامعتبر خواهد شد. برای معتبر کردن تغییر خود، مهاجم باید هش تمام بلاک‌های بعدی (۱۰۱، ۱۰۲، ۱۰۳ و...) را نیز مجدداً محاسبه کند که این کار به دلیل نیاز به توان محاسباتی عظیم، عملاً غیرممکن است. این مکانیزم، خاصیت تغییرناپذیری (Immutability) را برای بلاکچین به ارمغان می‌آورد.

مهر زمانی (Timestamp)

مهر زمانی یک عدد است که زمان تقریبی ایجاد بلاک را بر اساس استاندارد یونیکس (تعداد ثانیه‌های گذشته از ۱ ژانویه ۱۹۷۰) ثبت می‌کند. این داده توسط ماینری که بلاک را با موفقیت استخراج کرده، به آن اضافه می‌شود.

  • کاربرد مهر زمانی چیست؟

    • تنظیم سختی شبکه: بلاکچین‌ها (مانند بیت‌کوین) از مهر زمانی برای تنظیم سختی استخراج استفاده می‌کنند. به عنوان مثال، در شبکه بیت‌کوین، الگوریتم به گونه‌ای طراحی شده که به طور متوسط هر ۱۰ دقیقه یک بلاک جدید ایجاد شود. با بررسی مهرهای زمانی ۲۰۱۶ بلاک اخیر، شبکه می‌تواند تشخیص دهد که آیا سرعت ایجاد بلاک‌ها بیشتر یا کمتر از حد مطلوب بوده و بر اساس آن، سختی استخراج را برای ۲۰۱۶ بلاک بعدی تنظیم کند.

    • ایجاد ترتیب زمانی: مهر زمانی به تراکنش‌ها یک ترتیب زمانی مشخص می‌بخشد و تاریخچه قابل اعتمادی از وقایع شبکه را فراهم می‌کند.

نانس (Nonce)

واژه "Nonce" مخفف "number used only once" (عددی که فقط یک بار استفاده می‌شود) است. نانس یک عدد صحیح ۳۲ بیتی است که در فرآیند استخراج مبتنی بر اثبات کار (Proof of Work - PoW) نقشی حیاتی دارد. ماینرها برای استخراج یک بلاک، باید عددی را به نام نانس پیدا کنند که اگر همراه با سایر اطلاعات هدر، از طریق یک تابع هش (مانند SHA-256) پردازش شود، خروجی‌ای تولید کند که از یک مقدار مشخص (معروف به "هدف" یا Target) کوچکتر باشد.

  • فرآیند یافتن نانس: از آنجایی که خروجی توابع هش کاملاً غیرقابل پیش‌بینی است، ماینرها هیچ راهی جز آزمون و خطا ندارند. آن‌ها مقادیر مختلف نانس را (از صفر شروع کرده و یکی یکی بالا می‌روند) در هدر قرار می‌دهند و هر بار هش جدید را محاسبه می‌کنند. این فرآیند میلیون‌ها و حتی میلیاردها بار در ثانیه تکرار می‌شود تا زمانی که یک ماینر خوش‌شانس، نانس صحیح را پیدا کند. اولین ماینری که این معما را حل کند، حق اضافه کردن بلاک به زنجیره و دریافت پاداش (شامل کوین‌های جدید و کارمزد تراکنش‌ها) را به دست می‌آورد.

ریشه درخت مرکل (Merkle Root)

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

  • نحوه کار درخت مرکل:

    1. ابتدا هش هر تراکنش در بلاک به صورت جداگانه محاسبه می‌شود. این هش‌ها "برگ‌های" درخت را تشکیل می‌دهند.

    2. سپس، هر دو هش مجاور با هم ترکیب شده و دوباره هش آن‌ها محاسبه می‌شود تا "گره‌های" بالاتر درخت ایجاد شوند.

    3. این فرآیند به صورت بازگشتی ادامه می‌یابد تا در نهایت به یک هش واحد و نهایی برسیم. این هش نهایی، ریشه درخت مرکل (Merkle Root) نام دارد.

  • مزایای ریشه مرکل:

    • خلاصه‌سازی کارآمد: ریشه مرکل یک اثر انگشت دیجیتال منحصر به فرد از تمام تراکنش‌های موجود در بلاک است. این مقدار ۳۲ بایتی، به طور فشرده کل مجموعه تراکنش‌ها را نمایندگی می‌کند و در هدر بلاک قرار می‌گیرد.

    • تأیید سریع تراکنش (SPV): با استفاده از درخت مرکل، یک کاربر می‌تواند بدون نیاز به دانلود کل بلاکچین (که حجم آن صدها گیگابایت است)، به سرعت تأیید کند که آیا تراکنش مورد نظرش در یک بلاک خاص وجود دارد یا خیر. این فرآیند که به آن "تأیید پرداخت ساده" (Simple Payment Verification) می‌گویند، برای کیف پول‌های سبک (lightweight wallets) بسیار حیاتی است.

سایر اجزای هدر (مانند نسخه و بیت‌های سختی)

علاوه بر موارد فوق، هدر بلاک شامل چند فیلد دیگر نیز می‌شود:

  • نسخه (Version): عددی که نشان‌دهنده نسخه نرم‌افزار و قوانین اعتبارسنجی بلاک است. این فیلد به شبکه اجازه می‌دهد تا به‌روزرسانی‌ها و تغییرات پروتکل (مانند سافت فورک‌ها) را مدیریت کند.

  • بیت‌های سختی (Difficulty Bits): این مقدار، "هدف" (Target) سختی استخراج را به صورت فشرده نمایش می‌دهد. ماینرها باید هشی را پیدا کنند که مقدار عددی آن کمتر از این هدف باشد.

جزء هدر اندازه (در بیت‌کوین) وظیفه اصلی اهمیت
نسخه (Version) 4 بایت مشخص کردن قوانین اعتبارسنجی بلاک امکان به‌روزرسانی پروتکل
هش بلاک قبلی 32 بایت اتصال بلاک به بلاک قبلی در زنجیره تضمین یکپارچگی و تغییرناپذیری زنجیره
ریشه درخت مرکل 32 بایت خلاصه‌سازی و اثر انگشت تمام تراکنش‌ها تأیید سریع و کارآمد تراکنش‌ها (SPV)
مهر زمانی 4 بایت ثبت زمان تقریبی ایجاد بلاک تنظیم سختی شبکه و ایجاد ترتیب زمانی
بیت‌های سختی 4 بایت تعیین سختی استخراج بلاک (Target) کنترل نرخ تولید بلاک (تقریباً هر ۱۰ دقیقه)
نانس (Nonce) 4 بایت متغیر مورد استفاده در فرآیند اثبات کار کلید حل معمای محاسباتی برای استخراج بلاک
مجموع 80 بایت شناسنامه کامل و فشرده بلاک ستون فقرات امنیت و عملکرد بلاکچین

نگاهی به درون بدنه بلاک (Block Body): قلب تپنده تراکنش‌ها

بدنه بلاک، جایی است که داده‌های واقعی و ارزشمند، یعنی تراکنش‌ها، ذخیره می‌شوند. این بخش به مراتب بزرگتر از هدر است و می‌تواند تا چندین مگابایت حجم داشته باشد (بسته به پروتکل بلاکچین).

شمارنده تراکنش (Transaction Counter)

در ابتدای بدنه بلاک، یک شمارنده قرار دارد که تعداد کل تراکنش‌های موجود در آن بلاک را مشخص می‌کند. این عدد به نرم‌افزارها و نودها کمک می‌کند تا بدانند چه مقدار داده باید از بدنه بلاک بخوانند و پردازش کنند.

لیست تراکنش‌ها (List of Transactions)

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

  • ورودی‌ها (Inputs): آدرس‌هایی که کوین از آن‌ها ارسال می‌شود. ورودی‌ها در واقع به خروجی‌های خرج‌نشده (UTXO) از تراکنش‌های قبلی اشاره دارند.

  • خروجی‌ها (Outputs): آدرس‌هایی که کوین به آن‌ها دریافت می‌شود، همراه با مقدار دقیق هر کدام.

  • امضای دیجیتال (Digital Signature): هر ورودی باید با کلید خصوصی (Private Key) مالک آن آدرس امضا شود. این امضا اثبات می‌کند که فرستنده واقعاً مالک کوین‌ها بوده و مجاز به خرج کردن آن‌هاست.

نکته مهم: اولین تراکنش در هر بلاک، یک تراکنش ویژه به نام تراکنش کوین‌بیس (Coinbase Transaction) است. این تراکنش هیچ ورودی ندارد و توسط ماینر برای پاداش دادن به خودش ایجاد می‌شود. خروجی این تراکنش، شامل کوین‌های جدیدی است که به عنوان پاداش استخراج (Block Reward) ایجاد شده‌اند، به علاوه مجموع کارمزد تمام تراکنش‌های دیگر موجود در آن بلاک.

بلاک چگونه ایجاد و به زنجیره اضافه می‌شود؟

اکنون که با تمام اجزای یک بلاک آشنا شدیم، بیایید فرآیند کامل ایجاد و پیوستن آن به بلاکچین را مرور کنیم:

  1. جمع‌آوری تراکنش‌ها: نودهای استخراج (ماینرها) به طور مداوم تراکنش‌های جدید و تأییدنشده را از شبکه جمع‌آوری کرده و در یک استخر حافظه موقت (Mempool) ذخیره می‌کنند.

  2. انتخاب تراکنش‌ها و ساخت بلاک: ماینر تراکنش‌ها را بر اساس اولویت (معمولاً آن‌هایی که کارمزد بالاتری دارند) از Mempool انتخاب کرده و بدنه بلاک کاندید خود را می‌سازد. سپس، ریشه درخت مرکل را برای این مجموعه از تراکنش‌ها محاسبه می‌کند.

  3. ساخت هدر بلاک: ماینر با استفاده از هش بلاک قبلی، ریشه مرکل، مهر زمانی و سایر اطلاعات، هدر بلاک کاندید را تشکیل می‌دهد.

  4. شروع رقابت استخراج (اثبات کار): ماینر شروع به تغییر مکرر مقدار "نانس" در هدر کرده و برای هر تغییر، هش کل هدر را محاسبه می‌کند. این کار تا زمانی ادامه می‌یابد که هشی پیدا شود که از مقدار "هدف" تعیین‌شده توسط شبکه کمتر باشد.

  5. اعلام بلاک جدید: به محض یافتن نانس صحیح، ماینر بلاک کامل (هدر و بدنه) را برای سایر نودهای شبکه ارسال می‌کند.

  6. تأیید توسط شبکه: سایر نودها بلاک دریافت‌شده را به سرعت بررسی می‌کنند. آن‌ها تأیید می‌کنند که:

    • هش بلاک معتبر و کمتر از هدف است.

    • تمام تراکنش‌های داخل آن معتبر و دارای امضای صحیح هستند.

    • بلاک به درستی به بلاک قبلی زنجیره متصل است.

  7. اضافه شدن به زنجیره: اگر بلاک توسط اکثریت نودها معتبر شناخته شود، آن‌ها آن را به نسخه محلی خود از بلاکچین اضافه می‌کنند. از این لحظه، بلاک به بخشی دائمی و تغییرناپذیر از تاریخچه شبکه تبدیل می‌شود.

نتیجه‌گیری: بلاک‌ها، آجرهای یک سازه انقلابی

یک بلاک در بلاکچین، بسیار بیشتر از یک لیست ساده از تراکنش‌هاست. این یک ساختار داده پیچیده و هوشمندانه است که با ترکیب رمزنگاری، نظریه بازی‌ها و مهندسی نرم‌افزار، سیستمی برای ثبت اطلاعات به شیوه‌ای امن، شفاف و غیرمتمرکز فراهم می‌کند. از هش بلاک قبلی که زنجیره‌ای ناگسستنی می‌سازد تا ریشه درخت مرکل که یکپارچگی هزاران تراکنش را تضمین می‌کند و نانس که امنیت شبکه را از طریق رقابت محاسباتی تأمین می‌کند، هر جزء با دقتی بی‌نظیر برای ایفای نقشی حیاتی طراحی شده است. درک عمیق این اجزا، کلید فهم قدرت و پتانسیل واقعی فناوری بلاکچین است.

سوالات متداول (FAQ)

بلاک جنسیس (Genesis Block) چیست و چه تفاوتی با سایر بلاک‌ها دارد؟

بلاک جنسیس اولین بلاک در هر بلاکچین است (بلاک شماره ۰). این بلاک منحصر به فرد است زیرا هیچ بلاک قبلی وجود ندارد که به آن اشاره کند؛ بنابراین، فیلد "هش بلاک قبلی" در هدر آن معمولاً با صفر یا یک مقدار قراردادی پر می‌شود. این بلاک به صورت دستی توسط توسعه‌دهندگان اولیه بلاکچین ایجاد می‌شود و نقطه شروع کل زنجیره است.

حجم یک بلاک چقدر است و آیا محدودیتی دارد؟

بله، حجم بلاک‌ها محدودیت دارد تا از رشد بی‌رویه بلاکچین و سخت شدن نگهداری آن برای نودها جلوگیری شود. در شبکه بیت‌کوین، حجم اولیه بلاک به ۱ مگابایت محدود بود. بعدها با معرفی سگویت (SegWit)، این محدودیت به صورت تئوری تا ۴ مگابایت (واحد وزنی) افزایش یافت. سایر بلاکچین‌ها مانند اتریوم از سیستمی به نام "Gas Limit" برای محدود کردن تعداد محاسبات و تراکنش‌های قابل گنجاندن در یک بلاک استفاده می‌کنند.

اگر دو ماینر تقریباً همزمان یک بلاک معتبر پیدا کنند چه اتفاقی می‌افتد؟

این وضعیت منجر به یک "انشعاب موقت" یا "فورک" (Fork) در زنجیره می‌شود. در این حالت، شبکه به طور موقت دارای دو زنجیره موازی خواهد بود. این مشکل به طور خودکار حل می‌شود: نودها کار بر روی اولین بلاکی که دریافت کرده‌اند را ادامه می‌دهند، اما زنجیره دیگر را نیز نگه می‌دارند. به محض اینکه بلاک بعدی بر روی یکی از این زنجیره‌ها ساخته شود، آن زنجیره طولانی‌تر شده و طبق "قانون بلندترین زنجیره" (Longest Chain Rule)، به عنوان زنجیره معتبر و اصلی پذیرفته می‌شود. بلاک موجود در زنجیره کوتاه‌تر "یتیم" (Orphaned) شده و تراکنش‌های آن به استخر حافظه بازگردانده می‌شوند تا در بلاک‌های بعدی گنجانده شوند.

آیا می‌توان اطلاعات درون یک بلاک را پس از اضافه شدن به زنجیره تغییر داد؟

تغییر اطلاعات یک بلاک پس از تأیید و اضافه شدن به زنجیره، عملاً غیرممکن است. همانطور که توضیح داده شد، هر تغییری، هرچند کوچک، در یک تراکنش باعث تغییر کامل هش آن بلاک می‌شود. این امر پیوند رمزنگاری‌شده با بلاک بعدی را می‌شکند و کل زنجیره را از آن نقطه به بعد نامعتبر می‌کند. برای معتبر کردن این تغییر، یک مهاجم باید نه تنها آن بلاک، بلکه تمام بلاک‌های بعدی را نیز مجدداً استخراج کند و در این رقابت محاسباتی از کل شبکه پیشی بگیرد که به آن حمله ۵۱ درصدی می‌گویند و نیاز به توان محاسباتی فوق‌العاده عظیمی دارد.

سوسن
سوسن نوبخت

من سوسن نوبخت هستم؛ نویسنده‌ای که عاشق مقایسه، تحلیل و ساده‌سازی اطلاعات برای کاربران است. تلاش می‌کنم هر موضوع پیچیده‌ای را شفاف، قابل‌فهم و کاربردی ارائه کنم تا انتخاب‌های بهتری داشته باشید.

دسته‌بندی‌ها و محصولات مرتبط
اشتراک‌گذاری:

نظرات کاربران