Github چیست؟ Git چیست؟ و چگونه می‌توان از این ابزار توسعه استفاده کرد؟
ﺯﻣﺎﻥ ﻣﻄﺎﻟﻌﻪ: 12 دقیقه

Github چیست؟ Git چیست؟ و چگونه می‌توان از این ابزار توسعه استفاده کرد؟

احتمالا اولین برنامه‌ای که می‌نویسید خیلی تاثیرگذار نخواهد بود. شما اشتباه‌های زیادی مرتکب خواهید شد و هرگز نمی‌خواهید که به گذشته برگردید. اما به زودی، برنامه‌های بزرگ و پیچیده‌ای خواهید نوشت. شاید اکنون مواردی را حذف کنید که بعدها بخواهید آن‌ها را برگردانید یا شاید هم از دوستان خود کمک بگیرید و در حالی‌که به کار خود ادامه می‌دهید، تغییرات آن‌ها را به برنامه‌تان اضافه کنید.

اینجاست که سیستم کنترل ورژن وارد می‌شود و این مهارتی است که هر کارفرمایی از شما انتظار دارد که به آن تسلط داشته باشید. همچنین برای هرکسی که روی هر چیزی کار می‌کند بسیار مفید است.

کنترل ورژن چیست؟

کنترل ورژن به توانایی ذخیره‌ی موقعیت شما در یک سند یا پوشه اشاره می‌کند و ذخیره‌های قبلی را ارجاع می‌دهد.

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

Git چیست؟

یک سیستم کنترل ورژن است که توسط لینوس توروالدز در سال ۲۰۰۵ توسعه یافت ( همان شخصی که لینوکس را نوشت). Git به توسعه‌دهندگان کمک می‌کند تا وضعیت کد خود را پیگیری کنند و همکاری در Codebase را ممکن می‌سازد. در ادامه به اجزای اصلی می‌پردازیم.

اگر می‌خواهید این مقاله را دنبال کنید، باید Git را روی کامپیوتر خود نصب کنید. یک ترمینال باز کنید و git را در آن تایپ کنید. اگر لیستی از دستورات ممکن را مشاهده کردید، بهتر است ادامه دهید!

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

استفاده از Git

اگر تا به حال از یک برنامه‌ی رایانه‌ای یا یک بازی ویدئویی استفاده کرده باشید، متوجه شده‌اید که می‌توانید به نسخه‌ی از پیش ذخیره شده برگردید، اینجاست که نیاز به Git را درک می‌کنید. این کار به سادگی ذخیره‌ی یک اسنپ‌شات از برنامه‌ی شما در زمان است و تغییرات بین کدی که اکنون دارید و ﺁخرین باری که ذخیره کردید را یادداشت می‌کند و دیگر نیازی نیست که هر خط کد از برنامه خودتان را پیگیری کنید. Git یادداشت‌های در حال اجرا را در یک پوشه‌ی پنهان مخصوص ذخیره می‌کند.

اجازه دهید این برنامه‌ی جاوااسکریپت را در نظر بگیریم. این سه خط روی کنسول چاپ می‌شود (خروجی که در مرورگر یا ترمینال خود می‌توانید ببینید):

console.log('Hello, this is a git example!')
console.log('And here is another!')
console.log('And yet a third')

دستور git init

اگر بخواهم نسخه‌های کارم را ذخیره کنم، می‌توانم از Git استفاده کنم. اول git init را در ترمینال تایپ می‌کنم تا بتوانم از آن استفاده کنم. این کار یک پوشه‌ی .git ایجاد خواهد کرد، جایی که Git فایل‌های خود را ذخیره می‌کند.

دستور git add

git add . تمام فایل‌ها را در برنامه‌ی ما ذخیره خواهد کرد. اگر git init را بعد از ایجاد یک فایل یا هر زمانی که فایل جدیدی ساختید اجرا کردید، شما باید به Git فرمان دهید که با این دستور شروع به ردیابی تغییرات در آن‌ها کند.

دستور git commit

سپس من دستور git commit -am "Initial commit” را تایپ می‌کنم. git commit دستوری است که یک نسخه از کدهای ما ذخیره می‌کند. نام دیگر دستور -am، (flag) می‌باشد. flag a یعنی ما همه‌ی تغییرات خود را ذخیره خواهیم کرد. flag m اشاره می‌کند که ما پس از آن یک پیام ارائه خواهیم کرد، مثل دستور "Initial commit".

چگونه Git تغییرات را ذخیره می‌کند

