اگر شما یک برنامهنویس تازهکار هستید، گیت را باید در لیست اولیتهای خود برای یادگیری در نظر بگیرید. زمانی که وارد یک شغل در حوزه برنامهنویسی شوید، گیت چیزی خواهد بود که به صورت روزانه با آن کار خواهید کرد.
چه چیزهایی را میتوان از این مطلب انتظار داشت؟
در این مطلب ما یک مقدمه از گیت همچنان روشی برای شروع کار با آن را به شما ارائه خواهیم کرد.
- گیت چیست؟
- آشنایی با اصطلاحات دنیای گیت.
- استفاده از گیت از طریق خط فرمان.
گیت یک سیستم کنترل نسخه یا Version Control System است که به اختصار به آن VCS میگویند. اما سوالی که پیش میآید این است، VCS چیست؟ یک سیستم VCS تمام تغییراتی که روی یک فایل انجام میشود را ردیابی و شناسایی میکند. البته این فایل باید در اختیار VCS قرار گرفته باشد.
در کنار این مورد، شما با استفاده از این تکنولوژی میتوانید بین توسعهدهندگان مختلف از امکانات همکاری و به اشتراک گذاری پروژهها استفاده کنید. این کار بدون تاثیر مخرب گذاشتن روی همدیگر انجام میشود.
هر فایلی که برای ردیابی در اختیار VCS قرار میگیرد، قسمتهای متفاوتی از آن ردیابی میشود که میتوان به صورت منحصر به فرد به آنها دسترسی داشت. برای مثال:
- چه چیزهایی از فایل تغییر کرده است؟
- چه کسی این تغییرات را اعمال کرده است؟
- چه زمانی این تغییرات اتفاق افتادهاند؟
برای آنکه بتوانید از طریق گیت، یک سیستم همکاری با توسعهدهنده را داشته باشید، نیاز است که از نسخههای گیت که روی یک سرور میزبانی میشوند استفاده کنید. Github، Bitbucket و MVSTS نمونههایی از این پلتفرمها هستند که تقریبا در تمام آنها یکسری ویژگیهای مشترک دیده میشود.
منظور از مخزن یا Repository در گیت چیست؟
یک مخزن به دایرکتوری گفته میشود که گیت روی آن نظارت دارد. در اصطلاح سادهتر آن را Repo مینامند. یک مخزن ممکن است که چندین فایل مختلف و چندین دایرکتوری و ساب-دایرکتوری را در خود داشته باشد.
در داخل هر مخزن یک دایرکتوری مخفی به نام .git وجود دارد که شامل تمام فایلها و دایرکتوریهایی میشود که گیت برای دنبال کردن تغییرات به آنها نیاز خواهد داشت.
اگر ما .git را حذف کنیم، گیت دیگر قابلیت ردیابی فایلهای ما را ندارد و دیگر مخزنی نیز وجود نخواهد داشت. مخازنی که روی یک کامپیوتر به صورت محلی قرار میگیرند به local repository یا مخزن محلی معروف هستند. از طرفی دیگر مخازنی که روی پلتفرمهای میزبانی شده گیت قرار میگیرند remote repository یا مخزن ریموت نامگذاری میشوند.
دانلود و نصب گیت
دانلود و نصب گیت کار بسیار سادهای است. تنها کافیست به صفحه دانلود مراجعه کرده و براساس سیستم عاملی که در حال کار با آن هستید، نسخه مورد نظرتان را دانلود کرده و در نهایت یک پروسه نصب نرم افزار را پشت سر بگذارید. همچنین مطالعه مستندات گیت میتواند مفید باشد.
پیادهسازی یک مخزن گیت
قبل از آنکه از گیت بخواهیم فایلهای ما را دنبال کند، نیاز است که گیت را در بخشی از فضای کاریمان پیادهسازی کنیم. در حقیقت باید دایرکتوری کاری را به یک مخزن تبدیل کنیم. برای چنین کاری نیاز است که از طریق محیط خط فرمان وارد عمل شوید:
خط فرمان یا ترمینال خود را باز کرده و با استفاده از دستورات Change Directory یا cd وارد دایرکتوری مورد نظرتان شوید. بعد از اینکار دستور زیر را وارد نمایید:
git init
این دستور فرایند پیادهسازی گیت روی دایرکتوری مورد نظر را اجرا میکند. بخشی از این فرایند به قرارگیری دایرکتوری .git روی دایرکتوری کنونی اختصاص داده میشود. همانطور که گفته شد، این دایرکتوری شامل فایلهایی میشود که گیت برای دنبال کردن فایلهای شما به آن نیاز خواهد داشت.
ممکن است به نظرتان بیاید که دایرکتوری کنونی شما تغییری نکرده و مانند سابق تنها یک دایرکتوری ساده است، اما گیت نظر متفاوتی دارد، از حال به بعد دایرکتوری شما برای گیت تبدیل به یک مخزن شده است و از آنجایی که این مخزن روی سرور یا یک فضای میزبانی قرار نگرفته، به یک مخزن محلی معروف است.
وضعیت مخزن
برای آنکه وضعیت مخزن خودتان را مشاهده کنید و ببینید که چه چیزهایی توسط گیت دنبال میشود، نیاز است که از دستور زیر استفاده نمایید:
git status
البته از آنجایی که تقریبا در چندین مرحله دیگر این دستور را به کار میبریم، بنابراین فعلا نیازی به ارائه توضیحات بیشتر نیست.
دنبال کردن یک مخزن
با وجود آنکه ما یک دایرکتوری را تبدیل به یک مخزن کردیم، اما هیچ چیزی به صورت خودکار دنبال نمیشود. ما باید به صورت دستی به گیت بگوییم که این محتوا را دنبال کند.
برای انجام چنین کاری ما باید از دستور git add استفاده نماییم. سینتکس کلی این دستور به صورت زیر است:
git add file.txt
در این حالت گیت فایلی را با نام file.txt دنبال میکند. البته میتوانید چندین فایل دیگر را نیز وارد کنید، برای جداسازی آنها نیز کافیست که از یک ویرگول استفاده نمایید. با این حال اگر بخواهید که تمام محتوای داخل یک مخزن را دنبال کنید کافیست به صورت زیر عمل نمایید:
git add .
یک دستور دیگر نیز وجود دارد که دقیقا همین کار را انجام میدهد:
git add –A
بیایید تصور کنیم که فایلهای زیر را در داخل مخزن خود داریم:
همانطور که مشاهده میکنید، ما یک دایرکتوری با نام .git داریم. زمانی که برای اولین بار git init را اجرا میکنیم، محتویات داخل دایرکتوری .git به صورت زیر خواهد بود:
اما درست بعد از آنکه دستورات دیگری را در گیت اجرا کردیم، مخزن گیت ما به صورت زیر در خواهد آمد:
برای آنکه ببینیم چه فایلهایی توسط گیت دنبال میشود میتوانیم از دستور قبلی git status استفاده کنیم:
git status
On branch master
No commits yet
Untracked files:
(use “git add <file>…” to include in what will be committed)
HelloWorld.html
Notes.txt
README.md
nothing added to commit but untracked files present (use “git add” to track)
از آنجایی که ما هنوز به صورت واقعی هیچ فایلی را دنبال نکردهایم، در خروجی دستور status هیچ فایلی دنبال نمیشود. بیایید به یک مرحله عقبتر برگردیم و چند فایل واقعی را با استفاده از دستور git add به گیت معرفی کنیم:
$ git add HelloWorld.html Notes.txt
حال بیایید یک بار دیگر دستور git status را وارد کرده و خروجی را مشاهده نماییم:
git status
On branch master
No commits yet
Changes to be committed:
(use “git rm — cached <file>…” to unstage)
new file: HelloWorld.html
new file: Notes.txt
Untracked files:
(use “git add <file>…” to include in what will be committed)
README.md
همانطور که مشاهده میکنید حال ما دو فایل جدید داریم که توسط گیت دنبال میشوند، اما یک فایل دیگر با نام README.md نیز وجود دارد که گیت آن را دنبال نمیکند.
در واژهشناسی گیت به این کاری که انجام دادیم، استیجینگ یا Staging یک فایل گفته میشود. پس در واقع ما در حال حاضر دو فایل را به مرحله استیج بردهایم.
اما باز هم گیت به صورت کامل تغییرات فایلهای ما را دنبال نمیکند، تا زمانی که آنها را کامیت نکنیم.
کامیت فایلهای استیج شده
برای کامیت کردن فایلهایی که استیج کردهاید کافیست به صورت زیر عمل نمایید:
git commit -m ‘Initial Commit
برای هر کامیتی که ایجاد میکنید، نیاز است که یک پیام را نیز برای آن قرار دهید. –m پارامتری است که قابلیت الصاق یک کامنت یا پیام را به کامیت میدهد. اگر میخواهید که تمام کامیتهای انجام شده را مشاهده بکنید، میتوانید از دستور git log بهره ببرید.
git log
commit 8525b32ffcb92c731f5d04de7fe285a2d0ebe901 (HEAD -> master)
Author: shahzan <sxxxxxxn@gmail.com>
Date: Sun Apr 28 01:12:20 2019 +0100
Initial Commit
هر زمانی که یکی از فایلهای استیج شده تغییری بکند، نیاز است که از ابتدا پروسه git add را آغاز کنید و آن را به حالت استیج ببرید. بعد از آن نیز یک بار دیگر باید فرایند کامیت کردن را انجام دهید. این فایلها تا زمانی که استیج و کامیت نشوند، توسط گیت به عنوان فایلهای تغییریافته یا modified شناخته میشوند.
برای نمایش بهتر این قضیه من یکسری تغییرات را در فایل Notes.txt اعمال کردم. حال اگر دستور git status را اجرا کنید، با خروجی زیر روبرو خواهید شد:
git status
On branch master
Changes not staged for commit:
(use “git add <file>…” to update what will be committed)
(use “git checkout — <file>…” to discard changes in working directory)
modified: Notes.txt
Untracked files:
(use “git add <file>…” to include in what will be committed)
README.md
no changes added to commit (use “git add” and/or “git commit -a”)
با توجه به خروجیهای بالا، متوجه خواهید شد که فایل Notes.txt تغییراتی کرده اما هنوز برای کامیت کردن استیج نشده است. برای اینکار باید پروسه git add و git commit را یکبار دیگر اجرا کنید:
git add Notes.txt
Shahzan@BlackBox MINGW64 /d/Medium Post Pics/Git/Source Code (master)
$ git status
On branch master
Changes to be committed:
(use “git reset HEAD <file>…” to unstage)
modified: Notes.txt
Untracked files:
(use “git add <file>…” to include in what will be committed)
README.md
همانطور که مشاهده میکنید، فایل Notes.txt استیج شده و آماده کامیت شدن است.
git commit -m ‘Notes.txt file updated’
[master 184fcad] Notes.txt file updated
1 file changed, 3 insertions(+), 1 deletion(-)
حال اگر دستور git log را یک بار دیگر اجرا کنید، متوجه میشوید یک یک کامیت دیگر اضافه شده است:
git log
commit 184fcad4185296103cd9dba0da83520399a11383 (HEAD -> master)
Author: shahzans <shuaib.shahzan@gmail.com>
Date: Sun Apr 28 01:15:38 2019 +0100
Notes.txt file updated
commit 8525b32ffcb92c731f5d04de7fe285a2d0ebe901
Author: shahzans <shuaib.shahzan@gmail.com>
Date: Sun Apr 28 01:12:20 2019 +0100
Initial Commit
نادیده گرفتن فایلها
در داخل یک مخزن، ممکن است فایلهایی وجود داشته باشند که اطلاعات حساسی را در خود نگهداری میکنند و نباید توسط گیت ردگیری شوند.
.gitignore فایلی است که برای ایجاد چنین حالتی به شما کمک میکند. با استفاده از این فایل میتوانید تعیین کنید که دقیقا چه فایلهایی باید دنبال شود.
برای عملی کردن این موضوع فایل .gitignore را ایجاد کرده و نام فایلهایی که نمیخواهید گیت آنها را دنبال کند به صورت مستقیم بنویسید. البته میتوانید تکنیک دیگری را نیز در نظر بگیرید. برای مثال بگویید تمام فایلهایی که پسوند .md دارند را نادیده بگیر. برای چنین کاری کافیست *.md را در فایل .gitignore وارد کنید.
در پایان
گیت یک ابزار فوقالعاده است، در حقیقت چیزیست که هر توسعهدهنده مدرن باید بداند و حتما در رزومه کاریاش قرار داشته باشد. کارهای بسیار زیاد دیگری مانده که میتوانید با گیت انجام دهید. اگر قصد یادگیری بیشتری در این زمینه را دارید پیشنهاد میکنم به دوره آموزشی «آموزش گیت و گیت هاب» و «مدیریت پروژه های متنباز با git و github» مراجعه نمایید.
دیدگاه و پرسش
در حال دریافت نظرات از سرور، لطفا منتظر بمانید
در حال دریافت نظرات از سرور، لطفا منتظر بمانید