مقالات

راهنمای جامع نصب و پیکربندی افزونه Bunny.net در وردپرس (افزایش سرعت سایت)

راهنمای جامع نصب و پیکربندی افزونه Bunny.net در وردپرس (افزایش سرعت سایت)

درود بر شما. من محمد صدرا حسینی هستم، کارشناس سئو در مجموعه وزیر سئو.

دستیابی به امتیازات بالا در شاخص‌های حیاتی وب (Core Web Vitals) مستلزم یک زیرساخت فنی بهینه است. در این میان، پیاده‌سازی صحیح یک شبکه توزیع محتوا (CDN) نقشی تعیین‌کننده در کاهش زمان بارگذاری (Latency) و بهبود تجربه کاربری (UX) دارد.

سرویس Bunny.net به دلیل کارایی بالا (High Performance) و هزینه مقرون‌به‌صرفه، یک راه‌حل استراتژیک در بهینه‌سازی فنی (Technical SEO) محسوب می‌شود. با این حال، موفقیت در این امر، نیازمند پیکربندی دقیق و بدون خطاست؛ نصب اشتباه می‌تواند منجر به بروز خطاهای 404 یا مشکلات CORS شده و اعتبار سایت شما را مخدوش کند.

در این راهنمای نصب Bunny.net، ما به صورت مرحله‌به‌مرحله و کاملاً نتیجه‌محور، تمام فرایند از ساخت Pull Zone تا عیب‌یابی خطاهای رایج را پوشش خواهیم داد تا شما بتوانید این زیرساخت حیاتی را با اطمینان کامل پیاده‌سازی نمایید.

جدول کاربردی: نقشه راه پیاده‌سازی

این جدول، چکیده‌ای از مراحلی است که در این راهنما طی خواهید کرد و هدف استراتژیک هر مرحله را روشن می‌سازد.

مرحله (Stage) هدف کلیدی (Key Objective) اهمیت استراتژیک (Strategic Importance)
۱. پیش‌نیازها ساخت Pull Zone و دریافت API Key اطمینان از آمادگی زیرساخت CDN در داشبورد Bunny.net قبل از هرگونه اقدام در وردپرس.
۲. نصب و اتصال نصب افزونه رسمی در وردپرس و ورود اطلاعات برقراری ارتباط فنی امن و احراز هویت شده بین وب‌سایت و سرویس CDN.
۳. پیکربندی پیشرفته فعال‌سازی Perma-Cache، بهینه‌سازی WebP و تنظیم CNAME بهینه‌سازی حداکثری فایل‌ها برای کاهش حجم و افزایش «نرخ برخورد کش» (Cache Hit Ratio).
۴. اعتبارسنجی و عیب‌یابی تست سورس کد، بررسی هدرها و رفع خطاهای رایج (CORS/404) تضمین عملکرد صحیح CDN، جلوگیری از اختلال در تجربه کاربری و اطمینان از بازنویسی URLها.

چرا باید از CDN و افزونه رسمی Bunny.net استفاده کنیم؟

استفاده از CDN یک اقدام زیرساختی برای سئوی فنی (Technical SEO) است. زمانی که کاربری از موقعیت جغرافیایی دور از سرور اصلی شما (Origin Server) به سایت مراجعه می‌کند، CDN محتوای استاتیک (تصاویر، فایل‌های CSS و JavaScript) را از نزدیک‌ترین سرور لبه (Edge Server) به او تحویل می‌دهد.

این فرایند به طور چشمگیری زمان رفت و برگشت (RTT) و در نتیجه، شاخص‌های حیاتی وب (Core Web Vitals) مانند LCP (Largest Contentful Paint) را بهبود می‌بخشد. اما چالش اصلی، ادغام (Integration) صحیح CDN با وردپرس است. افزونه Bunny.net این چالش فنی را به یک فرایند مدیریت‌شده و بهینه تبدیل می‌کند.

Bunny.net CDN چیست و چگونه سرعت سایت وردپرسی شما را متحول می‌کند؟

Bunny.net یک سرویس CDN پیشرو است که به دلیل عملکرد بسیار بالا (High Performance) و هزینه مقرون‌به‌صرفه شناخته می‌شود. این سرویس، فایل‌های سنگین و ثابت وب‌سایت وردپرسی شما را کپی کرده و در ده‌ها «پاپ‌سایت» (PoP – Point of Presence) در سراسر جهان ذخیره می‌کند.

زمانی که کاربر سایت شما را باز می‌کند، به جای دریافت فایل‌ها از سرور اصلی (مثلاً در آلمان)، آن‌ها را از نزدیک‌ترین سرور فیزیکی (مثلاً در تهران یا دبی) دریافت می‌کند. این اقدام، «تأخیر شبکه» (Network Latency) را به حداقل رسانده و زمان بارگذاری اولیه یا TTFB (Time to First Byte) را به شکل محسوسی کاهش می‌دهد.