اگر ما برنامه‌ی خودمان را تغییر دهیم (مانند تغییر متن خط اول)، ممکن است بخواهیم که یک نسخه‌ی جدید ذخیره کنیم. ما حتی می‌توانیم بین نسخه‌ها تغییر ایجاد کنیم، اگر بخواهیم شاهد چگونگی تغییر برنامه‌ی خودمان در طول زمان باشیم.

console.log('Now I have changed the first line.')
console.log('And here is another!')
console.log('And yet a third')

دستور git diff

این چیزی است که در حین اجرای این فرمان به نظر می‌رسد. Git تفاوت بین کدی که اکنون دارید و ﺁخرین باری که ذخیره شده بود را به شما نشان می دهد. درک کردن این مسائل کمی دشوار است، اما - حذفی‌ها و + الحاقی‌ها هستند. ما متن "سلام، این یک مثال از Git است!" را حذف کردیم و متن "اکنون خط اول را تغییر دادم" را اضافه کردیم. این‌گونه است که Git آن‌چه را که بین نسخه‌ها تغییر کرده است را پیگیری می‌کند.

diff --git a/git.js b/git.js
index eb0f1d1..8dbf769 100644
--- a/git.js
+++ b/git.js
@@ -1,3 +1,3 @@
+console.log('Now I have changed the first line.')
-console.log('Hello, this is a git example!')
 console.log('And here is another!')
 console.log('And yet a third')

حالا ما شاهد تغییرات commit خواهیم بود، می‌توانیم ادامه دهیم و با این دستور commit جدیدی را ایجاد کنیم: git commit -am 'Update first console log'

این کار تغییراتی که در اولین خط از متن انجام داده‌ام را ذخیره خواهد کرد.

دستور git log

ما می‌توانیم commit‌هایی که با این دستور انجام داده‌ایم را از نو مرور کنیم. اگر همین الان در برنامه آن را اجرا کنم، این خروجی را بدست خواهم آورد:

commit 67627dd44e84a3106a18a19e94cf9f3723e59b3c (HEAD -> master)
Author: amberwilkie <[email protected]>
Date:   Wed Apr 22 16:55:39 2020 -0400

    Update first console log

commit 49fe4152f474a9674a83e2b014a08828209d2690
Author: amberwilkie <[email protected]>
Date:   Wed Apr 22 16:54:59 2020 -0400

    Initial commit

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

دستور git checkout

اگر می‌خواستیم به گذشته برگردیم و تغییرات مربوط به کد خودمان را از commit قبلی مشاهده کنیم، ما این کار را با فرمان git checkout 49fe4152f474a9674a83e2b014a08828209d2690 انجام می‌دهیم. Git کد ما را در وضعیت موقتی قرار خواهد داد تا ما بتوانیم ببینیم که کدها در اسنپ‌شات به چه صورتی به نظر می‌رسد.

من شناسه را برای اولین commit خودم کپی کردم. اگر این فرمان را اجرا کنم، برنامه در خط اول، متن "سلام، این یک مثال از git است" را به من نشان می‌دهد.

برای بازگشت به آخرین کد، شما باید فرمان git checkout master را تایپ کنید.

Branch‌ها یا شاخه‌ها

اگر در بالا متوجه شده باشید، ما مجبور شدیم که master را تایپ کنیم تا به وضعیت فعلی کد خود برگردیم. چرا؟ چون master نام پیش‌فرض شاخه‌ی اصلی است، جایی که کدهای ما در آن بروز است. Git برای حفظ کدها به عملیات شاخه زدن یا Branching متکی است. شما می‌توانید master را تنه‌ی درخت در نظر بگیرید. ممکن است کنار گذاشته یا موجب تغییراتی شوید، اما در نهایت به تنه‌ی درخت یا همان master بر خواهید گشت. شما می‌توانید برای ایجاد یک شاخه‌ی جدید، از فرمان git checkout استفاده کنید.

