من مهدی ام اما دوستانم به من میگن جوزف :) الان سربازم اما قبلش قائم مقام فنی والکس بودم و قبلش هئیت مدیره و مدیر فنی سیبچه بودم،قبلا تیم لیدزیرساخت تپسی بودم، قبلش مدیرفنی سیب اپ بودم و ...
دوم از پانزدمین: زمان لانچ یا زمان ریلیز؟ مسئله این است!
خیلی وقته که تو بعضی از شرکتها، وقتی که یه فیچر جدید رو میخوان به دست کاربرهاشون (که میتونه کارمندای خود شرکت، بیزینسهای دیگه و در نهایت کاربر نهایی باشه) برسونن، بین تیم فنی و تیم مارکتینگ جنگی به پا میشه. چه جنگی؟ معلومه! تیم مارکتینگ از هفتهها قبل از رسیدن فیچر، شروع به تبلیغات کرده و روز خاصی و یا حتی ساعت خاصی رو معین کرده و به همه اطلاعرسانی کرده، اما این وسط اون روز و اون ساعت تیم فنی ممکنه در انتشار نسخهی جدید سرویس دچار مشکل بشه! این یعنی یه آبروریزی بزرگ به راه میافته و یا چیزی منتشر میشه که با قولهای تیم مارکتینگ تطابق نداره. جدا از این مسئله، اکثر مواقع برای بهرهمند شدن از اون قابلیت، کاربر میبایست اپلیکشناش رو به روز رسانی کنه و در نهایت، ممکنه در اون زمان خاصی که تیم مارکتینگ براش برنامهریزی کرده، به دستش نرسه. همهی این مسائل به ما این رو میگه که اتفاق بزرگی که تیم مارکتینگ براش یه عالمه برنامه چیده بود به خوبی اتفاق نیوفتاده.
اگه این اتفاق تو شرکت شما هم پیش میاد شاید این نوشته به کارتون بیاد.
در ابتدا داستان باید ۲ کلمه رو براتون تعریف کنم:
زمان ریلیز
زمانی هستش که محصول شما، تغییر میکنه و قابلیتهای جدید بهش اضافه میشه.
زمان لانچ
زمانی هستش که کاربر باید به قابلیتها و تغییرات جدید شما دسترسی داشته باشه.
تا امروز همهی ما این دو زمان رو یکسان میدیم. یعنی اگه میخواستیم یه قابلیت جدید رو لانچ کنیم، همون موقع نسخهی نرمافزارمون رو هم ریلیز میکردیم. اما در واقعیت میتونه این دو زمان از هم جدا در نظر گرفته بشه و این جدا کردن میتونه یه عالمه مزیت برای شرکتهامون داشته باشه.
بیاید با مثالی این اتفاق رو کمی شفافتر کنیم.
فرض کنید تیم مارکتینگ شما تصمیم به عوض کردن چند عکس در نرمافزار شما میگیره و قرار میشه ساعت ۱۲ در روز ۲۳ مرداد این نسخهی جدید رو برای همگان منتشر کنه. از دید تیم مارکتینگ نکتهی مهم این تصمیم، انجام شدن در راس ساعت ۱۲ هستش که اتفاق رو برای تیم فنی ممکنه سختتر کنه.
در ادامه تیم فنی، بنا به این درخواست، تسکی ایجاد میکنه و تسک رو به نحو احسن انجام میده.
روز موعود فرا میرسه و تیم فنی در ساعت ۱۱:۰۰ به خط میشه تا مراحل انتشار نسخهی جدید برنامه رو بچینه و در ساعت مقرر، همه چیز بدون مشکل انجام بشه.
اما ... در زمان انتشار نسخهی جدید مشکلاتی پیش میاد که خیلی هم جدی نیستند اما زمان انتشار رو از ساعت ۱۲ به ساعت ۱۲:۳۲ تغییر میده. این تغییر برای تیم مارکتینگ پذیرفته نیست و کلی سر و صدا به پا میکنه (جدا از هزینههای هدر رفته) اما با توضیحات مدیر فنی، اتفاق به فراموشی سپرده میشه.
دفعهی بعد که این درخواست از سمت تیم مارکتینگ تکرار میشه، مدیر فنی تدبیر جدیدی برای این اتفاق میاندیشه :). بهجای اینکه با انتشار برنامه تغییرات اعمال بشه، در تسک به توسعهدهندگان توضیح میده که باید تغییرات در کد و با شرطهایی وابسته به زمان (یعنی مثلا اگه زمان فعلی از فلان موقع بیشتر بود، عکس دیگری رو نمایش بدن) این تسک پیاده بشه، و قبل از تاریخ مقرر کد منتشر بشه. با این استراتژی اگر مشکلی برای انتشار نسخه به وجود بیاد، برای حل مشکلات زمان وجود خواهد داشت.
روز موعود فرا میرسه اما تیم فنی از قبل قابلیت مد نظر رو منتشر کرده بود و سر زمان همه چیز به خوبی و بدون نیاز به تغییری در چیزی، تغییر پیدا میکنه و مدیرفنی سربلند از این تسک بیرون میاد :)
اگر دقت کرده باشید مدیرفنی با جدا کردن زمان انتشار با زمان لانچ، تونسته بود که نیازهای تیم فنی و مارکتینگ رو با یک تیر رفع کنه. اما این روش کار در تعداد زیادی اتفاق قابل پیاده سازی نیست! درسته؟
کل صحبت ما همین بود! اما در اسکیل بزرگ و استاندارد!
از این به بعد در مورد روشی صحبت میکنیم که باهاش میشه این کار رو در اسکیل بزرگ و به صورت استاندارد (یا به قول بچههای فنی، به صورت تمیز) پیاده کرد.
خیلی قبلتر یکی از بزرگان علم کامپیوتر (مارتین فاولر) تئوریای برای پیادهسازی قابلیتهای جدید در سیستمهای بزرگ ارائه داده بود. اسم اون تئوری Feature toggle یا Feature flag هستش. برای مطالعهی بیشتر می تونید از این لینک استفاده کنید: https://www.martinfowler.com/articles/feature-toggles.html
برای اینکه مفهموم فیچر فلگ رو متوجه بشید، خیلی ساده سعی میکنم توضیح بدم که وقت زیادی ازتون گرفتهنشه.
وقتی که در تیمتون میخواید یه قابلیتی رو پیاده کنید که نیاز دارید زمان لانچ و ریلیز متفاوتی داشته باشه، ابتدا به اون فیچر یه نام یکتای انگلیسی بدید. مثلا test-feature که در سیستم بتونید این فیچر رو شناسایی کنید.
بعدش در جایی از سیستم (مثلا دیتابیس) لیستی از فیچرها رو با وضعیتشون که شامل (public | private) هستش نگه دارید. بعد لیستی از کاربرانی رو که به اون فیچر در حالت private قراره دسترسی داشته باشن، در جای دیگهای از سیستم نگهدارید (باز هم دیتابیس مکان خوبی هستش).
نحوهی چک کردن فعال بودن یک قابلیت برای هر کاربر به این صورت هستش:
۱- اگه اون قابلیت در حالت عمومی - public بود، همهی کاربرها به اون دسترسی دارن.
۲- اگه اون قابلیت در حالت خصوصی - private بود، فقط کاربرانی که از قبل اعلام شدهاند به اون قابلیت دسترسی دارن.
البته شما میتونید این مدل رو هر چقدر که دوست داشته باشید یا نیاز داشته باشید پیچیدهتر و کاملتر کنید.
در نهایت در زمان توسعهدادن اون قابلیت، با یک شرط ساده که توش چک میکنید که آیا اون کاربر به اون قابلیت دسترسی داره یا نه، یا نسخهی قبلی سیستم رو نشون میدید یا نسخهی جدید رو نشون میدید. همین و بس!
شاید براتون سوال باشه که مثلا سمت اپلیکیشن شما چه جوری باید این چک کردنها رو انجام بده، و خب جوابش ساده است، کافیه در درخواست لاگین یا گرفتن اطلاعات کاربر، لیست قابلیتهای فعال برای اون کاربر رو به سمت اپلیکیشن برگردونیم.
قابلیتهایی که زیرساخت فیچرفلگ به مجموعهی شما میده، از دید من (که قطعا ناقص هستش)، اینهاست:
- قابلیت انتشار نسخه، قبل از زمان لانچ
- قابلیت مشاهدهی نسخهی جدید برای بعضی از کاربران (مثلا تیم مارکتینگ یا تسترها و یا گروه تستی از کاربرها) در محیط پروداکشن
- قابلیت انتشار فیچری خاص برای گروه خاصی از کاربران (مثلا قابلیت ویژهای برای شرکت خاصی که باهاش کار میکنید)
- بازگشت راحت به نسخهی قبل برنامه در صورتی که باگ یا اروری در نسخهی جدید وجود داشت باشه
برای مارکتینگ یکسری پیشنهاد و قانون برای درخواست قابلیتهای جدید توی سالهایی که کار کردم تونستم در بیارم که شاید به درد شما هم بخوره و خلاصه اینهاست:
- قبل از اینکه قابلیتی که میخواید، ریلیز نشده و توسط شما دیده نشده، هیچ وقت به لانچ کردن اون قابلیت به صورت کورکورانه فکر نکنید
- برای لانچ کردن یک قابلیت، زمانی که با تیم فنی ددلاینهاتون رو میبندید، همهی کارهایی که داخلی هستش و توسط تیمهای شرکت انجام میشه رو ببرید جلو، اما هیچ ارتباط بیرونی یا تبلیغات بیرونیای انجام ندید و منتظر باشید که قابلیت ریلیز بشه و بعد از اون، ابتدا با تعداد محدودی از مشتریاتون اون قابلیت رو تست کنید، و در نهایت اگه فیچر درخواست شده، از دید شما قابلیت لانچ شدن داشت، پلن لانچ بریزید و روز لانچ صرفا فیچرفلگ مد نظر رو public کنید!
- هیچ وقت و هیچ وقت به ددلاینهای تیم فنی، اعتماد نکنید! و هیچ قولی به هیچ مشتریای پیروی قول تیم فنی ندید! این قول دادنها ممکن هستش جز آبروریزی و از دست دادن قرارداد، براتون هیچ آوردهای نداشته باشه.
امیدوارم این مقاله به شما در خلق ارزشهای بزرگتر کمکی کرده باشه :)
مطلبی دیگر از این انتشارات
اولین از پانزدهمین : Single point of Failure vs Single point of Truth
مطلبی دیگر از این انتشارات
۱۵ مسئلهی مهم برای مدیران فنی شرکت های نرم افزاری
افزایش بازدید بر اساس علاقهمندیهای شما
اولین وبینار با محوریت ادغام مشاغل سنتی با دنیای رمزارزها