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

چرخاندن گره‌ی اتریوم خودتان

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

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

توجه داشته باشید که پس از ادغام، دو کلاینت برای اجرای یک گره اتریوم مورد نیاز است. یک کلاینت لایه اجرا (EL) و یک سرویس گیرنده لایه اجماع (CL). این صفحه، نحوه نصب، پیکربندی و اتصال این دو کلاینت برای اجرای یک گره اتریوم را نشان می دهد.

پیش‌نیازها

شما باید بدانید که گره‌ی اتریوم چیست و چرا ممکن است بخواهید یک کلاینت را اجرا کنید. این موضوع در گره‌ها و کلاینت‌ها بررسی شده است.

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

انتخاب یک رویکرد

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

این صفحه شما را از طریق این تصمیمات راهنمایی می کند و به شما کمک می کند تا مناسب ترین راه را برای اجرای نمونه اتریوم خود پیدا کنید.

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

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

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

هنگامی که گره در حال اجرا و همگام سازی است، شما آماده استفاده از آن هستید، اما مطمئن شوید که مراقب نگهداری آن هستید.

نصب کلاینت

محیط زیست و سخت‌افزار

محلی یا ابری

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

  • ابر
    • ارائه‌دهندگانْ زمان به‌کار (uptime) سرور بالا و آدرس‌های آی‌پی (IP) عمومی ثابت ارائه می‌دهند
    • گرفتن سرور اختصاصی یا مجازی ممکن است راحت‌تر از ساختن سرور شخصی باشد
    • بده‌بستان بر سر این است که به یک شخص ثالث - ارائه‌دهده‌ی سرور اعتماد کنیم
    • به دلیل اندازه‌ی حافظه‌ی لازم برای گره‌ی کامل، هزینه‌ی اجاره‌ی سرور ممکن است بالا باشد
  • سخت‌افزار شخصی
    • رویکرد بی‌اعتمادتر و حاکمیتی‌تر
    • سرمایه‌گذاری برای یک بار
    • امکان خرید ماشین‌های پیش‌پیکربندی‌شده
    • شما باید به‌طور فیزیکی دستگاه و شبکه را آماده، نگهداری و احتمالاً عیب‌یابی کنید

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

سخت‌افزار

با این حال، یک شبکه‌ی غیرمتمرکز و مقاوم در برابر سانسور نباید بر ارائه‌دهندگان ابری متکی باشد. در عوض، اجرای گره تان بر روی سخت‌افزار محلی خودتان برای اکوسیستم سالم تر است. تخمین‌ها(opens in a new tab) سهم بزرگی از گره‌های اجرا شده روی ابر را نشان می‌دهد که می‌تواند به یک نقطه شکست تبدیل شود.

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

استفاده از سخت افزار خودتان می تواند بسیار آسان باشد. بسیاری از گزینه های ساده و همچنین تنظیمات پیشرفته برای افراد فنی بیشتر وجود دارد. بنابراین بیایید به الزامات و ابزارهای اجرای کلاینت های اتریوم بر روی دستگاه شما نگاه کنیم.

الزامات

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

پیش از نصب هر کلاینتی مطمئن شوید که رایانه‌ی شما منابع لازم را برای اجرای آن دارد. در زیر می توانید الزامات حداقل و توصیه شده را بیابید.

گلوگاه سخت افزار شما بیشتر فضای دیسک است. همگام سازی بلاکچین اتریوم بسیار فشرده ورودی/خروجی است و به فضای زیادی نیاز دارد. بهتر است یک حافظه اس اس دی با صدها گیگابایت فضای خالی حتی پس از همگام سازی داشته باشید.

اندازه پایگاه داده و سرعت همگام سازی اولیه به مشتری انتخابی، پیکربندی و استراتژی همگام سازی بستگی دارد.

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

سیستم‌عامل

