[깃, Git] Git diff 특정 branch(브랜치) / 특정 commit 비교하기
[깃, Git] Git diff 특정 branch(브랜치) / 특정 commit 비교하기
앞선 포스팅에서, git diff를 이용하여, 특정 파일의 변경사항을 확인하는 방법에 대해서 확인을 하였습니다. 아마도, 많은 분들은 이 부분에 대해서 인지하고 있었을 것이고 매우 유용하게 사용할 것이라고 생각합니다. 그러면 이 번에는 git에서 가장 핵심적인 요소인 branch(브랜치)간의 차이점와 commit(커밋)간 차이점을 비교하는 방법에 대해서 이야기를 해보고자 합니다.
[깃, Git] Git diff 특정 파일의 변경사항 확인하기
그럼 이번 포스팅에서는 총 2가지 관점에서 접근을 해보도록 하겠습니다.
1. branch(브랜치) 간의 차이점 확인
2. commit(커밋) 간의 차이점 확인
Branch 간의 차이점 확인
브랜치 사이에서 많은 파일이 생성될 수도 있고, 삭제될 수도 있습니다. 물론, 이 부분은 commit에서도 동일합니다. 그런 관점에서 한번 살펴보도록 하겠습니다.
먼저, branch간의 비교를 하기 위해서는 다음 명령어를 입력해주시길 바랍니다.
git diff a_branch..b_branch
git diff a_branch b_branch
물론, 위에서 직관적으로 보기 위해서 각 branch간의 식별하기 위한 문자를 ‘..’으로 나열하였지만 이 부분을 공백으로 작성하셔도 됩니다. (실제 작업하실때에는 ..보다는 공백을 더욱 많이 사용합니다.) 그러면 다음 부분에 대해서 간단한 예제를 통해서 다음 부분에 대해서 살펴보겠습니다.
먼저, 앞선 포스팅에서 사용한 예제를 그대로 활용할 예정입니다. 저는 여기에서, 일단, 다음 명령어를 통해서 target1이라는 branch(브랜치)를 생성해보도록 하겠습니다. (그런 후에 자동으로 target1으로 branch 전환해줍니다.)
$ git switch -c target1
그러면 다음과 같은 화면이 나타날 것입니다. 저 같은 경우에, 파일 수정을 진행하기 위해서, 윈도우 탐색기를 열 수 있는 "start . "명령어 또한 실행을 시켰습니다.
먼저, 여기에서, 최초 number.txt 라는 파일의 열어보도록 하겠습니다.
위에서 보이는 바와 같이 몇몇 숫자가 빠져 있는 것을 알 수 있습니다. 여기에서 저는 5~7열을 삭제하겠습니다.
그리고 나서 위에서 수정한 항목들에 대해서 git add 및 git commit을 진행해줍니다.
그리고 나서 약간의 변화를 더 주기 위해서, 다시 다음명령어를 통해서 mster 브랜치로 전화을 하도록 하겠습니다.
$ git switch master
그리고 touch명령어를 이용해서, master_h.txt파일을 하나 생성하도록 하겠습니다.
$ touch master_h.txt
위에서 생성한 master_h.txt 파일을 다음과 같이 수정을 하였습니다. (변경점만 확인하면 되기 떄문에 많은 부분을 입력하기에 앞서, 변경점만 확인하는 목적이기 때문에 간단한 문구만 입력하였습니다.)
그리고 나서, number.txt 부분에서도 마지막에 있는 "ten"이라는 글자을 삭제하였습니다.
위에까지 수정을 하고 나서, 수정한 부분에 대해서 다음 명령어를 통해서 확인하였습니다.
$ git status
위의 명령어를 실행하면 다음과 같은 결과를 확인할 수 있습니다.
그리고 위에 파일을 git add 및 git commit을 진행하도록 하겠습니다. 그러면 이제는 master와 target1 branch을 비교해보도록 하겠습니다.
git diff master..target1
위의 명령어를 실행하면 다음과 같은 결과 가 나타나는 것을 확인할 수 있습니다.
위에서 보이시는 바와 같이 a 기준은 앞서 입력한 master branch(브랜치)이고, b는 나중에 입력한 target1입니다. 그러면 반대로 입력을 해보도록 하겠습니다.
이 부분에 대해서 결과를 읽는 방법은 이전 포스팅을 참조하시면 될것입니다.(하단에 링크 삽입)
commit(커밋) 간의 차이점 확인
물론, 위에서 본 branch(브랜치)간의 비교점을 확인하는 것은 매우 중요합니다. 하지만, 이보다 각 commit 사이에서의 차이점도 비교가 필요로 합니다. 그러면 이제는 commit간의 비교하는 방법에 대해서 이야기를 해보겠습니다. 먼저 다음 명령어를 통해서 비교를 할 수 있습니다.
git diff commit_hash1..commit_hash2
먼저 다음 명령어를 통해서, commit 기록을 살펴보겠습니다.
$ git log --oneline
위의 출력된 앞에 헤시를 통해서 다음과 같이 명령어를 입력할 수 있습니다.
git diff 603807c..651431f
위에서와 같이 각 commit 사이에서의 차이점을 비교할 수 있습니다.
이번 포스팅에서는 [깃, Git] Git diff 특정 branch(브랜치) / 특정 commit 비교하기라는 주제로 포스팅을 했습니다. 이번 까지 해서, diff에 대해서는 대부분 다루어봤습니다. gitkraken을 통해서, 해당 부분에 대해서 gui 상으로 차이점을 어떻게 보는지에 대해서도 블로그 포스팅을 진행해볼 요량입니다. 혹 궁금하신 점이나 문의 사항이 있으시면 언제든지 댓글 및 방명록에 글 남겨주시길 바랍니다.