آموزش رایگان وردپرس، سئو ، طراحی سایت و اخبار روز تکنولوژی
ارتباط

بهینه‌سازی عمیق ووکامرس: دیتابیس، کوئری‌ها و اکشن‌های کدنویسی

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

نویسنده سایت آموز
تاریخ انتشار 1404 دی 15
زمان مطالعه 3 دقیقه
بازدید 22
بهینه‌سازی عمیق ووکامرس: دیتابیس، کوئری‌ها و اکشن‌های کدنویسی

ووکامرس شما چرا کُند می‌شه؟ اصل ماجرا اینجاست!

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

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

غواصی عمیق در دیتابیس: بهینه‌سازی کوئری‌های ووکامرس

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

شاخص‌گذاری جداول حیاتی (Indexing Key Tables)

یکی از مهم‌ترین قدم‌ها، اطمینان از اینه که جداول پرترافیک ووکامرس شاخص‌گذاری مناسبی دارن. جداولی مثل `wp_posts` (برای محصولات و سفارشات)، `wp_postmeta` (برای اطلاعات تکمیلی محصولات)، `wp_options` و `wp_woocommerce_sessions` از جمله جداولی هستن که باید شاخص‌های قوی داشته باشن. شاید فکر کنید وردپرس و ووکامرس خودشون این کار رو انجام می‌دن، اما گاهی اوقات برای فیلدهای خاصی که توسط افزونه‌ها یا کاستومایزهای شما اضافه شده، نیاز به شاخص‌گذاری دستی دارید. این اون قلق خاصیه که می‌تونه تفاوت رو رقم بزنه. مثلاً، اگر یک فیلد `_custom_product_code` در `wp_postmeta` دارید و زیاد بر اساس اون جستجو یا فیلتر می‌کنید، اضافه کردن یک شاخص می‌تونه معجزه کنه:


ALTER TABLE wp_postmeta ADD INDEX custom_product_code_idx (meta_key, meta_value(191));

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

کش کردن هوشمند داده‌ها (Smart Data Caching)

همه اطلاعات نیازی به کوئری زدن مداوم به دیتابیس رو ندارن. استفاده از Object Caching (مثل Redis یا Memcached) می‌تونه بار دیتابیس رو به شدت کاهش بده. اما اگر به این سیستم‌ها دسترسی ندارید یا نمی‌خواید ازشون استفاده کنید، `Transients API` وردپرس رفیق شماست. با Transients می‌تونید نتایج کوئری‌های سنگین رو برای مدت زمان مشخصی در دیتابیس (جدول `wp_options`) کش کنید و تا زمانی که این کش منقضی نشده، نیازی به اجرای مجدد کوئری نیست. مثال: کش کردن لیست ۱۰ محصول پرفروش:


function get_top_selling_products_cached() {
 $top_sellers = get_transient( 'top_selling_products' );

 if ( false === $top_sellers ) {
 // If cache is not found, fetch products
 $args = array(
 'post_type' => 'product',
 'posts_per_page' => 10,
 'meta_key' => 'total_sales',
 'orderby' => 'meta_value_num',
 'order' => 'DESC',
 );
 $top_sellers_query = new WP_Query( $args );
 $top_sellers = $top_sellers_query->posts;

 // Store the result in cache for 1 hour (3600 seconds)
 set_transient( 'top_selling_products', $top_sellers, HOUR_IN_SECONDS );
 }

 return $top_sellers;
}

این تنها یک مثال ساده است. می‌تونید این منطق رو برای هر کوئری پرمصرفی به کار ببرید.

کنترل نهایی با اکشن‌ها و فیلترها: بازنویسی برای پرفورمنس

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

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

حذف کوئری‌های اضافه در صفحات محصول (Trimming Product Page Queries)

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


remove_action( 'woocommerce_after_single_product_summary', 'woocommerce_output_related_products', 20 );

// Then، می‌توانید این بخش را با یک فراخوانی AJAX شخصی‌سازی شده جایگزین کنید.

با نگاهی دقیق‌تر به `woocommerce/includes/wc-template-hooks.php` می‌توانید اکشن‌های دیگری را هم پیدا کنید که شاید برای سایت شما ضروری نباشند و حذف آن‌ها باعث سبک‌تر شدن صفحه شود.

بهینه‌سازی لوپ محصولات (Optimizing Product Loops)

در صفحات دسته‌بندی یا آرشیو محصولات، لوپ‌های `WP_Query` نقش حیاتی در پرفورمنس دارن. استفاده نادرست از `posts_per_page` یا `meta_query`های پیچیده می‌تونه سایت رو به زانو دربیاره. اصل ماجرا اینه که باید حداقل کوئری‌ها رو اجرا کنیم و فقط اطلاعاتی رو لود کنیم که واقعاً نیاز داریم. برای این کار، در کاستومایز کردن لوپ محصولات، بهینه‌سازی آرگومان‌ها در `WP_Query` می‌تونه کمک‌کننده باشه:


$args = array(
 'post_type' => 'product',
 'posts_per_page' => 12,
 'tax_query' => array(
 array(
 'taxonomy' => 'product_cat',
 'field' => 'slug',
 'terms' => 'tshirts',
 ),
 ),
 'fields' => 'ids', // فقط ID محصولات را لود کنید تا سبک‌تر باشد
);
$products = new WP_Query( $args );

// سپس برای نمایش جزئیات هر محصول، از get_post() یا wc_get_product() استفاده کنید.

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

ترفندهای Checkout برای تجربه کاربری روان (Checkout Flow Optimization)

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


add_filter( 'woocommerce_checkout_fields' , 'custom_override_checkout_fields' );

function custom_override_checkout_fields( $fields ) {
 unset($fields['billing']['billing_company']);
 unset($fields['shipping']['shipping_company']);
 return $fields;
}

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

ابزارهای رفیق برای بررسی عملکرد (Our Go-To Performance Tools)

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

  • Query Monitor: این افزونه بی‌نظیره! به شما نشون می‌ده که چه کوئری‌هایی در هر صفحه اجرا می‌شن، چقدر طول می‌کشن و از کجا فراخوانی شدن. تمام اکشن‌ها، فیلترها، HTTP API Calls و PHP Errors رو هم نمایش می‌ده.
  • Debug Bar: یک نوار ابزار اشکال‌زدایی دیگه که اطلاعات مفیدی رو در مورد PHP، کش و کوئری‌های دیتابیس ارائه می‌ده.

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

همیشه به یاد داشته باشید که بهینه‌سازی فقط مربوط به سرعت نیست، بلکه به معنای بهبود کلی وبسایت و رعایت استانداردهای گوگل، مثل Core Web Vitals نیز هست.

کلام آخر: نگاهی به آینده پرفورمنس در ووکامرس

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

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

اشتراک‌گذاری مقاله

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

A

آقا کوچولو

توسعه‌دهنده وب و نویسنده محتوا با بیش از 13 سال تجربه در زمینه وردپرس و طراحی وب‌سایت. علاقه‌مند به آموزش و انتقال تجربیات به دیگران.

نظرات (0)

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

کد امنیتی