همه‌ی کلاینت‌ها از سیستم‌عامل‌های اصلی یعنی لینوکس، مک‌اواس و ویندوز پشتیبانی می‌کنند. این بدان معناست که می‌توانید گره‌ها را با سیستم‌عاملی (OS) که برای شما مناسب‌تر است، روی رایانه‌های رومیزی یا سرورهای معمولی اجرا کنید. مطمئن شوید که سیستم‌عامل شما به‌روز است تا از مشکلات احتمالی و آسیب‌پذیری‌های امنیتی جلوگیری شود.

الزامات حداقلی
  • پردازنده‌ با حداقل 2 هسته
  • 8 گیگ رم
  • 2 ترا SSD
  • پهنای باند حداقل 10 مگابیت بر ثانیه
مشخصات پیشنهادی
  • پردازنده‌ی سریع با حداقل 4 هسته
  • حداقل 16 گیگابایت رم
  • SSD سریع بالای 2 ترا
  • پهنای باند حداقل 25 مگابیت بر ثانیه

حالت همگام‌سازی و سرویس گیرنده‌ای که انتخاب می‌کنید بر فضای مورد نیاز تأثیر می‌گذارند، اما ما فضای دیسک مورد نیاز برای هر مشتری را در زیر تخمین زده‌ایم.

کلاینتاندازه دیسک (همگام سازی فوری)فضای حافظه (آرشیو کامل)
Besu800GB+12TB+
Erigonشامل نمی‌شود2.5TB+
Geth500GB+12TB+
Nethermind500GB+12TB+
Rethشامل نمی‌شود2.2TB+
  • توجه: Erigon و Reth همگام‌سازی فوری را ارائه نمی‌دهند، اما هرس کامل امکان‌پذیر است (حدود 2 ترا برای Erigon و حدود 1.2 ترا برای Reth)

برای کلاینت‌های اجماع، فضای مورد نیاز به پیاده‌سازی کلاینت و ویژگی‌های فعال (مثلاً جریمه‌کننده اعتبارسنج) نیز بستگی دارد، اما معمولاً با 200 گیگابایت دیگر مورد نیاز برای داده‌های بیکن محاسبه می‌شود. با تعداد زیادی اعتبارسنج، بار پهنای باند نیز افزایش می یابد. می‌توانید جزئیات مربوط به الزامات کلاینت اجماع را در این تحلیل بیابید(opens in a new tab).

راهکارهای عملی

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

اتریوم روی رایانه‌ی تک‌برد

یک راه آسان و ارزان برای اجرای یک گره اتریوم، استفاده از کامپیوتر تک بردی است، حتی با معماری ARM مانند Raspberry Pi. Ethereum on ARM(opens in a new tab) تصاویری با قابلیت اجرا و اجرای چندگانه مشتری را برای رزبری پای و دیگر بردهای ARM فراهم می‌کند.

دستگاه های کوچک، مقرون به صرفه و کارآمد مانند این ها برای اجرای یک گره در خانه ایده آل هستند، اما عملکرد محدود آنها را در نظر داشته باشید.

چرخاندن گره

راه‌اندازی واقعی کلاینت را می‌توان با راه‌اندازهای خودکار یا به صورت دستی انجام داد و مستقیماً نرم‌افزار کلاینت را راه‌اندازی کرد.

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

نصب با راهنما

چندین پروژه کاربرپسند قصد بهبود تجربه راه‌اندازی یک کلاینت را دارند. این لانچرها نصب و پیکربندی خودکار کلاینت را ارائه می‌کنند و برخی حتی یک رابط گرافیکی برای راه‌اندازی و نظارت بر کلاینت‌ها ارائه می‌دهند.

در زیر چند پروژه وجود دارد که می تواند به شما در نصب و کنترل کلاینت ها فقط با چند کلیک کمک کند:

راهنماب دستی نصب کلاینت

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

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

دریافت نرم‌افزار کلاینت

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

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