مزایای کلیدی استفاده از افزونه «رسمی» Bunny.net (مقایسه با روش‌های دستی)

بسیاری از متخصصان تازه‌کار تلاش می‌کنند CDN را به صورت دستی یا از طریق افزونه‌های کش (مانند WP Rocket یا LiteSpeed Cache) متصل کنند. اگرچه این روش‌ها ممکن است کار کنند، اما افزونه رسمی (Official Plugin) مزایای استراتژیک دقیقی را ارائه می‌دهد که برای یک نتیجه حرفه‌ای ضروری است:

  • بازنویسی خودکار URLها (Automatic URL Rewriting): این مهم‌ترین مزیت است. افزونه به طور خودکار تمامی آدرس‌های فایل‌های استاتیک شما (مثل com/image.jpg) را به آدرس CDN (مثل cdn.yourdomain.com/image.jpg) تغییر می‌دهد. انجام دستی این کار در وردپرس پیچیده و مستعد خطا است.
  • ادغام یکپارچه و بهینه (Seamless Integration): افزونه رسمی دقیقاً می‌داند که کدام فایل‌ها باید توسط CDN ارائه شوند و کدام فایل‌ها نباید کش شوند. این تنظیمات پیش‌فرض، از بروز خطاهای رایج (مانند مشکلات CORS یا بارگذاری نشدن فونت‌ها) جلوگیری می‌کند.
  • مدیریت آسان پاکسازی کش (Cache Purging): زمانی که شما یک تصویر را در وردپرس به‌روزرسانی می‌کنید، افزونه به طور خودکار نسخه قدیمی آن را از سرورهای CDN در سراسر جهان پاک می‌کند (Cache Purge). این تضمین می‌کند که کاربران همیشه آخرین نسخه فایل‌ها را می‌بینند.
  • امنیت و پایداری: افزونه رسمی مستقیماً توسط تیمnet توسعه یافته و پشتیبانی می‌شود. این به معنای سازگاری کامل با به‌روزرسانی‌های آینده وردپرس و خود سرویس CDN است.

آیا این افزونه جایگزین افزونه‌های کش (Cache) می‌شود؟

یک تصور اشتباه رایج این است که CDN جایگزین افزونه کش می‌شود. پاسخ کوتاه: خیر.

این دو ابزار مکمل یکدیگرند و اهداف متفاوتی دارند:

  1. افزونه کش (مانند WP Rocket یا LiteSpeed): در سرور اصلی شما کار می‌کند. وظیفه آن ایجاد نسخه‌های HTML استاتیک از صفحات داینامیک وردپرس است تا پردازش PHP و کوئری‌های دیتابیس کاهش یابد. این کار TTFB را بهینه می‌کند.
  2. افزونهnet CDN: در لبه شبکه (Edge) کار می‌کند. وظیفه آن تحویل سریع فایل‌های استاتیک (تصاویر، CSS, JS) به کاربر نهایی از نزدیک‌ترین موقعیت جغرافیایی است.

استراتژی بهینه (Quick Win): شما باید همزمان از یک افزونه کش قدرتمند (برای بهینه‌سازی سرور) و افزونه رسمی Bunny.net (برای بهینه‌سازی تحویل محتوا) استفاده کنید. افزونه Bunny.net جایگزین بخش CDN در افزونه‌های کش می‌شود و این کار را به شکل تخصصی‌تری انجام می‌دهد.

یک اقدام ضروری برای سئوی فنی

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

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

 

پیش‌نیازهای حیاتی: آماده‌سازی قبل از نصب افزونه

لطفاً این چهار گام را به دقت در وب‌سایت Bunny.net دنبال کنید.

گام ۱: ساخت حساب کاربری در وب‌سایت Bunny.net

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

گام ۲: ایجاد Pull Zone (منطقه کشش) در داشبورد Bunny

این مهم‌ترین بخش پیکربندی در سمت سرویس CDN است. “Pull Zone” (منطقه کشش) در واقع مجموعه‌ای از تنظیمات است که به سرورهای Bunny.net اطلاع می‌دهد فایل‌های وب‌سایت شما دقیقاً در کجا قرار دارند (سرور مبدأ) و چگونه باید آن‌ها را ذخیره (کش) و در سراسر جهان توزیع کند.