فرمان git checkout -b new-branch را امتحان کنید. زمانی از فلگ -b استفاده می‌کنیم که در حال ایجاد یک شاخه‌ی جدید باشیم و بعد از فلگ، نام شاخه‌ی جدید خود را می‌نویسیم. ما می‌توانیم در این شاخه‌ها commit‌های زیادی را ایجاد کنیم و سپس ﺁن‌ها را با فرﺁیندی به نام merging (ادغام کردن)، به master برگردانیم. در دیاگرام زیر، نقطه‌ها نشانگر commit هستند. دو شاخه از master ایجاد شده است. در توسعه‌ی نرم‌افزار، ما غالبا بر خلاف شاخه‌ی master اصلی، این شاخه ها را "feature" می‌نامیم. شاخه‌ی ﺁبی دوباره با master ادغام شده و شاخه‌ی زرد هنوز هم در حال توسعه است. توجه داشته باشید که حتی اگر شاخه‌ی زرد بعد از شاخه‌ی آبی ایجاد شده بود، فقط تغییرات master در آن شاخه قابل مشاهده خواهد بود. اگر بعضی‌اوقات شاخه‌ی سومی ایجاد کنیم، تغییراتی از شاخه‌ی اصلی و آبی در شاخه‌ی سوم جدید وجود خواهد داشت.

دستور git merge

git merge همه‌ی commitهایی که در آن شاخه انجام داده بودیم را می‌گیرد و آن‌ها را به شاخه‌ی master می‌چسباند و کار شما را ذخیره می‌کند.

چرا از شاخه‌ها استفاده می‌کنیم؟

اگر شما به تنهایی کار می‌کنید، منطقی نیست که کارتان را به چند شاخه تقسیم کنید. چرا همه چیز را فقط در master ذخیره نمی‌کنید؟

تا زمانی که در مورد کار تیمی با سایر توسعه‌دهندگان فکر نکنیم، شاخه سازی کاملا واضح نخواهد بود. به این ترتیب، هر توسعه دهنده می‌تواند شاخه‌ی خود را داشته و تا زمانی که نیاز داشته باشد روی featureهای خود کار کند و در زمان مناسب ﺁن را merge نماید.

Github چیست؟

Github یک پلتفرم رایگان و هاست ابری برای کد است که برای استفاده‌ي شخصی به کار می‌رود. این پلتفرم با Git در کامپیوترهای شما و همکارانتان کار می‌کند و به عنوان Origin، برای هر کسی که روی کد کار می‌کند، خدمت خواهد کرد.

شما و همکارانتان به طور متناوب کدهای خودتان را در GitHub آپلود می‌کنید و GitHub به مرور زمان ابزاری را برای کمک به مدیریت تغییرات در کد فراهم می‌کند.

آپلود کدهایتان در Github

ابتدا باید یک حساب Github ایجاد کنید. شما می‌توانید از این حساب برای کل حرفه‌ی برنامه نویسی خود استفاده کنید و نکته‌ی مهمی که بهتر است رعایت کنید این است که از یک اسم حرفه‌ای یا ترجیحا از اسم واقعی خودتان استفاده کنید.

پس از ورود به سیستم، به دنبال + در بالای صفحه بگردید. روی New Repository کلیک کنید. یک نام برای ﺁن انتخاب کنید، بهتر است هم نام همان پوشه‌ای باشد که قبلا commitهای خود را در ﺁن ذخیره کرده بودید. سپس بر روی "Create Repository" کلیک کنید. اکنون می‌توانید آدرس url مورد نظر خود را که به آن هدایت شده‌اید را کپی کنید و در Origin کدهای خودتان تنظیم کنید.

git remote add origin

حالا ما به codebase دستور می‌دهیم که کدهای ما را در کجای فضای ابری ذخیره کند.

ما فرمان git remote add origin <your-url> را تایپ خواهیم کرد که origin را برای مخزن ما تنظیم می‌کند. حالا می‌توانیم origin خودمان را Push کنیم تا فضای ابری را در Github ذخیره کنیم.

git push

با فرض این‌که هنوز در شاخه‌ی master هستیم (یعنی شاخه‌ی دیگری را بررسی نکرده‌ایم)، اکنون می‌توانیم git push را تایپ کنیم و کد به GitHub می‌رود.

مشاهده‌ی کدهایتان

حالا کد شما در Github زندگی می‌کند. مثال‌ها و توضیحاتی که در مورد مراحل Github زدم را به‌طور خلاصه در این‌جا مشاهده می‌کنید.

شما می‌توانید با مشاهده‌ی وضعیت فعلی کد، روی فایل‌ها و پوشه‌های مخزن کلیک کنید. همچنین می‌توانید نسخه‌های قبلی کد را با کلیک کردن بر روی "X commits" در سمت راست، وسط مشاهده کنید. شما لیستی از commitهای انجام شده در repo را مشاهده خواهید کرد و اگر روی ﺁن‌ها کلیک کنید، می‌توانید فایل‌های پروژه‌ی خود را همان‌طور که در ﺁن زمان وجود داشت مرور کنید.

