میثم سلیمی
میثم سلیمی
خواندن ۱۱ دقیقه·۲ سال پیش

مایگریشن سایت تخفیفان، داستان یک تغییر!


سلام، من میثم سلیمی هستم؛ از اردیبهشت 97 کارم رو توی دنیای SEO شروع کردم و در حال حاضر در شرکت تخفیفان مشغول به کارم.

چند روز پیش بود که من درباره مایگریشن (site migration) تخفیفان پستی توی لیندکین منتشر کردم و بعد از اون تصمیم گرفتم یکم بیشتر راجع بهش صحبت کنم و این تجربه رو با دوستان به اشتراک بذارم به امید اینکه برای چند نفر مفید باشه، نتیجه این تصمیم شد این مقاله :)

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

نکته دوم اینکه سعی میکنم تا جایی که بشه ساده بنویسم و امیدوارم بتونم کمک کوچکی به دوستان بکنم که اگه توی مسیر کاری SEO نیاز به مایگریشن بود بتونن تجربه خوبی داشته باشن.

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

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

خب تخفیفان تا چند ماه پیش یه سایت deal base بود و تخفیف‌های مختلفی روی اون قرار می‌گرفت و مردم استفاده می‌کردن، توی این مایگریشن تخفیفان به یه مارکت‌پلیس تبدیل شد و ساختار سایت به vendor base تغییر پیدا کرد.به این صورت که پیشنهادها و تخفیف‌هایی که توی سایت قرار میگیره توسط مالکین اون کسب و کار تعریف میشه که قبلا اینطوری نبود.

این مایگریشن از زمان اولین ریلیز تا زمان تکمیل شدن حدود 4 ماه طول کشید اما تا جایی که من میدونم سمت بیزینس حدود 1 سال درگیر این تغییر و تحولات بودن.

بریم سر اصل مطلب؛

ما توی تیم SEO برای اینکه بتونیم وظایف خودمون رو به درستی انجام بدیم اومدیم یه road map برای خودمون ایجاد کردیم که شامل بخش های زیر بود :

  • استخراج کامل دیتای سایت قبل از مایگریشن
  • جایگذاری دیتای جدید برای انتقال
  • بررسی تسک‌های انجام شده در استیج قبل از ریلیز
  • ریلیز release (انتشار روی سایت)
  • مانیتورینگ و بررسی خطاها و تاثیرات احتمالی

این road map رو با سایر تیم ها به اشتراک گذاشتیم و بابت زمانبندی‌ها با هم صحبت کردیم و هماهنگ شدیم.

بریم که یکم جزئی‌تر شیم و این مراحل رو با هم مرور کنیم.

1: استخراج کامل دیتای سایت قبل از مایگریشن

قبل از این که مایگریشن رو شروع کنیم باید اول صفحات و مشخصات کامل اون‌ها رو استخراج و دسته‌بندی می‌کردیم. ما شروع کردیم به کراول تمام بخش های سایت و دسته بندی کردن اطلاعات.این کار رو بسته به شرایط و ابعاد سایت به روش‌های مختلف می‌تونید انجام بدید، screaming frog, python , google sheet.

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

برای سایت‌های بزرگ‌تر باید از python یا screaming frog استفاده کنید. توی این پست از لینکدینِ علیرضا اسمی‌خانی می‌تونید روش کراول سایت با python رو ببینید و برای screaming frog هم که آموزش‌های مقدماتی و پیشرفته زیادی وجود داره.این رو هم اگه می‌خواهید از پایه کار باهاش رو یاد بگیرید از طریق این لینک اقدام کنید.

ما بخش زیادی از این مرحله رو با screaming frog پیش بردیم.

حقیقتش اینه اگه سایتتون صفحات زیادی داشته باشه همین مرحله اول تایم نسبتا زیادی رو ازتون می‌گیره.برای اینکه مراحل بعدی رو به خوبی پیش ببرید نیاز دارید که این مرحله رو با دقت بالایی انجام بدید.ما توی این مرحله دیتای صفحات‌مون رو استخراج کردیم که شامل URL, page title, meta title, meta description, canonical, content و یه سری دیتای دیگه از کتگوری‌ها و صفحات deal می‌شد.