نحوه ایجاد Pull Zone:

  1. پس از ورود به داشبوردnet، به بخش “Pull Zones” بروید.
  2. گزینه “Add Pull Zone” را انتخاب کنید.
  3. Name (نام): یک نام منحصربه‌فرد برای این منطقه انتخاب کنید (مثلاً my-site-name). این نام، بخشی از آدرس CDN پیش‌فرض شما خواهد بود (مانند my-site-name.b-cdn.net).
  4. Origin URL (آدرس مبدأ): آدرس کامل و دقیق وب‌سایت وردپرسی خود را وارد کنید (مثلاً https://yourdomain.com). این همان سروری است که Bunny فایل‌های استاتیک را از آن “می‌کشد” (Pull).
  5. سایر تنظیمات مانند “Pricing Tier” (سطح قیمت‌گذاری) و “Geo-Replication” (مناطق جغرافیایی توزیع) را بر اساس نیاز خود انتخاب و Pull Zone را ایجاد کنید.

گام ۳: یافتن و کپی کردن کلید API (API Key) حساب کاربری

افزونه وردپرسی برای برقراری ارتباط امن با حساب Bunny.net شما و انجام عملیات مدیریتی (مانند پاکسازی خودکار کش یا Automatic Cache Purging) به یک کلید احراز هویت نیاز دارد. این کلید، “API Key” حساب شما است.

نحوه یافتن کلید API:

  1. در داشبوردnet، روی نام کاربری خود کلیک کرده و به بخش تنظیمات حساب (Account Settings) بروید.
  2. در این صفحه، قسمتی مربوط به API یا “Security” وجود دارد.
  3. کلید API (API Key) خود را پیدا کرده و آن را کپی کنید. این یک رشته طولانی و محرمانه از حروف و اعداد است. آن را در مکانی امن ذخیره کنید، زیرا در مرحله نصب افزونه در وردپرس به آن نیاز فوری خواهیم داشت.

گام ۴: (اختیاری اما پیشنهادی) تنظیم CNAME سفارشی

اگرچه شما می‌توانید مستقیماً از آدرسی که Bunny ارائه می‌دهد (مانند my-site-name.b-cdn.net) استفاده کنید، اما از دیدگاه سئو و برندینگ، اکیداً توصیه می‌شود که یک “Hostname” یا CNAME سفارشی برای دامنه خودتان تنظیم کنید.

دلایل اهمیت این اقدام:

  • اعتبار و برندینگ (E-E-A-T): استفاده از آدرسی مانند yourdomain.com بسیار حرفه‌ای‌تر است و سیگنال اعتماد (Trust) قوی‌تری به کاربران و موتورهای جستجو ارسال می‌کند.
  • انعطاف‌پذیری آینده: اگر زمانی تصمیم به تغییر ارائه‌دهنده CDN خود بگیرید، کافی است این رکورد CNAME را در تنظیمات DNS خود به‌روزرسانی کنید، بدون اینکه نیازی به تغییر تنظیمات در وب‌سایت وردپرس باشد.

نحوه تنظیم CNAME:

  1. به پنل مدیریت DNS دامنه خود مراجعه کنید (این پنل معمولاً در شرکت ارائه‌دهنده هاست یا دامنه شما، یا در سرویس‌هایی مانند Cloudflare قرار دارد).
  2. یک رکورد جدید از نوع CNAME ایجاد کنید.
  3. در فیلد “Name” (یا Host)، زیردامنه دلخواه خود را وارد کنید (مثلاً cdn).
  4. در فیلد “Target” (یا Value/Content)، آدرس Pull Zone خود در Bunny را وارد کنید (مثلاً my-site-name.b-cdn.net).
  5. رکورد را ذخیره کنید. (توجه: اعمال تغییرات DNS ممکن است از چند دقیقه تا چند ساعت زمان ببرد).

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

 

راهنمای گام به گام نصب افزونه Bunny.net در وردپرس

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

نصب مستقیم از طریق مخزن وردپرس (آسان‌ترین روش)

  1. ورود به پیشخوان وردپرس: ابتدا وارد داشبورد مدیریت وب‌سایت وردپرسی خود شوید.
  2. مراجعه به بخش افزونه‌ها: از منوی سمت راست، روی گزینه «افزونه‌ها» (Plugins) بروید و سپس «افزودن» (Add New) را کلیک کنید.
  3. جستجوی افزونه: در کادر جستجوی افزونه‌ها (در گوشه بالا سمت چپ)، عبارت دقیق “net CDN” را جستجو کنید.
  4. شناسایی و نصب: افزونه رسمی معمولاً اولین نتیجه خواهد بود. مطمئن شوید که توسعه‌دهنده آن “BunnyWay” یا “Bunny.net” ذکر شده است. پس از اطمینان، روی دکمه «هم‌اکنون نصب کن» (Install Now) کلیک کنید.
  5. صبر برای نصب: وردپرس به صورت خودکار افزونه را دانلود و نصب خواهد کرد. این فرایند ممکن است چند ثانیه طول بکشد.

فعال‌سازی و دسترسی به منوی تنظیمات افزونه

  1. فعال‌سازی (Activate): پس از اتمام نصب، دکمه «هم‌اکنون نصب کن» به دکمه «فعال کردن» (Activate) تغییر می‌کند. روی آن کلیک کنید.
  2. موفقیت‌آمیز بودن نصب: با فعال‌سازی موفق، شما به لیست تمام افزونه‌های نصب‌شده هدایت خواهید شد و پیامی مبنی بر فعال شدن افزونه مشاهده خواهید کرد.
  3. دسترسی به تنظیمات: برای شروع پیکربندی نهایی، به دو روش می‌توانید به تنظیمات افزونه دسترسی پیدا کنید:
    • روش اول: در همان لیست افزونه‌ها، زیر نام “Bunny.net CDN”، روی لینک «تنظیمات» (Settings) کلیک کنید.
    • روش دوم (پیشنهادی): یک منوی جدید در نوار کناری پیشخوان وردپرس شما با عنوان “Bunny.net” اضافه شده است. روی آن کلیک کنید تا وارد صفحه اصلی تنظیمات افزونه شوید.

 

پیکربندی افزونه Bunny.net: تنظیمات اصلی و حیاتی

وارد منوی “Bunny.net” در پیشخوان وردپرس خود شوید تا این تنظیمات را تکمیل کنید.

اتصال افزونه به حساب کاربری (استفاده از API Key)

اولین اقدام، احراز هویت افزونه نزد حساب Bunny.net شما است. این کار از طریق کلید API (API Key) که در مراحل آماده‌سازی (گام ۳ پیش‌نیازها) کپی کرده‌اید، انجام می‌شود.

  1. در صفحه تنظیمات افزونه، فیلد “API Key” را پیدا کنید.
  2. کلید API محرمانه خود را که از داشبوردnet کپی کرده بودید، در این فیلد جای‌گذاری (Paste) نمایید.

نکته استراتژیک: این کلید صرفاً برای اتصال اولیه نیست؛ بلکه به افزونه اجازه می‌دهد تا عملیات حیاتی مانند «پاکسازی کش» (Cache Purge) را به صورت خودکار و مستقیماً از داخل پیشخوان وردپرس شما مدیریت کند.

تنظیمات عمومی (General): پیوند دادن Pull Zone به سایت شما

پس از احراز هویت، باید مشخص کنید که این سایت وردپرسی دقیقاً به کدام «منطقه کشش» (Pull Zone) که در داشبورد Bunny ساخته‌اید (گام ۲ پیش‌نیازها)، متصل شود.

  1. در فیلد “Pull Zone Name” (نام منطقه کشش)، فقط نام Pull Zone خود را وارد کنید.
  2. مثال: اگر آدرس Pull Zone شما b-cdn.net است، شما باید در این فیلد فقط عبارت vazirseo را وارد نمایید.

انتخاب نوع پیوند (Linkage Type): تفاوت CNAME سفارشی و Hostname پیش‌فرض

این بخش، نحوه بازنویسی URLهای فایل‌های شما (تصاویر، CSS و…) را تعیین می‌کند. شما باید بین دو گزینه اصلی انتخاب کنید:

  1. Hostname پیش‌فرض (Default Hostname):
    • چیست؟ استفاده مستقیم از آدرسی کهnet به شما اختصاص داده است (مانند vazirseo.b-cdn.net).
    • عملکرد: افزونه تمام لینک‌های شما را به این آدرس تغییر می‌دهد.
  2. Hostname سفارشی (Custom Hostname / CNAME):
    • چیست؟ استفاده از آدرس سفارشی که در گام ۴ پیش‌نیازها روی دامنه خودتان تنظیم کردید (مانند yourdomain.com).
    • عملکرد: اگر این گزینه را انتخاب کنید، باید در فیلد مربوطه، آدرس CNAME سفارشی خود را (مثلاً yourdomain.com) وارد کنید.

توصیه تخصصی سئو (E-E-A-T): استفاده از Hostname سفارشی (CNAME) به شدت توصیه می‌شود. این کار نه تنها از دیدگاه برندینگ حرفه‌ای‌تر است، بلکه سیگنال‌های اعتماد (Trustworthiness) بهتری ارسال می‌کند و به شما انعطاف‌پذیری فنی کامل برای مدیریت یا جابجایی CDN در آینده، بدون نیاز به تغییر در سایت، می‌دهد.

مدیریت فایل‌های مستثنی (Exclude): چه فایل‌هایی نباید از CDN بارگذاری شوند؟

در عمل، همه فایل‌های وب‌سایت نباید توسط CDN ارائه (Serve) شوند. برخی فایل‌های داینامیک یا حساس (مانند فایل‌های XML یا اسکریپت‌های خاص مدیریتی) ممکن است در صورت کش شدن توسط CDN، در عملکرد سایت اختلال ایجاد کنند.

بخش “Excluded Files” (فایل‌های مستثنی شده) به شما این امکان را می‌دهد که فایل‌ها، دایرکتوری‌ها یا پسوندهای خاصی را از فرایند بازنویسی URL مستثنی کنید.

  • مثال کاربردی: افزونه به صورت پیش‌فرض ممکن است پسوندهایی مانند .xml یا .xsl را مستثنی کند. این اقدام صحیح است، زیرا فایل‌های نقشه سایت (Sitemap) نباید از CDN بارگذاری شوند.
  • اقدام عملی: اگر اسکریپت یا فایلی در سایت خود دارید (مثلاً در پوشه /my-scripts/) که با بارگذاری از CDN دچار مشکل می‌شود، می‌توانید آدرس آن دایرکتوری (/my-scripts/) یا پسوند آن فایل را به این لیست اضافه کنید.

پس از تکمیل این چهار بخش، دکمه «ذخیره تنظیمات» (Save Settings) را کلیک کنید.

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

 

تنظیمات پیشرفته (Advanced): بهینه‌سازی تخصصی برای حداکثر کارایی

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

Perma-Cache (حافظه پنهان دائمی) چیست و چرا باید آن را فعال کنید؟

در حالت عادی CDN، اگر فایلی (مانند یک تصویر قدیمی) در یک سرور لبه (Edge Server) برای مدتی درخواست نشود، از حافظه پنهان آن سرور حذف می‌شود (Cache Eviction). اگر کاربری مجدداً آن فایل را درخواست کند، CDN باید دوباره به سرور اصلی شما (Origin Server) مراجعه کند. این فرایند باعث افزایش «زمان بارگذاری» (Latency) و مصرف پهنای باند سرور اصلی شما می‌شود.

Perma-Cache (حافظه پنهان دائمی) یک قابلیت استراتژیک در Bunny.net است.

  • عملکرد: با فعال‌سازی این گزینه (که نیازمند اتصال به یک Storage Zone در حساب Bunny شما است)، به جای حذف فایل‌های قدیمی از کش، net آن‌ها را به یک فضای ذخیره‌سازی ابری بسیار ارزان‌تر و دائمی منتقل می‌کند.
  • توصیه تخصصی (Quick Win): فعال‌سازی این گزینه، «نرخ برخورد کش» (Cache Hit Ratio) را به شدت افزایش می‌دهد. این یعنی تقریباً تمام فایل‌های استاتیک شما، حتی مقالات قدیمی، همیشه مستقیماً از شبکه Bunny تحویل داده می‌شوند، نه هاست اصلی شما. این اقدام برای کاهش بار سرور اصلی (Origin Load) حیاتی است.

بهینه‌سازی تصاویر (Image Optimization) و فعال‌سازی WebP

تصاویر معمولاً سنگین‌ترین دارایی‌ها (Assets) در یک صفحه وب هستند و تأثیر مستقیم بر شاخص حیاتی LCP (Largest Contentful Paint) دارند.

سرویس “Bunny Optimizer” (که باید جداگانه از داشبورد Bunny.net برای Pull Zone خود فعال کنید) می‌تواند بهینه‌سازی تصاویر را به صورت خودکار و در لبه شبکه (On-the-fly) انجام دهد.

  • قابلیت کلیدی: مهم‌ترین ویژگی این سرویس، تبدیل خودکار تصاویر JPG و PNG به فرمت مدرن WebP است. فرمت WebP حجم تصاویر را به طور چشمگیری کاهش می‌دهد (گاهی تا ۵۰٪) بدون افت کیفیت محسوس.
  • اقدام عملی: پس از فعال‌سازی “Optimizer” در داشبورد Bunny، باید گزینه‌های مربوط به آن (مانند “Enable Image Processing” یا “WebP Conversion”) را در تنظیمات افزونه وردپرس نیز فعال نمایید. این کار تضمین می‌کند که نسخه‌های بهینه و کم‌حجم تصاویر به کاربران تحویل داده می‌شود.

مدیریت هدرهای امنیتی (Security Headers) و CORS

این بخش یکی از رایج‌ترین نقاط بروز مشکل پس از فعال‌سازی CDN است.

زمانی که فایل‌ها (به‌ویژه فونت‌ها، آیکون‌ها و فایل‌های CSS/JS) از یک دامنه متفاوت (مثلاً cdn.yourdomain.com) بارگذاری می‌شوند، مرورگرها به دلایل امنیتی به هدرهای CORS (Cross-Origin Resource Sharing) نیاز دارند.

  • مشکل رایج: عدم تنظیم صحیح این هدرها، دلیل اصلی بارگذاری نشدن فونت‌ها (نمایش اشتباه آیکون‌ها) یا اعمال نشدن برخی استایل‌ها پس از فعال‌سازی CDN است.
  • راهکار: افزونهnet و خود سرویس معمولاً هدرهای CORS لازم را به صورت پیش‌فرض مدیریت می‌کنند. با این حال، در بخش تنظیمات پیشرفته (یا مستقیماً در داشبورد Bunny.net)، اطمینان حاصل کنید که هدر Access-Control-Allow-Origin به درستی تنظیم شده باشد (معمولاً روی * یا دامنه اصلی شما https://yourdomain.com تنظیم می‌شود) تا از بروز این خطاها جلوگیری شود.

تنظیمات پیشرفته کش (Cache) و زمان انقضا (Expiry Time)

این تنظیمات مشخص می‌کنند که فایل‌های شما چه مدت در سرورهای لبه (Edge Servers) ذخیره بمانند قبل از اینکه CDN مجدداً برای دریافت نسخه جدیدتر به سرور اصلی شما مراجعه کند. این زمان به عنوان TTL (Time To Live) یا “Cache Expiry Time” شناخته می‌شود.

  • اشتباه رایج: تنظیم زمان انقضای کوتاه برای فایل‌های استاتیک (مانند تصاویر یا CSS) به امید «تازه‌ماندن» محتوا.
  • استراتژی بهینه (Quick Win): برای فایل‌هایی که به ندرت تغییر می‌کنند (مانند تصاویر، فونت‌ها، و فایل‌های CSS/JS نهایی)، باید زمان انقضا (Expiry Time) را بسیار طولانی تنظیم کنید (مثلاً ۳۰ روز یا حتی ۳۶۵ روز).

نگران نباشید؛ به لطف اتصال API (که در مراحل قبل تنظیم کردیم)، هر زمان که شما فایلی را در وردپرس به‌روزرسانی کنید یا کش افزونه‌هایی مانند WP Rocket را پاک کنید، افزونه Bunny.net به طور خودکار کش آن فایل خاص را در سراسر شبکه جهانی پاک (Purge) می‌کند. بنابراین، تنظیم TTL طولانی، عملکرد و Cache Hit Ratio را به حداکثر می‌رساند، بدون آنکه مانع نمایش محتوای جدید شود.

پس از اعمال این تنظیمات پیشرفته، زیرساخت CDN شما برای حداکثر سرعت ممکن بهینه شده است.

 

اعتبارسنجی و تست: چگونه مطمئن شویم CDN به درستی کار می‌کند؟

روش اول: بررسی سورس کد (View Page Source) و یافتن آدرس فایل‌ها

این مستقیم‌ترین، سریع‌ترین و قطعی‌ترین روش برای اطمینان از بازنویسی (Rewrite) شدن URLها توسط افزونه است.

  1. باز کردن سایت در حالت ناشناس (Incognito): مرورگر خود را در حالت ناشناس (Incognito یا Private Window) باز کنید و آدرس وب‌سایت خود را وارد نمایید. (این کار تضمین می‌کند که از حافظه پنهان محلی مرورگر خودتان استفاده نمی‌کنید).
  2. مشاهده سورس صفحه: در صفحه اصلی سایت، کلیک راست کرده و گزینه “View Page Source” (یا “نمایش سورس صفحه”) را انتخاب کنید.
  3. جستجوی فایل‌های استاتیک: در صفحه سورس کد، با فشردن Ctrl + F (یا Cmd + F در مک)، به دنبال پسوندهای فایل‌های استاتیک خود بگردید. به عنوان مثال:
    • .jpg یا .png (برای تصاویر)
    • .css (برای فایل‌های استایل)
    • .js (برای فایل‌های جاوا اسکریپت)
  4. بررسی آدرس (URL) فایل‌ها:
    • نتیجه اشتباه (CDN کار نمی‌کند): اگر آدرس فایل‌ها همچنان دامنه اصلی شما را نشان می‌دهد (مانند: https://yourdomain.com/wp-content/uploads/image.jpg)، یعنی افزونه در بازنویسی URLها شکست خورده است.
    • نتیجه صحیح (CDN فعال است): آدرس فایل‌ها باید به آدرس CNAME سفارشی (مانند: https://cdn.yourdomain.com/wp-content/uploads/image.jpg) یا آدرس پیش‌فرض Bunny (مانند: https://yourpullzone.b-cdn.net/wp-content/uploads/image.jpg) تغییر یافته باشد.

روش دوم: استفاده از ابزارهای آنلاین (مانند GTmetrix یا PageSpeed Insights)

این روش نه‌تنها فعال بودن CDN را تأیید می‌کند، بلکه به شما نشان می‌دهد که CDN چقدر در بهبود «عملکرد» (Performance) موثر بوده است.

  1. به وب‌سایت GTmetrix مراجعه کنید.
  2. آدرس سایت خود را وارد کرده و تست را اجرا نمایید.
  3. پس از اتمام تحلیل، به تب (زبانه) “Waterfall” (آبشار) بروید.
  4. این نمودار، تمام فایل‌های بارگذاری‌شده در صفحه شما را به ترتیب نشان می‌دهد. ستون “Domain” را بررسی کنید.
  5. نتیجه صحیح: شما باید ببینید که اکثر فایل‌های استاتیک (تصاویر، CSS، JS، فونت‌ها) به جای اینکه از دامنه اصلی شما (com) بارگذاری شوند، از دامنه CDN شما (cdn.yourdomain.com) بارگذاری می‌شوند.

نکته تخصصی (Quick Win): در همان نمودار Waterfall، روی یکی از فایل‌هایی که از CDN بارگذاری شده کلیک کنید و هدرهای (Headers) آن را بررسی نمایید. به دنبال هدر X-Cache (یا موارد مشابه) بگردید. اگر مقدار آن HIT باشد، یعنی فایل مستقیماً از حافظه پنهان لبه (Edge Cache) تحویل داده شده که این وضعیت ایده‌آل برای حداکثر سرعت است.

نحوه پاک کردن کش (Purge Cache) پس از اعمال تغییرات در سایت

ما در تنظیمات پیشرفته، زمان انقضای (Expiry Time) طولانی برای فایل‌ها تنظیم کردیم. حال این سوال پیش می‌آید: اگر من فایل style.css یا یک تصویر را تغییر دهم، آیا باید ۳۰ روز صبر کنم تا کاربران نسخه جدید را ببینند؟

پاسخ خیر است. به لطف اتصال API که برقرار کردیم، می‌توانیم کش CDN را به صورت آنی (Instant) پاک کنیم.

اقدام عملی (راه‌حل سریع):

  1. در پیشخوان وردپرس خود، به نوار ابزار مدیریت در بالای صفحه (Admin Bar) نگاه کنید.
  2. یک منو با عنوان “Bunny.net” یا “Bunny” اضافه شده است.
  3. روی آن هاور (Hover) کنید.
  4. گزینه “Purge Pull Zone Cache” (یا “پاکسازی کش منطقه کشش”) را انتخاب کنید.

با کلیک بر روی این گزینه، افزونه بلافاصله به تمام سرورهای Bunny.net در سراسر جهان فرمان می‌دهد که تمام نسخه‌های کش‌شده فایل‌های شما را حذف کنند. در بازدید بعدی، CDN نسخه‌های کاملاً جدید را از سرور اصلی شما «کشش» (Pull) کرده و مجدداً ذخیره خواهد کرد.

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

 

عیب‌یابی و مشکلات رایج (تجربه عملی)

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

مشکل: تصاویر یا فایل‌های CSS/JS از CDN بارگذاری نمی‌شوند (خطای 404)

تشخیص (Diagnosis): شما سایت را باز می‌کنید و متوجه می‌شوید که تصاویر شکسته هستند یا استایل‌های سایت (CSS) بارگذاری نشده‌اند. با بررسی در ابزار Inspect مرورگر (تب Network)، متوجه می‌شوید که مرورگر هنگام فراخوانی فایل‌ها از آدرس CDN (مثلاً cdn.yourdomain.com/…/image.jpg) با خطای 404 (Not Found) مواجه می‌شود.

علت ریشه‌ای (Root Cause): این خطا به این معناست که افزونه کار خود (بازنویسی URL) را به درستی انجام داده، اما سرورهای لبه (Edge Servers) در شبکه Bunny.net نمی‌توانند فایل مورد نظر را در سرور اصلی شما (Origin Server) پیدا کنند.

راهکار عملی (Actionable Solution):

  1. بررسی Origin URL در داشبورد Bunny: به داشبوردnet بروید. وارد تنظیمات Pull Zone خود شوید. مطمئن شوید که فیلد “Origin URL” دقیقاً آدرس سایت شما با پروتکل صحیح (https://) و پیشوند صحیح (با www یا بدون www) است. هرگونه عدم تطابق جزئی (مانند http به جای https) باعث بروز 404 می‌شود.
  2. بررسی فایروال سرور (مهم): بسیاری از هاست‌ها یا افزونه‌های امنیتی (مانند Wordfence) ممکن است دسترسی ربات‌ها یا سرویس‌های خارجی را مسدود کنند. شما باید اطمینان حاصل کنید که IP آدرس‌های رسمیnet (که در وب‌سایت آن‌ها موجود است) در لیست سفید (Whitelist) فایروال سرور شما قرار دارند تا CDN بتواند فایل‌ها را “Pull” کند.

مشکل: تغییرات در سایت نمایش داده نمی‌شوند (مشکلات کش)

تشخیص (Diagnosis): شما یک تصویر را در وردپرس به‌روزرسانی کرده‌اید یا فایل style.css قالب خود را تغییر داده‌اید، اما پس از بارگذاری مجدد سایت، همچنان نسخه‌های قدیمی را مشاهده می‌کنید.

علت ریشه‌ای (Root Cause): این یک مشکل کلاسیک «حافظه پنهان» (Cache) است. فایل‌های شما در سه لایه ممکن است کش شده باشند: ۱. کش مرورگر شما، ۲. کش افزونه کش وردپرس (مانند WP Rocket)، ۳. کش CDN در سرورهای لبه Bunny.net.

راهکار عملی (Actionable Solution): فرایند پاکسازی کش باید به ترتیب صحیح انجام شود:

  1. گام اول: پاکسازی کش وردپرس: ابتدا کش افزونه کش (WP Rocket, LiteSpeed, etc.) خود را در پیشخوان وردپرس پاک کنید. این کار تضمین می‌کند که سرور اصلی شما، نسخه جدید فایل را آماده تحویل دارد.
  2. گام دوم: پاکسازی کشnet: از نوار ابزار بالای وردپرس (Admin Bar)، روی منوی “Bunny.net” رفته و گزینه “Purge Pull Zone Cache” را بزنید. این کار به تمام سرورهای لبه دستور می‌دهد که نسخه‌های قدیمی را حذف کنند.
  3. گام سوم: پاکسازی کش مرورگر: مرورگر خود را با Ctrl + F5 (یا Cmd + Shift + R در مک) رفرش سخت (Hard Refresh) کنید یا کش مرورگر خود را به طور کامل پاک نمایید.

مشکل: خطای CORS (Cross-Origin Resource Sharing) هنگام بارگذاری فونت‌ها

تشخیص (Diagnosis): این یکی از رایج‌ترین مشکلات پس از فعال‌سازی CDN است. سایت بارگذاری می‌شود، اما فونت‌ها (یا آیکون‌های مبتنی بر فونت مانند Font Awesome) نمایش داده نمی‌شوند و به فونت پیش‌فرض مرورگر بازمی‌گردند. در کنسول (Console) مرورگر، خطایی حاوی عبارت “CORS policy” یا “Access-Control-Allow-Origin” مشاهده می‌کنید.

علت ریشه‌ای (Root Cause): به دلایل امنیتی، مرورگرها به صورت پیش‌فرض اجازه نمی‌دهند که یک دامنه (مثلاً yourdomain.com) فایلی حساس مانند فونت را از دامنه‌ای دیگر (مثلاً cdn.yourdomain.com) بارگذاری کند، مگر اینکه دامنه دوم (CDN) با ارسال یک هدر HTTP خاص، صراحتاً این اجازه را صادر کند.

راهکار عملی (Actionable Solution): شما باید این هدر امنیتی را در سطح CDN تنظیم کنید:

  1. وارد داشبورد net شوید و به تنظیمات Pull Zone خود بروید.
  2. به بخش “Headers” (سربرگ‌ها) مراجعه کنید.
  3. روی “Add Header” کلیک کنید.
  4. در فیلد “Name” (نام هدر)، دقیقاً عبارت Access-Control-Allow-Origin را وارد کنید.
  5. در فیلد “Value” (مقدار)، ستاره (*) را وارد کنید. (توجه: برای امنیت بیشتر، می‌توانید به جای *، آدرس دامنه اصلی خود را https://yourdomain.com وارد کنید، اما * معمولاً برای فایل‌های عمومی مانند فونت‌ها پذیرفته شده است).
  6. تنظیمات را ذخیره کرده و کش CDN را پاک کنید.

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

 

جمع‌بندی (Conclusion)

پیاده‌سازی یک شبکه توزیع محتوا (CDN) تنها یک اقدام فنی نیست، بلکه یک سرمایه‌گذاری مستقیم بر تجربه کاربری (UX) و سیگنال‌های حیاتی سئو (SEO Signals) است. با دنبال کردن دقیق مراحل این راهنما، شما نه تنها افزونه Bunny.net را نصب کرده‌اید، بلکه یک زیرساخت مقیاس‌پذیر و بهینه برای تحویل محتوا در لبه شبکه (Edge) پیاده‌سازی نموده‌اید.

شما آموختید که چگونه یک Pull Zone ایجاد کنید، اتصال API را برای مدیریت خودکار کش برقرار سازید، تنظیمات پیشرفته‌ای مانند Perma-Cache و CNAME سفارشی را برای بهبود برندینگ و کارایی اعمال کنید، و مهم‌تر از آن، چگونه خطاهای رایج و فنی مانند 404 و CORS را عیب‌یابی نمایید.

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

author-avatar

درباره محمد صدرا حسینی

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

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *