Git
[Git] pull과 충돌
qoth_0
2023. 12. 11. 09:48
728x90
반응형
git pull과 충돌
- 수정 후 수정사항 업로드
- add, commit, push
- 수정사항 다운로드
- git pull
- origin이 수정되어 local과의 차이 발생시
- origin의 변경사항은 local에서는 추적불가능
- vscode의 source control의 변경사항 인지는 local repository에 대한 변경인지
→ push 했을 때 다른사람이 먼저 수정해서 올려놨으면 origin과 로컬이 다르기 때문에 내려받은 후 수정을 해야됨
- git pull origin 브랜치명
- ex)git pull origin main
- origin을 기준으로 local을 update
- fetch + merge까지 되는 것 → 바로 origin내용으로 바뀜
- pull은 working directory까지 반영
- 별도의 브랜치명 명시 안하면 현재 checkout 된 branch에서 pull
- 만약 로컬의 변경파일과 origin의 변경파일이 같이 변경되면 충돌발생 가능성
- 이 때는 git fetch 사용해서 비교한 후 merge 해야함
- ex)git pull origin main
실습
- origin main에서 test3.txt 파일 변경 발생
→ local에서 변경사항 인지 가능한지 vscode에서 확인, 소스트리도 확인
data:image/s3,"s3://crabby-images/08b91/08b9161a948bf3b038ccbd2284535822f999c6c2" alt=""
data:image/s3,"s3://crabby-images/0c40b/0c40b553a0c4d444ab4ee5dd24eb6abf2898f084" alt=""
data:image/s3,"s3://crabby-images/b66ff/b66ffd601c3f67dd0e7fb446f611030e3f5fcff4" alt=""
- 내 local에서 test3.txt 파일 변경하여 push 시도
data:image/s3,"s3://crabby-images/6f434/6f4345365cbd7617e42c849e48706a91c6bbf83a" alt=""
data:image/s3,"s3://crabby-images/acf15/acf156d7bc8ad2eefd0745e10ea29de1200319ff" alt=""
- 충돌로 push 불가 → 일단 force를 통해 강제 push
data:image/s3,"s3://crabby-images/9dba4/9dba47208ec8d7f8a8f444e320bb0907c79671f0" alt=""
data:image/s3,"s3://crabby-images/5499c/5499c0599c3c1585a745aeaefe95c791c7e609c0" alt=""
⇒ git pull origin main하면 origin에서 바꾼 내용이 vs코드에 반영됨
- 로컬에서 test1.txt 파일 수정 후 커밋(push x), github에서 test2.txt 파일 수정 후 git pull - 서로 다른 파일
data:image/s3,"s3://crabby-images/5ac5b/5ac5bc16974afe27cbbacbb0b89882910822d077" alt=""
로컬 수정
data:image/s3,"s3://crabby-images/39615/39615ae4302f6b9d8bce2f0b5570f50ce0c3056f" alt=""
커밋
data:image/s3,"s3://crabby-images/cbbf6/cbbf6c818faf18ef11d90fc2d6e8e2d9a26d9cba" alt=""
github수정
data:image/s3,"s3://crabby-images/edf3a/edf3ab67c140c4b99afb7edd300948d38574c93c" alt=""
git pull origin
data:image/s3,"s3://crabby-images/a7d5f/a7d5fb0113aa3a0367935b55545f7fb34ecc860c" alt=""
⇒ test2.txt 내용이 로컬에도 반영됨 - 충돌 x (다른 파일이기 때문)
728x90
반응형