Gitflow چیست

اغلب مشکلاتی مثل همزمانی توسعه ویژگی‌ها، تداخل و Merge Conflict هنگام انجام کارهای گروهی و تیمی پیش می‌آیند و در این شرایط برای ادغام کردن برنچ‌های مختلف و deploy کردن آن‌ها زمان زیادی از ما تلف شده و معمولاً پروژه برای مدت کوتاهی متوقف می‌گردد. در ادامه با مفهوم Gitflow چیست بیشتر آشنا می‌شویم.

 

ویدیو پییشنهادی : آموزش Git
آموزش Git

 

Gitflow مفهومی برای مدیریت کردن برنچ‌ها است که به آن Branch Model نیز می‌گویند. در واقع برای مدیریت تیم توسعه استفاده از این مفهوم لازم و ضروری می‌باشد چرا که به وسیله آن می‌توان Feature‌های مختلف را بدون آن که نگرانی از بابت لانچ و مرج قسمت‌های مختلف وجود داشته باشد، به بخش‌های مختلف پروژه اضافه نمود.

Gitflow چیست

gitflow راهکاری فوق العاده برای مدیریت پروژه

به طور کلی می توانیم GitFlow را یک ایده مدیریتی برای محیط‌های توسعه در نظر بگیریم که روشی برای ساخت انواع برنچ‌ها محسوب شده و همچنین طریقه Merge کردن آن‌ها با هم را مشخص می‌نماید.

Gitflow چیست و چگونه کار می‌کند

برای استفاده از گیت‌فلو ابتدا باید آن را نصب کنید و با اجرای دستور زیر آن را در پروژه خود فعال نمایید.

git flow init

این دستور تغییری در ریپازیتوری شما ایجاد نمی کند و فقط همراه با گیت برای موارد لازم استفاده میشود.

طرز کار GitFlow چگونه است؟

در انجام یک پروژه به جای استفاده از برنچ‌های مختلف، حتی با یک برنچ مستر  نیز می‌توانیم از برنچ develop و master استفاده کنیم. برای استفاده از develop branch می‌توان با استفاده از دستور زیر آن را روی ریپازیتوری لوکال ایجاد نمود و سپس پوش کرد. البته می‌توان در محیط کنترل ورژن نیز آن را ایجاد نمود.

 

مقاله پییشنهادی : منظور از گیت Git چیست
منظور از گیت Git چیست

 

git branch develop git push -u origin develop

برنچ master در واقع نسخه لانچ شده پروژه بوده و برنچ develop همان نسخه‌ای است که تغییرات نهایی پروژه و تمام فیچر‌ها روی آن قرار گرفته و ابتدا تست می‌شوند و در نهایت با با برنچ مستر، مرج می‌شوند.

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

حال که می‌دانید Gitflow چیست باید بدانید که با اجرای دستور git flow init همزمان با ایجاد گیت روی ریپازیتوری، develop branch نیز ایجاد می‌گردد؛

 

Gitflow چیست و چگونه کار می‌کند

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 روی اوبونتو
نحوه نصب 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’

مکمل قدرتمند گیت git flow

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 چیست و تا چه حد می‌تواند روند اعمال تغییرات و مدیرت شاخه‌ها را آسان نماید.
در حقیقت گیت فلو خیلی از مراحل را به طور اتوماتیک پیش برده و روند مدیریت پروژه‌ را برای اعضای تیم تسهیل می‌بخشد. امیدواریم مطالب موجود در این مقاله برایتان مفید بوده باشد.