دستورالعمل‌های نصب هر کلاینت در اسنادی که در فهرست‌ کلاینت‌های فوق‌الذکر پیوند داده شده‌اند، ارائه شده است.

در اینجا صفحات انتشار کلاینت ها وجود دارد که می توانید باینری های از پیش ساخته شده آنها یا دستورالعمل های نصب را پیدا کنید:

کلاینت‌های اجرا

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

کلاینت‌های اجماع

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

آخرین استفاده از کلاینت شبکه را ببینید(opens in a new tab) و درباره تنوع کلاینت بیشتر بدانید.

تایید نرم افزار

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

توسعه دهندگان، باینری های منتشر شده را با کلیدهای PGP خود امضا می کنند تا بتوانید به صورت رمزنگاری تأیید کنید که دقیقاً نرم افزاری را که ایجاد کرده اند اجرا می کنید. شما فقط باید کلیدهای عمومی مورد استفاده توسعه دهندگان را به دست آورید که می توانند در صفحات انتشار کلاینت یا در اسناد یافت شوند. پس از دانلود نسخه کلاینت و امضای آن، می توانید از پیاده‌سازی PGP استفاده کنید، به عنوان مثال GnuPG(opens in a new tab) تا به راحتی آنها را تأیید کنید. آموزش تأیید نرم‌افزار منبع باز با استفاده از gpg در لینوکس(opens in a new tab) یا ویندوز/مک(opens in a new tab) را بررسی کنید.

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

1sha256sum teku-22.6.1.tar.gz
2
39b2f8c1f8d4dab0404ce70ea314ff4b3c77e9d27aff9d1e4c1933a5439767dde

نصب کلاینت

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

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

سایر گزینه های پیکربندی اولیه عبارتند از، به عنوان مثال. انتخاب یک شبکه - شبکه اصلی یا شبکه‌های آزمایشی، فعال کردن نقطه پایانی HTTP برای RPC یا WebSockets و غیره. شما می توانید تمام ویژگی ها و گزینه ها را در اسناد کلاینت بیابید. پیکربندی های مختلف کلاینت را می توان با اجرای کلاینت با پرچم های مربوطه به طور مستقیم در فایل CLI یا پیکربندی تنظیم کرد. هر کلاینت کمی متفاوت است. لطفاً برای جزئیات بیشتر در مورد گزینه های پیکربندی، همیشه به اسناد رسمی یا صفحه راهنمای آن مراجعه کنید.

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

نمونه هایی از اجرای کلاینت های اجرایی با پیکربندی اولیه را می توان در بخش بعدی یافت.

آغاز به‌کار کلاینت اجرا

قبل از راه‌اندازی نرم‌افزار کلاینت اتریوم، آخرین بررسی را انجام دهید که آیا محیط شما آماده است. برای مثال، مطمئن شوید که:

  • فضای دیسک کافی با توجه به شبکه انتخابی و حالت همگام سازی وجود دارد.
  • حافظه و پردازنده توسط برنامه‌های دیگر استفاده نمی‌شود.
  • سیستم عامل به آخرین نسخه آپدیت شده است.
  • سیستم زمان و تاریخ صحیح را دارد.
  • روتر و فایروال شما اتصالات را در پورت‌های شنونده (listening ports) می‌پذیرند. به طور پیش‌فرض کلاینت‌های اتریوم از یک پورت شنونده (TCP) و یک پورت یابنده (UDP) که هر دو به‌طور پیش‌فرض روی 30303 هستند استفاده می‌کنند.

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

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

کلاینت‌های اجرا و اجماع از طریق یک نقطه پایانی تأیید شده مشخص شده در Engine API(opens in a new tab) ارتباط برقرار می کنند. برای اتصال به یک کلاینت اجماع، کلاینت اجرا باید یک jwtsecret(opens in a new tab) در یک مسیر شناخته شده ایجاد کند. به دلایل امنیتی و پایداری، کلاینت‌ها باید روی یک ماشین اجرا شوند و هر دو کلاینت باید این مسیر را بدانند زیرا برای تأیید اعتبار یک اتصال RPC محلی بین آنها استفاده می‌شود. کلاینت اجرا همچنین باید یک پورت شنونده (listening port) برای APIهای تایید شده تعریف کند.

