To sync your local repository with a remote one using Git, you'll perform a series of steps that include fetching changes, merging updates, and possibly resolving conflicts, akin to updating your personal copy of a shared document with the latest edits made by others.
The Big Picture
Imagine you and your friends are collaboratively writing a book. You have your own copy of the book, and there’s a central copy that everyone updates. To make sure your copy has all the latest changes, you periodically need to synchronize your copy with the central one. This is what syncing your local repository with a remote one in Git is like.
Core Concepts
- Remote Repository: The central place where all your team’s code resides.
- Local Repository: Your own copy of the project on your computer.
- Fetching: Pulling down the latest changes from the remote repository to your local repository.
- Merging: Integrating those changes into your local working copy.
- Pulling: A combination of fetching and merging.
- Pushing: Sending your changes from your local repository to the remote repository.
Detailed Walkthrough
Fetch the latest changes from the remote repository:
Command:
git fetch origin
This command fetches all the changes from the remote repository (commonly named
origin
) without merging them into your working copy. It updates your remote-tracking branches.git fetch origin
Merge the changes into your local branch:
Command:
git merge origin/main
(or whatever the main branch is called)This merges the fetched changes into your current branch.
git merge origin/main
1,2. Pull the latest changes from the remote repository:
- Command: git pull
- This command is essentially a shortcut that combines git fetch
and git merge
in one step.
```bash
git pull
```
Resolve any conflicts:
- If there are changes in the same parts of files that you have also modified, Git will prompt you to resolve these conflicts manually.
Push your changes to the remote repository:
Command:
git push
Once your local copy is up-to-date and you’ve made your changes, you can push them to the remote repository.
git push origin main
Understanding Through an Example
Imagine you and a friend are both working on a document. Your friend makes changes and updates the shared copy (remote repository). To get these changes:
- Fetch: You get a notification of all changes your friend made (without applying them to your document yet).
- Merge: You apply these changes to your copy of the document.
1,2. Pull: You do both steps in one go. - Resolve conflicts: If you both made changes to the same paragraph, you discuss and decide whose changes to keep.
- Push: Once you’ve made your edits, you update the shared copy with your new changes.
Conclusion and Summary
Syncing your local repository with a remote one involves fetching updates from the remote repository, merging those updates into your local repository, and resolving any conflicts that arise. The key commands are git fetch
, git merge
, git pull
, and git push
.
Test Your Understanding
- What is the difference between
git fetch
andgit pull
? - How do you resolve conflicts that arise during a merge?
- What command would you use to send your local changes to the remote repository?
Reference
For more detailed information, you can check the Git documentation.
'100===Dev Ops > Git' 카테고리의 다른 글
Git 제대로 이해하기: 시간여행자의 코드 관리 비법 🚀 (2) | 2024.11.17 |
---|---|
Gitlab Introduced (0) | 2024.06.11 |
Git Introduced (0) | 2024.05.26 |