مقدمه
سرعت سایت یکی از مهمترین فاکتورهایی است که مستقیماً بر تجربه کاربری، نرخ تبدیل و رتبهبندی گوگل تأثیر میگذارد. وقتی کاربر وارد سایت وردپرسی شما میشود، مرورگر باید دهها درخواست مختلف را پردازش کند؛ از بارگذاری فایلهای CSS و JS گرفته تا ارتباط با دامنههای خارجی مثل فونت گوگل، CDN، تصاویر یا سرویسهای آنالیتیکس. در این میان، هر بار که مرورگر نیاز داشته باشد دامنهای جدید را شناسایی کند، فرایندی به نام DNS Lookup انجام میشود. این فرایند هرچند کوتاه، اما میتواند سرعت بارگذاری سایت را کاهش دهد و زمان TTFB (Time to First Byte) را بیشتر کند.
یکی از راهکارهای بهینهسازی برای رفع این مشکل، استفاده از تکنیکی به نام DNS Prefetch است. این تکنیک به مرورگر اعلام میکند قبل از اینکه کاربر واقعاً به یک منبع نیاز داشته باشد، دامنه مقصد را شناسایی و IP آن را کش کند. در نتیجه، هنگام بارگذاری منابع خارجی، زمان صرف شده برای DNS Lookup به حداقل میرسد و سرعت سایت وردپرسی افزایش پیدا میکند.
در این مقاله به صورت کامل بررسی میکنیم که DNS Prefetch چیست، چه تفاوتی با Preconnect و Preload دارد، و چگونه میتوان آن را در سایت وردپرسی (با افزونه یا کدنویسی) پیادهسازی کرد تا سرعت بارگذاری بهینه شود. اگر شما یک طراح سایت، سئوکار یا صاحب کسبوکار آنلاین هستید، این مطلب میتواند به شما کمک کند تجربه بهتری برای کاربران خود رقم بزنید و در عین حال امتیاز بهتری در ابزارهایی مثل PageSpeed Insights به دست آورید.
DNS Prefetch چیست و چگونه کار میکند؟
DNS مخفف Domain Name System است؛ سیستمی که وظیفه دارد آدرسهای دامنه (مثل example.com) را به آدرسهای IP سرور (مثل 192.168.1.1) ترجمه کند. وقتی مرورگر کاربر برای اولین بار قصد دسترسی به یک دامنه جدید را دارد، باید این فرایند را طی کند. این مرحله که به آن DNS Lookup گفته میشود، معمولاً بین ۲۰ تا ۱۲۰ میلیثانیه زمان میبرد. شاید این عدد کوچک به نظر برسد، اما در بهینهسازی سرعت سایت، همین چند میلیثانیهها هم اهمیت زیادی دارند.
اینجاست که DNS Prefetch وارد عمل میشود. این قابلیت به مرورگر دستور میدهد که قبل از نیاز واقعی به یک دامنه خارجی، آن را پیشپردازش کند. به عبارت ساده، مرورگر از قبل آدرس دامنه را به IP تبدیل میکند و در حافظه نگه میدارد. در نتیجه وقتی زمان فرا میرسد که فایل یا منبعی از آن دامنه لود شود، مرحله DNS Lookup حذف شده یا بسیار سریع انجام میگیرد.
برای نمونه، فرض کنید سایت وردپرسی شما از فونت گوگل (fonts.googleapis.com) استفاده میکند. در حالت عادی، مرورگر هنگام بارگذاری فونت باید ابتدا DNS Lookup انجام دهد. اما اگر شما از تگ DNS Prefetch برای این دامنه استفاده کنید، مرورگر خیلی زودتر از لحظه نیاز، این کار را انجام داده و سرعت بارگذاری فونت افزایش مییابد.
به طور خلاصه، DNS Prefetch:
- زمان لازم برای اتصال به دامنههای خارجی را کاهش میدهد.
- باعث کاهش TTFB و در نتیجه بهبود امتیاز PageSpeed Insights میشود.
- تجربه کاربری روانتر و سریعتری ایجاد میکند.