این نشانه به طور خودکار توسط نرم‌افزار کلاینت تولید می شود، اما در برخی موارد، ممکن است لازم باشد خودتان آن را انجام دهید. می‌توانید آن را با OpenSSL(opens in a new tab)تولید کنید:

1openssl rand -hex 32 > jwtsecret

اجرای یک کلاینت اجرا

این بخش شما را از طریق راه‌اندازی کلاینت های اجرا راهنمایی می کند. این فقط به عنوان نمونه ای از یک پیکربندی اولیه عمل می کند که کلاینت را با این تنظیمات شروع می‌کند:

  • شبکه ای را برای اتصال به شبکه اصلی در مثال های ما مشخص می کند
    • در عوض می‌توانید یکی از شبکه‌های آزمایشی را برای آزمایش اولیه تنظیمات خود انتخاب کنید
  • دایرکتوری داده را تعریف می کند، جایی که تمام داده ها از جمله بلاکچین در آن ذخیره می شود
    • مطمئن شوید که مسیر را با یک مسیر واقعی جایگزین کنید، به عنوان مثال به درایو خارجی شما اشاره می کند
  • رابط ها را برای برقراری ارتباط با کلاینت فعال می کند
    • از جمله JSON-RPC و Engine API برای ارتباط با کلاینت اجماع
  • مسیر jwtsecret را برای API احراز هویت شده تعریف می کند
    • مطمئن شوید که مسیر مثال را با یک مسیر واقعی جایگزین کنید که برای کلاینت‌ها قابل دسترسی باشد، مثلاً /tmp/jwtsecret

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

توجه داشته باشید که جریمه‌های معکوس \ در مثال ها فقط برای اهداف قالب بندی هستند. پرچم های پیکربندی را می توان در یک خط تعریف کرد.

اجرای Besu

این مثال Besu را در شبکه اصلی شروع می‌کند، داده‌های بلاکچین را در قالب پیش‌فرض در /data/ethereum ذخیره می‌کند، JSON-RPC و Engine RPC را برای اتصال کلاینت اجماع فعال می‌کند. Engine API با نشانه jwtsecret احراز هویت می شود و فقط تماس از localhost مجاز است.

1besu --network=mainnet \
2 --data-path=/data/ethereum \
3 --rpc-http-enabled=true \
4 --engine-rpc-enabled=true \
5 --engine-host-allowlist="*" \
6 --engine-jwt-enabled=true \
7 --engine-jwt-secret=/path/to/jwtsecret

Besu همچنین دارای یک گزینه لانچر است که یک سری سوالات را می پرسد و فایل پیکربندی را ایجاد می کند. لانچر تعاملی را با استفاده از موارد زیر اجرا کنید:

1besu --Xlauncher

اسناد Besu(opens in a new tab) حاوی گزینه‌های اضافی و جزئیات پیکربندی است.

اجرای Erigon

این مثال Erigon را در شبکه اصلی شروع می‌کند، داده‌های بلاکچین را در /data/ethereum ذخیره می‌کند، JSON-RPC را فعال می‌کند،تعیین می کند که چه فضاهای نامی مجاز است و احراز هویت را برای اتصال کلاینت اجماع که توسط مسیر jwtsecret تعریف می شود، فعال می کند.

1erigon --chain mainnet \
2 --datadir /data/ethereum \
3 --http --http.api=engine,eth,web3,net \
4 --authrpc.jwtsecret=/path/to/jwtsecret