نکته: بعضی از ستون‌هایی که توی عکس زیر می‌بینید (مثلا parent - slug - category ids) توسط بچه‌های فنی پر شده بودند و اونها علاوه بر دیتای ما به یه سری دیتای دیگه برای پیشبرد کار نیاز داشتن.

در نتیجه یه همچین داکیومنتی آماده کردیم:

استخراج دیتای صفحات سایت قبل از مایگریشن
استخراج دیتای صفحات سایت قبل از مایگریشن


2: جایگذاری دیتای جدید برای انتقال

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

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

توی سایت تخفیفان چیزی حدود 100.000 صفحه deal وجود داشت. منظور از صفحه deal همون تخفیف هایی بود که ارائه می‌شد.مثلا یه صفحه برای "تخفیف صبحانه رستوران گردان برج میلاد ویژه آخر هفته" وجود داشت و یه صفحه هم برای "تخفیف صبحانه رستوران گردان برج میلاد ویژه وسط هفته" وجود داشت.

یا مثلا اگه یه خواننده در سال 5 بار کنسرت اجرا می‌کرد هربار توی تخفیفان براش یه صفحه deal ایجاد می‌شد.اما وقتی داشتیم به سمت vendor base شدن می‌رفتیم باید اینطوری میشد که فقط یک صفحه برای اون خواننده ایجاد بشه و هروقت هر کنسرتی داره توی همون صفحه پیشنهادش نمایش داده بشه.

اینارو گفتم که بگم گاهی اوقات دیده می‌شد که برای یک وندور بیشتر از 10 تا صفحه deal وجود داره و ما باید اول همه اون هارو پیدا می‌کردیم و براشون 1 صفحه وندور ایجاد می‌کردیم و بعد ریدایرکتشون می‌کردیم به صفحه وندور.

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

اما بیاید فرض کنیم که این اتفاق نیوفتاده بود، حالا بر چه اساسی باید صفحات وندور رو می‌ساختیم؟

چیزی که به ذهن من می‌رسه استفاده از ریجکس (Regex) توی گوگل شیتِ ؛ مثلا اگه ما 10 تا صفحه deal داشتیم که توی عنوانشون از کلمه رستوران گردان برج میلاد استفاده شده بود، می‌شد با استفاده از ریجکس پیداشون کرد و براشون یک صفحه وندور به اسم رستوران گردان برج میلاد ساخت.

خب، در نهایت ما اومدیم یه داکیومنت درست کردیم و توی اون مشخص کردیم که چه صفحاتی باید به چه صفحاتی ریدایرکت بشن.

نتیجه:

این وسط ما یه سری صفحات رو هم مشخص کردیم که باید حذف می‌شدن. بیشتر این‌ها صفحاتی بودن که مربوط به هیچ وندوری نمی‌شدن و بودنشون توی سایت هیچ منفعتی نداشت و ضرر هم داشت.

پس ما:

  • یه سری صفحات رو ریدایرکت کردیم به وندور مربوطه.
  • یه سری از صفحات رو کلا 410 کردیم.
  • و یه سری صفحات رو هم که به نظرمون نباید از اول تو گوگل ایندکس می‌شدن رو noindex کردیم.

جالبه بدونید در نهایت حدود 35.000 صفحه رو از نتایج گوگل حذف کردیم و سعی کردیم crawl رو به سمت صفحات مهم تر ببریم.

خب مهم ترین قسمت از مرحله 2 رو گذروندیم، می‌رسیم به موارد دیگه.

طبیعتا ما توی این مرحله دیتاهای دیگه مثل تایتل، دیسکریپشن و ... رو هم جایگذاری کردیم.

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

(البته توی مایگریشنی که ساختار سایت تغییرات اساسی داره نمیشه از یه تست خاص برداشت دقیقی کرد)

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

