만약에 로컬 레포지터리에서 푸시를 해주고 다음 푸시를 해주기 전에 리모트 레포지터리에 변화 생기면 어떡할까요? 한번 해보겠습니다. 먼저 깃허브로 가서 마스터 브랜치의 내용을 수정해보겠습니다.
연핀 모양의 기호를 클릭하면 수정할 수 있습니다. 나누기 함수를 추가해주고 커밋을 해보겠습니다.
이제 로컬 레포지터리에서 이름이 다른 나누기 함수를 추가해보겠습니다.
커밋을 한 뒤에 푸시를 해보겠습니다.
에러가 뜨네요.. 이처럼 리모트 레포지터리에 변화가 생긴 경우 push를 하게 되면 오류가 납니다. 이를 해결해주기 위해서는 pull을 먼저 해주고 내용을 고친 뒤에 다시 푸시를 해주면 됩니다. 풀을 해보겠습니다.
그런데 merge conflict가 발생했습니다! 그 이유는 리모트 레포지터리의 최신 커밋들을 가져와서 병합하는 과정까지가 git pull이기 때문입니다. conflic를 해결하는 방법은 working directory로 가서 직접 수정해주면 된다고 했었죠?
코드를 아래와 같이 바꿔준 다음에 커밋을 하면 충돌이 해결됩니다.
그러면 이제 푸시를 해줘도 문제가 없겠네요. 푸시를 해보겠습니다!
이제는 잘 되네요.
정리해보겠습니다. A, B 개발자가 하나의 리모트 레포지터리를 가져와서 각각 새로운 커밋을 했다고 가정해보겠습니다. B 개발자가 먼저 푸시를 해주면 A 개발자는 푸시를 해줄 수가 없습니다. A 개발자가 푸시를 해주기 위해서 A 개발자는 풀을 이용해 리모트 레포지터리의 최신 커밋을 자신의 로컬 레포지터리에도 반영시켜 줘야합니다.
그런데 리모트 레포지터리의 내용들을 머지하지 않고 가져오기만 하는 기능이 있습니다. ' git fetch '명령어를 사용하면 됩니다. git fetch는 리모트 레포지터리에서 가져온 브랜치의 내용을 머지하기 전에 점검할 필요가 있을때 사용합니다.
예를 들어 리모트 레포지터리에 프로젝트와 전혀 상관없는 코드가 있다고 가정해보겠습니다. 제 리모트 레포지터리에 'hello'를 출력하는 코드를 추가해 보겠습니다.
git bash 터미널에서 git fetch 명령어를 입력해줍니다.
이제 로컬 레포지터리와 리모트 레포지터리를 비교해보겠습니다. git diff master origin/master 명령어를 입력하면 됩니다.
print('hello')는 필요 없으니 이를 지우고 다시 push를 해주겠습니다. 푸시를 해주기 전에 머지를 하고 working directory에서 print('hello')를 지워줍니다.
다시 깃허브에 가서 확인해보겠습니다.
print('hello')가 잘 지워진 것을 확인할 수 있습니다.
이처럼 리모트 레포지터리의 내용을 가져올때 pull과 fetch를 사용할 수 있습니다. pull은 가져옴과 동시에 병합을 해주는 기능이고, fetch는 내용을 가져오기만 해주는 기능입니다
'Git' 카테고리의 다른 글
[Git] remote repository에 올라간 커밋 취소하기 (0) | 2022.01.14 |
---|---|
[Git] 누가 기록했는지 확인하기 (0) | 2022.01.14 |
[Git] merge 완전정복 (0) | 2022.01.14 |
[Git] Reset vs Checkout (1) | 2022.01.14 |
[Git] HEAD와 branch의 관계 (0) | 2022.01.14 |