Erigon به طور پیش فرض یک همگام سازی کامل را با 8 گیگابایت هارد دیسک انجام می دهد که منجر به بیش از 2 ترابایت داده آرشیو می شود. مطمئن شوید که datadir به دیسک با فضای خالی کافی اشاره می کند یا به پرچم --prune نگاه کنید که می تواند انواع مختلف داده را هرس کند. برای کسب اطلاعات بیشتر، --help مربوط به Erigon را بررسی کنید.

اجرای Geth

این مثال Geth را در شبکه اصلی شروع می‌کند، داده‌های بلاکچین را در /data/ethereum ذخیره می‌کند، JSON-RPC را فعال می‌کند و مشخص می‌کند که کدام فضاهای نام مجاز هستند. همچنین احراز هویت را برای اتصال کلاینت اجماع فعال می کند که به مسیر jwtsecret نیاز دارد و همچنین گزینه ای را که در مثال ما فقط از localhost مجاز است، تعیین می کند.

1geth --mainnet \
2 --datadir "/data/ethereum" \
3 --http --authrpc.addr localhost \
4 --authrpc.vhosts="localhost" \
5 --authrpc.port 8551
6 --authrpc.jwtsecret=/path/to/jwtsecret

اسناد برای همه گزینه‌های پیکربندی(opens in a new tab) را بررسی کنید و درباره اجرای Geth با یک کلاینت اجماع(opens in a new tab) بیشتر بدانید.

اجرای Nethermind

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

1Nethermind.Runner --config mainnet \
2 --datadir /data/ethereum \
3 --JsonRpc.JwtSecretFile=/path/to/jwtsecret

اسناد Nethermind یک راهنمای کامل(opens in a new tab) در مورد اجرای Nethermind با کلاینت اجماع ارائه می دهد.

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

اجرای Reth

این مثال با استفاده از موقعیت مکانی داده پیش فرض، Reth را در شبکه اصلی شروع می کند. احراز هویت JSON-RPC و Engine RPC را برای اتصال کلاینت اجماع که توسط مسیر jwtsecret تعریف شده است، فعال می کند و فقط تماس از localhost مجاز است.

1reth node \
2 --authrpc.jwtsecret /path/to/jwtsecret \
3 --authrpc.addr 127.0.0.1 \
4 --authrpc.port 8551

برای اطلاعات بیشتر در مورد دایرکتوری های داده پیش فرض داده، به پیکربندی Reth(opens in a new tab) مراجعه کنید. اسناد Reth(opens in a new tab) حاوی گزینه‌های اضافی و جزئیات پیکربندی است.

آغاز به‌کار کلاینت اجماع

کلاینت اجماع باید با پیکربندی پورت مناسب شروع شود تا یک اتصال RPC محلی به کلاینت اجرا برقرار شود. کلاینت های اجماع باید با پورت کلاینت اجرای در معرض، به عنوان آرگومان پیکربندی اجرا شوند.

کلاینت اجماع همچنین به مسیر jwt-secret کلاینت اجرا نیاز دارد تا بتواند ارتباط RPC بین آنها را تأیید کند. مشابه مثال‌های اجرایی بالا، هر کلاینت اجماع یک پرچم پیکربندی دارد که مسیر فایل توکن jwt را به عنوان آرگومان می‌گیرد. این مسیر باید با مسیر jwtsecret ارائه‌شده به کلاینت اجرا مطابقت داشته باشد.

اگر قصد دارید یک اعتبارسنج را اجرا کنید، مطمئن شوید که یک پرچم پیکربندی که آدرس اتریوم گیرنده کارمزد را مشخص می‌کند، اضافه کنید. اینجاست که پاداش‌های اتر برای اعتبارسنج شما جمع می‌شوند. هر کلاینت اجماع یک گزینه دارد، مثلاً --suggested-fee-recipient=0xabcd1، که آدرس اتریوم را به عنوان آرگومان می گیرد.

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

اجرای یک کلاینت اجماع

اجرای Lighthouse