پس ما اومدیم سراغ کتگوری ها و خواستیم روی تقریبا نصف کتگوری ها با تغییر تایتل و دیسکریپشن تست انجام بدیم و توی مرحله جایگذاری دیتا، تایتل و دیسکریپشن نصف کتگوری هارو هم تغییر دادیم.(تقریبا 2000 کتگوری توی تخفیفان وجود داره که در حال حاضر فقط حدود 100 تا از اون ها از طریق منو قابل مشاهده هستن)

3: بررسی تسک‌های انجام شده در استیج قبل از ریلیز

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

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

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

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

4: ریلیز release (انتشار روی سایت)

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

چند روز بعد از ریلیز هم ما sitemap رو آپدیت کردیم و اولین گروه از وندورها وارد sitemap شدن.

فاصله بین ریلیز اول و ریلیز دوم حدود یک ماه بود چون این اولین کتگوری بود که vendor base می‌شد و هم تیم SEO و هم تیم های دیگه شدیدا درگیر رصد تاثیرات این جابجایی روی بیزینس بودیم.

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

5: مانیتورینگ و بررسی خطاها و تاثیرات احتمالی

بعد از اینکه تغییرات مورد نظر روی سایت اعمال شد ما شروع کردیم به بررسی اتفاقاتی که داره میوفته و حقیقتش شخصا استرس زیادی هم داشتم.

چه چیزهایی رو باید بررسی می‌کردیم؟

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

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

پس توی این مرحله باید مطمئن بشید که هرچی که توی استیج چک کردید درست منتشر شده و اگه مورد مهمی هست که درست انجام نشده سریعا به تیم فنی انتقال بدین.

علاوه بر این موارد ما حدود 2 هفته منتظر موندیم تا اون کتگوری کاملا کراول شه و 2 مورد رو بررسی کنیم:

1: خطاهای احتمالی در کراول، ایندکس و ...

2: تغییر جایگاه ها و بررسی دراپ احتمالی کیوردها در SERP

در آخر دوست دارم یه سری نکاتی که به نظرم مهم هستن رو اینجا بگم:

  • ارتباط با تیم های دیگه همیشه توی SEO مهم بوده و زمان مایگریشن هم یکی از مهم‌ترین مسائلی هست که باید خوب از پسش بر بیاید.موضوع ارتباط با تیم های دیگه خیلی گسترده‌اس؛ پیمان خلیلی یه مقاله به اسم "چطور با سایر تیم ها در سئو ارتباط موثر ایجاد کنیم؟" داره که به نظر من خیلی جذاب این موضوع رو بررسی کرده که پیشنهاد می‌کنم حتما بخونید.
  • همونطور که گفتم ما مایگریشن رو مرحله به مرحله انجام دادیم و به نظرم این موضوع مخصوصا توی سایت‌های متوسط و بزرگ خیلی مهمه و می‌شه کار رو بهتر پیش برد.
  • یه اتفاق مهمی که برای ما توی این مایگریشن افتاد تغییر سرور درست وسط تغییرات ساختاری سایت بود.تغییر سرور توی حالت عادی هم ممکنه تاثیراتی روی سئو داشته باشه. ما سعی کردیم جلوی این اتفاق رو بگیریم اما این چیزی نبود که زور ما بهش برسه و باید انجام می‌شد.

به هر حال، بهتره که تغییر سرور وسط تغییرات ساختاری سایت اتفاق نیوفته اما اگه مجبور به این کار شدید و سایت برای چند ساعت down بود برای اینکه مشکلی توی سئو پیش نیاد از تیم فنی بخواهید که status code 503 رو به مرورگر برگردونن.

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

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

امیدوارم با این مقاله تونسته باشم نکات به درد بخوری رو منتقل کنم :) شما هم اگه تجربه ای توی مایگریشن دارید لطفا توی کامنت ها باهامون به اشتراک بگذارید تا استفاده کنیم.




تغییر ساختارتخفیفانسایتتیم فنی
علاقه مند به سئو و دنیای کسب کار آنلاین
شاید از این پست‌ها خوشتان بیاید