تفاوت DNS Prefetch با Preconnect و Preload
در گزارشهای ابزارهایی مثل PageSpeed Insights یا GTmetrix معمولاً هشدارهایی مانند “Preconnect to required origins” یا “Reduce DNS lookups” نمایش داده میشود. برای رفع این خطاها معمولاً راهکارهایی مثل DNS Prefetch، Preconnect و حتی Preload پیشنهاد میشوند. اما هرکدام از این روشها کاربرد و تأثیر متفاوتی دارند.
۱. DNS Prefetch
همانطور که توضیح داده شد، DNS Prefetch تنها وظیفه دارد آدرس دامنه را به IP ترجمه کند. یعنی مرورگر از قبل DNS Lookup را انجام میدهد تا هنگام نیاز به منبع خارجی، وقفهای برای پیدا کردن IP ایجاد نشود.
مزیت: سبک، سریع و بدون فشار اضافی به سرور.
محدودیت: فقط مرحله DNS حل میشود، ولی اتصال TLS یا TCP همچنان در لحظه نیاز انجام خواهد شد.
۲. Preconnect
Preconnect یک قدم جلوتر از DNS Prefetch است. وقتی از این ویژگی استفاده کنید، مرورگر علاوه بر حل DNS، اتصال TCP و حتی TLS را هم از قبل برقرار میکند. به این ترتیب زمانی که نیاز به دریافت منابع از یک دامنه خارجی باشد، عملاً همهچیز آماده است و منبع بلافاصله دانلود میشود.
مزیت: کاهش چشمگیر زمان بارگذاری منابع حیاتی (مثل فونتها یا اسکریپتهای CDN).
محدودیت: اگر اتصال برقرار شود اما در نهایت منبع مورد استفاده قرار نگیرد، منابع مرورگر هدر خواهد رفت.
۳. Preload
Preload در اصل برای منابعی به کار میرود که مرورگر باید هرچه زودتر آنها را دانلود کند. مثلاً اگر فایلی CSS یا JS برای عملکرد سایت ضروری باشد، با Preload به مرورگر اعلام میکنیم که بلافاصله اقدام به بارگذاری آن کند.
مزیت: سرعت بارگذاری محتوای حیاتی به شدت افزایش مییابد.
محدودیت: استفاده نادرست میتواند منجر به افزایش مصرف پهنای باند یا لود شدن منابع غیرضروری شود.
به زبان ساده:
- DNS Prefetch = آمادهسازی DNS
- Preconnect = آمادهسازی DNS + TCP + TLS
- Preload = بارگذاری فوری یک منبع مشخص

چرا استفاده از DNS Prefetch برای افزایش سرعت سایت وردپرسی مهم است؟
در سایتهای وردپرسی معمولاً از منابع خارجی متعددی استفاده میشود؛ از فونتهای گوگل گرفته تا کتابخانههای جاوااسکریپت (مثل jQuery یا Swiper از CDN)، سرویسهای آنالیتیکس، شبکههای تبلیغاتی و حتی CDN تصاویر. هر بار که مرورگر بخواهد به این منابع دسترسی پیدا کند، ابتدا باید DNS دامنه مقصد را شناسایی کند و این موضوع میتواند باعث تأخیر در بارگذاری صفحه شود.
استفاده از DNS Prefetch به شما کمک میکند این تأخیرها را به حداقل برسانید. دلایل اهمیت آن در سایت وردپرسی به شرح زیر است:
۱. کاهش زمان TTFB
یکی از مشکلات رایج در گزارشهای PageSpeed Insights، بالا بودن زمان Time To First Byte است. وقتی مرورگر DNS Lookup را از قبل انجام دهد، مدت زمانی که برای دریافت اولین بایت داده لازم است، کوتاهتر میشود و این یعنی امتیاز بهتری در ابزارهای سنجش سرعت خواهید گرفت.
۲. بهبود تجربه کاربری (UX)
کاربران اینترنت در ایران به دلیل شرایط سرعت و کیفیت اتصال، بیش از دیگر کشورها حساسیت نسبت به تأخیر در بارگذاری دارند. اگر منابع خارجی سایت شما سریعتر لود شوند، کاربر حس میکند سایت روانتر و حرفهایتر است و همین موضوع باعث افزایش نرخ ماندگاری و کاهش بانس ریت میشود.
۳. کمک به بهینهسازی سئو سایت
گوگل به وضوح اعلام کرده که سرعت سایت یکی از فاکتورهای مهم رتبهبندی است. با پیادهسازی DNS Prefetch، شما عملاً زمان بارگذاری صفحات را کاهش داده و امتیاز Core Web Vitals را بهبود میدهید. این موضوع تأثیر مستقیم روی رتبه کلمات کلیدی مهم، مثل «افزایش سرعت سایت وردپرسی»، خواهد داشت.
۴. اجرای آسان بدون نیاز به افزونههای سنگین
DNS Prefetch را میتوان تنها با چند خط کد ساده یا حتی یک افزونه سبک در وردپرس پیادهسازی کرد. برخلاف برخی تکنیکهای پیچیده بهینهسازی، این روش نیازمند تغییرات عمیق در ساختار سایت نیست و برای همه وبسایتها قابل اجراست.