قبل از اجرای Lighthouse، در Lighthouse Book(opens in a new tab) درباره نحوه نصب و پیکربندی آن بیشتر بیاموزید.

1lighthouse beacon_node \
2 --network mainnet \
3 --datadir /data/ethereum \
4 --http \
5 --execution-endpoint http://127.0.0.1:8551 \
6 --execution-jwt /path/to/jwtsecret
اجرای Lodestar

نرم‌افزار Lodestar را با کامپایل یا دانلود تصویر داکر نصب کنید. در اسناد(opens in a new tab) و جامع تر در راهنمای راه اندازی(opens in a new tab) بیشتر بیاموزید.

1lodestar beacon \
2 --rootDir="/data/ethereum" \
3 --network=mainnet \
4 --eth1.enabled=true \
5 --execution.urls="http://127.0.0.1:8551" \
6 --jwt-secret="/path/to/jwtsecret"
اجرای Nimbus

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

1nimbus_beacon_node \
2 --network=mainnet \
3 --web3-url=http://127.0.0.1:8551 \
4 --rest \
5 --jwt-secret="/path/to/jwtsecret"
اجرای Prysm

Prysm همراه با اسکریپت است که امکان نصب خودکار آسان را فراهم می کند. جزئیات را می توان در اسناد Prysm(opens in a new tab) پیدا کرد.

1./prysm.sh beacon-chain \
2 --mainnet \
3 --datadir /data/ethereum \
4 --execution-endpoint=http://localhost:8551 \
5 --jwt-secret=/path/to/jwtsecret
اجرای Teku
1teku --network mainnet \
2 --data-path "/data/ethereum" \
3 --ee-endpoint http://localhost:8551 \
4 --ee-jwt-secret-file "/path/to/jwtsecret"

هنگامی که یک کلاینت اجماع برای خواندن قرارداد سپرده و شناسایی اعتبارسنج‌ها به کلاینت اجرا متصل می شود، به سایر همتایان بیکن‌نود نیز متصل می شود و شروع به همگام سازی اسلات های اجماع از زمان پیدایش می کند. هنگامی که Beacon Node به دوره فعلی رسید، Beacon API برای اعتبارسنج شما قابل استفاده می شود. درباره API های Beacon Node(opens in a new tab) بیشتر بیاموزید.

افزودن اعتبارسنج‌ها

یک کلاینت اجماع به عنوان یک Beacon Node برای اعتبارسنج‌ها برای اتصال عمل می کند. هر کلاینت اجماع دارای نرم‌افزار اعتبارسنج مخصوص به خود است که در مستندات مربوطه به تفصیل شرح داده شده است.

اجرای اعتبارسنج خود اجازه‌ی سهامگذاری انفرادی، موثرترین و بی اعتمادترین روش برای پشتیبانی از شبکه اتریوم را می‌دهد. بااین‌حال، نیاز به سپرده‌گذاری 32 اتر دارد. برای اجرای یک اعتبارسنج بر روی گره خود با مقدار کمتر، ممکن است یک استخر غیرمتمرکز با عملگرهای گره بدون مجوز، مانند Rocket Pool(opens in a new tab) مورد علاقه شما باشد.

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

برای مروری بر گزینه های سهامگذاری به صفحه سهامگذاری نگاه کنید.

استفاده کردن از گره

کلاینت‌های اجرا نقاط پایانی RPC API را ارائه می‌کنند که می‌توانید از آنها برای ارسال تراکنش‌ها، تعامل با قراردادهای هوشمند یا استقرار آنها در شبکه اتریوم به روش‌های مختلف استفاده کنید:

