Gitflow چیست و چگونه کار می کند ؟
Gitflow چیست
اغلب مشکلاتی مثل همزمانی توسعه ویژگیها، تداخل و Merge Conflict هنگام انجام کارهای گروهی و تیمی پیش میآیند و در این شرایط برای ادغام کردن برنچهای مختلف و deploy کردن آنها زمان زیادی از ما تلف شده و معمولاً پروژه برای مدت کوتاهی متوقف میگردد. در ادامه با مفهوم Gitflow چیست بیشتر آشنا میشویم.
ویدیو پییشنهادی : آموزش Git
Gitflow مفهومی برای مدیریت کردن برنچها است که به آن Branch Model نیز میگویند. در واقع برای مدیریت تیم توسعه استفاده از این مفهوم لازم و ضروری میباشد چرا که به وسیله آن میتوان Featureهای مختلف را بدون آن که نگرانی از بابت لانچ و مرج قسمتهای مختلف وجود داشته باشد، به بخشهای مختلف پروژه اضافه نمود.
gitflow راهکاری فوق العاده برای مدیریت پروژه
به طور کلی می توانیم GitFlow را یک ایده مدیریتی برای محیطهای توسعه در نظر بگیریم که روشی برای ساخت انواع برنچها محسوب شده و همچنین طریقه Merge کردن آنها با هم را مشخص مینماید.
Gitflow چیست و چگونه کار میکند
برای استفاده از گیتفلو ابتدا باید آن را نصب کنید و با اجرای دستور زیر آن را در پروژه خود فعال نمایید.
git flow init
این دستور تغییری در ریپازیتوری شما ایجاد نمی کند و فقط همراه با گیت برای موارد لازم استفاده میشود.
طرز کار GitFlow چگونه است؟
در انجام یک پروژه به جای استفاده از برنچهای مختلف، حتی با یک برنچ مستر نیز میتوانیم از برنچ develop و master استفاده کنیم. برای استفاده از develop branch میتوان با استفاده از دستور زیر آن را روی ریپازیتوری لوکال ایجاد نمود و سپس پوش کرد. البته میتوان در محیط کنترل ورژن نیز آن را ایجاد نمود.
مقاله پییشنهادی : منظور از گیت Git چیست
git branch develop git push -u origin develop
برنچ master در واقع نسخه لانچ شده پروژه بوده و برنچ develop همان نسخهای است که تغییرات نهایی پروژه و تمام فیچرها روی آن قرار گرفته و ابتدا تست میشوند و در نهایت با با برنچ مستر، مرج میشوند.
به خاطر داشته باشید که پس از هر بار لانچ کردن، با استفاده از تگها باید برنچ مستر را ورژنبندی نمود.
حال که میدانید Gitflow چیست باید بدانید که با اجرای دستور git flow init همزمان با ایجاد گیت روی ریپازیتوری، develop branch نیز ایجاد میگردد؛
Feature Branches
هر برنچ شامل یک Feature است که هنگام اضافه کردن ویژگیهای مختلف به پروژه ساخته میشود و در نهایت هر Feature دارای یک Branch مخصوص به خود است. پس از تکمیل شدن هر ویژگی، Feature با Develop مرج میشود. ( Feature Branchها تابع Develop هستند و آن را والد خود در نظر میگیرند.)
نکته: هیچگاه برنچهای Feature با master مرج نمیشوند.
مقاله پییشنهادی : گیت هاب چیست؟
در نظر داشته باشید که هر Feature Branch ساخته شده از آخرین ورژن develop branch بوده و همچنین همزمان با توسعه Featureهای مختلف برنچ develop متوقف شده و در همین زمان میتوان سایر برنچها را نیز Merge کرد.
ایجاد feature branch
البته میتوان بدون GitFlow نیز اقدام به ساخت feature branch نمود:
،،git checkout develop git checkout -b feature_branch
ولی اگر از GitFlow استفاده کنید، باید به صورت زیر feature branch را ایجاد نمایید:
git flow feature start feature_branch
اتمام Feature Branch
پس از تکمیل شدن feature branch باید آن را با develope branch مرج نماییم؛
با استفاده از دستور زیر میتوان بدون gitflow آن را مرج کرد:
git checkout develop git merge feature_branch
همچنین با دستور زیر میتوان ضمن استفاده از gitflow آن را مرج کرد:
git flow feature finish feature_branch
Release Branches
پس از توسعه برنچ develop و مرج شدن فیچرهای لازمه، میتوان به Release کردن آن پرداخت و یک انشعاب از develop برای Release گرفت. زمانی که برنچ Release ایجاد میشود در واقع از این نقطه یک چرخه حیات برای آن برنچ ایجاد میشود.
در صورت مرج شدن یک feature جدید با برنچ develop، تغییراتی صورت میگیرد که شامل این نسخه از release نمیشود. به همین دلیل در کار تیمهایی که به صورت مستقل روی featureهای مختلف کار میکنند داخلی ایجاد نمیشود. در واقع هیچ ویژگی جدیدی نمیتواند به این برنچ اضافه شود. (به جز bug fixها و موارد حیاتی مربوط به این برنچ)
مقاله پییشنهادی : نحوه نصب Git روی اوبونتو
پس از آمادهسازی Release برای انتشار، این برنچ با master branch مرج میشود.(همراه تگ ورژن مربوطه) از طرفی برای آنکه تغییرات اعمال شده روی برنچ develop قرار بگیرند باید مجددا develop branch مرج شود.
در حین استفاده از Release branchها افراد توسعهدهنده هر یک میتوانند به راحتی روی گسترش ویژگیهای مختلف کار کرده و پروژه را به خوبی و طبق برنامه از قبل تعیین شده، پیش ببرند. معمولاً خیلی راحت میتوان هماهنگ کرد که در تاریخ مشخصی ورژن مشخصی از پروژه لانچ شود.
نحوه ایجاد Release Branch بدون استفاده از gitflow:
git checkout develop git checkout -b release/0.1.0
نحوه ایجاد Release Branch با استفاده از gitflow:
$ git flow release start 0.1.0 // Switched to a new branch ‘release/0.1.0’
با توجه به اطلاعات فوق حال میدانید که Gitflow چیست و چگونه کار میکند اما لازم است به نکات ضرروی هنگام کدنویسی توجه کنید تا عملکرد خوبی را شاهد باشید. یکی از نکات مهم مربوط به دسترسی feature branchها به تغییرات صورت گرفته میباشد. برای این منظور باید حتما باید Release Branch با develop branch مرج شود.
نحوه به اتمام رساندن release branch بدون استفاده از gitflow:
git checkout develop git merge release/0.1.0 git checkout master git checkout merge release/0.1.0
نحوه به اتمام رساندن release branch با استفاده از gitflow:
git flow release finish ‘0.1.0’
Hotfix Branches
برای آن که محصول نهایی باگزدایی شود و بتوان از آن نگهداری نمود معمولاً از hotfix branch استفاده میشود. hotfix branchها به طور مستقیم از master، انشعاب دریافت میکنند وپس رفع باگها با برنچهای master و develop مرج میشوند.
نحوه ایجاد Hotfix branches برای بدون استفاده از gitflow:
git checkout master git checkout -b hotfix_branch
نحوه ایجاد Hotfix branches برای بدون استفاده از gitflow:
git flow hotfix start hotfix_branch
نحوه مرج کردن hotfix Branch با برنچهای develop و master بدون استفاده از gitflow:
git checkout master git merge hotfix_branch git checkout develop git merge hotfix_branch git branch -D hotfix_branch
نحوه مرج کردن hotfix Branch با برنچهای develop و master بدون استفاده از gitflow:
git flow hotfix finish hotfix_branch
مکمل قدرتمند گیت gitflow چیست
تا این قسمت از مقاله به یادگیری مفاهیمی مثل Gitflow پرداختیم و طرز عملکرد آن را شرح دادیم. این مکمل قدرتمند ابزار فوق العادهای است که امکانات گستردهای از git را در اختیارتان گذاشته و لذت کار با گیت را برایتان افزایش میدهد.
جدا از زبانی که با آن کار میکنید و سطح آگاهی شما، یا حتی تکنولوژیهای مورده استفادهتان، در هر صورت استفاده از گیت بخش مهمی از روند برنامهنویسی شما محسوب میشود. در واقع برای کار با گیت و کار با ورژن کنترلها باید از یک مکمل قدرتمند استفاده کرد و قطعا gitflow بهترین گزینه خواهد بود.
نصب گیت فلو
شما کاربران گرامی میتوانید پس از نصب گیت در سیستمهای مختلف، مکمل gitflow را با استفاده از کدهای دستوری زیر نصب کنید؛
نصب گیتفلو در اوبونتو
1sudo apt-get install git-flow
نصب گیتفلو در مک
1brew install git-flow
نصب گیتفلو در ویندوز
برای نصب گیتفلو در ویندوز باید ابتدا یک پکیجمنیجر متناسب را روی آن نصب نمایید.(برای این منظور می توانید از لینک زیر استفاده نموده و سپس گیت فلو رانصب نمایید)
wget -q -O – –no-check-certificate https://raw.githubusercontent.com/petervanderdoes/gitflow/develop/contrib/gitflow-installer.sh
./gitflow-installer.sh install <state>
rm -rf gitflow gitflow-installer.sh
راه اندازی گیت فلو
برای راه اندازی گیت فلو از طریق ترمینال، وارد پوشه مورد نظر شده و سپس دستور زیر را اجرا نمایید؛
1git flow init
پس از درج دستور فوق در رابطه با نام شاخههایی که مد نظر دارید از شما سوالاتی پرسیده میشود که با فشردن دکمه اینتر میتوانید نامهای پیشفرض را تایید نمایید.
برای مثال در صورتی که بخواهید روی یک ویژگی جدید به نام signup کار کنید، می توانید کد دستوری زیر را به کار بگیرید؛
1git flow feature start signup
بدین وسیله در feature branch یک شاخه جدید به نام signup ساخته میشود. در این قسمت تمامی دستورات گیت قابل اجرا و کاربردی هستند. ( دستوراتی مثل git branch و git checkout )
با توجه به مثال فوق پس از اتمام کار با فیچر signup میتوانیم دستور زیر را اجرا کنیم؛
1git flow feature finish signup
با اجرای دستور فوق به طور اتوماتیک اعمال زیر پیادهسازی میشوند؛
- شاخه جدید singup با شاخه develop مرج میشوند.
- شاخه feature حذف میشود.
- Signup به شاخه develop برگردانده شده و checkout میشود.
به احتمال زیاد با وجود این توضیحات به خوبی متوجه شدهاید که Gitflow چیست و تا چه حد میتواند روند اعمال تغییرات و مدیرت شاخهها را آسان نماید.
در حقیقت گیت فلو خیلی از مراحل را به طور اتوماتیک پیش برده و روند مدیریت پروژه را برای اعضای تیم تسهیل میبخشد. امیدواریم مطالب موجود در این مقاله برایتان مفید بوده باشد.