درخواست‌های Pull

ویژگی‌های زیادی برای Github وجود دارد که مهم‌ترین آن‌ها در همکاری با همکاران، ویژگی درخواست Pull است. یک درخواست Pull، که اغلب به آن PR هم گفته می‌شود، راهی برای مدیریت تغییرات دریافتی در codebase است. برای ایجاد این کار، شما باید یک شاخه‌ی جدید را در کامپیوتر خود بسازید و حداقل یک commit را در آن شاخه ایجاد کنید، سپس git push origin head را تایپ کنید تا آن شاخه به Github ارسال شود. شما می‌توانید نام شاخه‌ی خود را به جای head قرار دهید ولی بهتر است که همه چیز را دقیقا با هم هماهنگ کنید.

حالا وقتی به Github برگردید، باید ببینید که شاخه‌ی شما در دسترس است تا یک PR ایجاد کنید.

اگر روی دکمه‌ی "Compare & pull request" کلیک کنید، می‌توانید تنظیمات بسیاری را برای PR خود تغییر دهید. مهم‌تر از همه انتخاب عنوان و شرح توضیحات آن است. اگر با یک تیم به صورت گروهی کار می‌کنید، می‌توانید همکاران خود را تگ کنید تا از ﺁن‌ها بخواهید که کد شما را بازبینی کنند یا به پروژه‌ها چیزی اضافه کنند و یا بسیاری از ویژگی‌های دیگر که احتمالا هنوز هم به آن‌ها اهمیتی نمی‌دهید.

توجه داشته باشید که ما در حال مقایسه‌ی شاخه‌ها هستیم. در اینجا از شما می‌خواهیم که تغییراتی را که در شاخه‌ی (pr-example) داده شده است را به شاخه‌ی master اضافه کنید. اما ما می‌توانیم هر یک از شاخه‌های دیگر را در repo هدف قرار دهیم. پس فعلا متوجه شده‌اید که فقط شاخه‌ی master نیست که می‌توان به آن درخواست Pull داد.

هنگامی که روی دکمه‌ی "Create Pull Request" کلیک می‌کنید، با این صفحه مواجه خواهید شد:

می‌توانید تمام commitهای موجود در این شاخه را مشاهده کنید و همچنین می‌توانید درخواست Pull خودتان را merge کنید. آیا به خاطر دارید وقتی که داشتیم در مورد Git حرف می‌زدیم، چطور می‌توانستیم کد خودمان را merge کنیم؟ ما می‌توانیم همان عمل را با کد میزبانی ابری در GitHub انجام دهیم. اگر بر روی دکمه‌ی سبز رنگ "Merge pull request" کلیک کنید، تغییرات شما در master ادغام خواهند شد.

دستور git pull

آخرین دستوری که هم اکنون باید بشناسید، git pull است. اگر شما PR خود را به شاخه‌ی master در Github ادغام کنید، اکنون تغییراتی در origin ایجاد می‌شود که هنوز در رایانه‌ی خود ندارید. اگر شما شاخه‌ی master را بررسی کنید و سپس فرمان git pull origin master را اجرا کنید، تغییراتی که چندی پیش ادغام کرده بودید در رایانه‌ی شما خواهند بود.

➜  git-example git:(master) git pull origin master
From https://github.com/AmberWilkie/git-example
 * branch            master     -> FETCH_HEAD
Updating 67627dd..38ad2da
Fast-forward
 git.js | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

این Fast-forward به Catching up شاخه‌ی master و شاخه‌ي origin ما اشاره دارد. ما این روند را کامل کردیم:

۱. تغییرات در Local

۲. Push کردن به Github و ساخت PR

۳. ادغام کردن PR در داخل master

۴. Pull کردن master در کامپیوتر Local

وقتی گذراندن این مراحل برای شما آسان باشد، شما ۸۰ درصد از راه کسب مهارت در Git و Github را خواهید داشت.

منبع

چه امتیازی برای این مقاله میدهید؟

خیلی بد
بد
متوسط
خوب
عالی
در انتظار ثبت رای

/@Pooriarazmjoo

پوریا رزمجویی هستم

دیدگاه و پرسش

برای ارسال دیدگاه لازم است وارد شده یا ثبت‌نام کنید ورود یا ثبت‌نام

در حال دریافت نظرات از سرور، لطفا منتظر بمانید

در حال دریافت نظرات از سرور، لطفا منتظر بمانید