چگونه DNS Prefetch را در وردپرس پیادهسازی کنیم؟ (افزونه و کدنویسی)
پیادهسازی DNS Prefetch در سایت وردپرسی کار پیچیدهای نیست و میتوان آن را هم با استفاده از افزونهها و هم از طریق کدنویسی دستی انجام داد. در ادامه هر دو روش را بررسی میکنیم:
۱. استفاده از افزونهها
اگر تمایل ندارید کدنویسی کنید، افزونههای متعددی برای مدیریت منابع خارجی و بهینهسازی سرعت وجود دارند. برخی از بهترین گزینهها:
Perfmatters: افزونهای سبک که امکان مدیریت DNS Prefetch و Preconnect را به صورت گرافیکی فراهم میکند.
WP Rocket: علاوه بر کشینگ، قابلیت تعریف دامنههای DNS Prefetch را نیز دارد.
Asset CleanUp: با این افزونه میتوانید منابع خارجی را کنترل کرده و برای دامنههای آنها Prefetch تنظیم کنید.
کافی است دامنههایی مثل fonts.googleapis.com یا cdnjs.cloudflare.com را در بخش مربوط به DNS Prefetch وارد کنید تا مرورگر از قبل آنها را آماده کند.
۲. افزودن دستی کد در وردپرس
اگر میخواهید بدون افزونه این قابلیت را اضافه کنید، میتوانید چند خط کد ساده به فایل functions.php قالب یا پلاگین اختصاصی خود اضافه کنید:
function add_dns_prefetch() {
echo '<link rel="dns-prefetch" href="//fonts.googleapis.com">';
echo '<link rel="dns-prefetch" href="//cdnjs.cloudflare.com">';
echo '<link rel="dns-prefetch" href="//www.googletagmanager.com">';
}
add_action('wp_head', 'add_dns_prefetch', 1);در این مثال، مرورگر قبل از نیاز به منابع، دامنههای مربوطه را از قبل پردازش میکند. شما میتوانید دامنههای مورد نیاز سایت خود را جایگزین کنید.
۳. نکات مهم هنگام استفاده
تنها دامنههایی را Prefetch کنید که واقعاً در سایت شما استفاده میشوند.
زیادهروی نکنید؛ چرا که Prefetch بیمورد میتواند منابع مرورگر را بیجهت درگیر کند.
همیشه پس از اعمال Prefetch، سایت را با ابزارهایی مثل PageSpeed Insights یا GTmetrix بررسی کنید تا مطمئن شوید نتیجه مطلوب حاصل شده است.
نتیجه: چه با افزونه و چه با کدنویسی، اضافه کردن DNS Prefetch به سایت وردپرسی یک راهکار سریع و مطمئن برای افزایش سرعت سایت و بهبود تجربه کاربری است.
جمعبندی
سرعت سایت وردپرسی دیگر فقط یک عامل فنی نیست؛ بلکه به طور مستقیم بر رضایت کاربران، نرخ تبدیل و رتبه سئو شما تأثیر میگذارد. یکی از تکنیکهای ساده اما بسیار کاربردی برای بهبود سرعت، استفاده از DNS Prefetch است.
اگر شما یک طراح سایت، سئوکار یا صاحب کسبوکار آنلاین هستید و به دنبال راهکاری سریع برای افزایش سرعت سایت وردپرسی خود میگردید، DNS Prefetch یکی از اولین گامهایی است که باید در استراتژی بهینهسازی سایتتان در نظر بگیرید. این تکنیک کوچک میتواند تفاوت بزرگی در تجربه کاربری ایجاد کند و شما را یک قدم جلوتر از رقبایتان قرار دهد.