کلاینت‌های مختلف پیاده‌سازی‌های مختلفی برای نقاط پایانی RPC دارند. اما برای JSON-RPC استانداردی وجود دارد که می‌توانید برای هر کلاینتی استفاده نمایید. برای مروری اجمالی، مستندات JSON-RPC را بخوانید. برنامه‌های کاربردی که نیاز به اطلاعات از شبکه‌ی اتریوم دارند می‌توانند از RPC استفاده کنند. به عنوان مثال، کیف پول محبوب متامسک به شما امکان می دهد به نقطه پایانی RPC خود متصل شوید(opens in a new tab) که دارای مزایای امنیتی و حریم خصوصی قوی است.

کلاینت‌های اجماع همگی یک API بیکن(opens in a new tab) را در معرض نمایش می‌گذارند که می‌تواند با ارسال درخواست با استفاده از ابزارهایی مانند Curl(opens in a new tab) برای بررسی وضعیت کلاینت اجماع یا بارگیری کردن بلوک‌ها و داده‌های اجماع استفاده شود. اطلاعات بیشتر در این مورد را می‌توان در اسناد مربوط به هر کلاینت اجماع یافت.

دستیابی به RPC

درگاه پیش‌فرض برای اجرای برنامه JSON-RPC 8545 است اما می‌توانید پورت‌های نقاط انتهایی محلی را در پیکربندی تغییر دهید. در حالت پیش‌فرض، رابط RPC فقط در هاست محلی (localhost) رایانه‌ی شما قابل دسترسی است. برای اینکه بتوانید از راه دور به آن دسترسی داشته باشید، می‌توانید با تغییر آدرس به 0.0.0.0 آن را در معرض دید عموم قرار دهید. این باعث می شود که از طریق شبکه محلی و آدرس های IP عمومی قابل دسترسی باشد. در بیشتر موارد، باید روی روتر خود باز ارسالی پورت (port forwarding) را هم تنظیم کنید.

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

راه‌حل این مشکل، جلوگیری از تغییرپذیری روش‌های بالقوه خطرناک RPC است. برای مثال، با Geth، می‌توانید روش‌های اصلاح‌پذیر را با یک پرچم اعلام کنید: ‎--http.api web3,eth,txpool.

دسترسی به رابط RPC را می توان از طریق توسعه APIهای لایه لبه یا برنامه های کاربردی وب سرور، مانند Nginx، و اتصال آنها به آدرس محلی و پورت کلاینت خود گسترش داد. استفاده از یک لایه میانی همچنین می‌تواند به توسعه‌دهندگان این امکان را بدهد که گواهی را برای اتصالات https ایمن به رابط RPC تنظیم کنند.

راه‌اندازی یک وب سرور، یک پروکسی یا Rest API روبه‌ خارج تنها راه برای دسترسی به نقطه پایانی RPC گره شما نیست. یکی دیگر از راه‌های حفظ حریم خصوصی برای تنظیم یک نقطه پایانی قابل دسترسی عمومی، میزبانی گره در سرویس پیاز Tor(opens in a new tab) خودتان است. بدین ترتیب می‌توانید به RPC خارج از شبکه‌ی محلی خود بدون آدرس آی‌پی (IP) عمومی ثابت یا پورت‌های باز شده دسترسی پیدا کنید. با این حال، استفاده از این پیکربندی ممکن است تنها به نقطه پایانی RPC اجازه دهد که از طریق شبکه Tor که توسط همه برنامه‌ها پشتیبانی نمی‌شود و ممکن است منجر به مشکلات اتصال شود، قابل دسترسی باشد.

برای انجام این کار، باید سرویس onion(opens in a new tab) خود را ایجاد کنید. اسناد(opens in a new tab) راه‌اندازی سرویس پیاز را برای هاست خود بررسی کنید. می توانید آن را به یک وب سرور با پروکسی به درگاه RPC یا فقط مستقیماً به RPC اشاره کنید.

در نهایت، و یکی از محبوب ترین راه ها برای دسترسی به شبکه های داخلی از طریق اتصال VPN است. بسته به مورد استفاده شما و تعداد کاربرانی که نیاز به دسترسی به گره شما دارند، یک اتصال VPN ایمن ممکن است یک گزینه باشد. OpenVPN(opens in a new tab) یک SSL VPN با امکانات کامل است که برنامه افزودنی شبکه ایمن لایه دوم یا سوم OSI را با استفاده از پروتکل استاندارد صنعتی SSL/TLS پیاده‌سازی می‌کند، از روش‌های تأیید اعتبار کلاینت انعطاف‌پذیر بر اساس گواهی‌ها، کارت‌های هوشمند و/یا نام کاربری پشتیبانی می‌کند، نام کاربری/رمز را ارائه می دهد و به سیاست های کنترل دسترسی خاص کاربر یا گروه با استفاده از قوانین فایروال اعمال شده در رابط مجازی VPN اجازه کار می دهد.

استفاده از گره

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

آنلاین نگه‌داشتن گره

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

  • اگر وضعیت اخیر همچنان روی دیسک نوشته می شود، خاموش شدن می تواند چند دقیقه طول بکشد.
  • خاموش شدن اجباری می تواند به دیتابیس آسیب برساند و شما را ملزم به همگام سازی مجدد کل گره کند.
  • کلاینت شما با شبکه همگام نمی شود و با راه اندازی مجدد باید مجدداً همگام شود. در حالی که گره می تواند از زمانی که آخرین خاموش شده بود همگام سازی را آغاز کند، بسته به مدت زمانی که آفلاین بوده است، فرآیند ممکن است زمان ببرد.

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

ساختن سرویس‌های کلاینت

ساختن سرویسی را برای اجرای خودکار کلاینت‌های خود در هنگام راه‌اندازی در نظر بگیرید. به عنوان مثال، در سرورهای لینوکس، بهترین رویه ایجاد یک سرویس است، به عنوان مثال با systemd، که کلاینت را با پیکربندی مناسب، تحت یک کاربر با امتیازات محدود اجرا می کند و به طور خودکار ریستارت می شود.

به‌روزرسانی کلاینت‌ها

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

قبل از به‌روزرسانی‌های مهم شبکه، EF یک پست را در وبلاگ(opens in a new tab) خود منتشر می‌کند. می‌توانید مشترک این اعلامیه‌ها شوید(opens in a new tab) تا زمانی که گره شما نیاز به بروزرسانی دارد، اعلان را در ایمیل خود دریافت کنید.

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

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

اجرای سرویس‌های اضافه

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

نظارت بر گره

برای نظارت صحیح بر گره خود، معیارهای تجمعی را در نظر بگیرید. کلاینت‌ها نقاط پایانی معیارها را ارائه می‌کنند تا بتوانید داده‌های جامعی درباره گره خود دریافت کنید. از ابزارهایی مثل InfluxDB(opens in a new tab) یا Prometheus(opens in a new tab) برای ساخت پایگاه داده‌هایی استفاده کنید که می‌توانید با استفاده از نرم‌افزارهایی مثل Grafana(opens in a new tab) آن‌ها را تبدیل به بازنمایی بصری و نمودار کنید. تنظیمات زیادی برای استفاده از این نرم‌افزار و داشبوردهای مختلف Grafana وجود دارد تا بتوانید گره‌ خود و شبکه را کاملاً به شکل بصری بازنمایی کنید. برای مثال، آموزش نظارت بر Geth را بررسی کنید.

به‌عنوان بخشی از نظارت خود، مطمئن شوید که عملکرد دستگاه خود را زیر نظر داشته باشید. در طول همگام‌‌سازی اولیه‌ی گره شما، ممکن است نرم‌افزار کلاینت برای پردازنده و رم بسیار سنگین باشد. علاوه بر Grafana می‌توانید از ابزارهایی که سیستم‌عاملتان به شما ارائه می‌دهد، مثل htop یا uptime، برای این کار استفاده کنید.

بیشتر بخوانید

  • گره‌ها و کاربرها
  • بلوک‌ها
  • شبکه‌ها

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