Git 이란 무엇인가?
Git
이란 버전 관리 시스템(VCS, Version Control System)의 한 종류이다.
그렇다면 여기서 말하는 버전 관리란 무엇이고, 왜 필요할까?
버전 관리란 이름 그대로 여러 파일을 하나의 버전으로 묶어 관리하는 것이다. 버전 관리를 예를 들어 말해보자.
예를 들어, 우리가 제출해야 하는 레포트가 하나 있다. 처음에 ‘report.txt’를 만들었다가 내용이 바뀔 경우 ‘report_최종.txt’으로 바꿨다가 다시 수정을 거치면서 ‘report_진짜최종.txt’ 이런식으로 만든 경험이 있을 것이다.
우리는 여러 파일들을 복사, 저장, 백업 등을 하였고 이것을 버전 관리라고 부른다.
Git의 필요성
Git의 필요성을 말하기 위해 예를 하나 들어보자.
나와 나의 동료가 동시에 같은 웹사이트에서 페이지를 업데이트하고 있다고 하자.
나는 무언가를 변경하고 저장한 다음 웹사이트에 그것을 업로드한다. 그런데 이때 문제는 동료가 동시에 같은 페이지에서 작업할 때이다. 확인하지 않고 동시에 작업을 한다면 누군가의 작업은 겹쳐쓰여질 것이고 지워질 것이다.
깃과 같은 버전관리 시스템은 그런 일을 방지해준다.
나와 동료는 같은 페이지에 각자의 수정사항을 각각 업로드할 수 있고, 깃은 두 개의 복사본을 저장한다.
그런 후 우리는 어떤 작업도 잃어버리지 않고 변경사항들을 병합(Merge)할 수 있다. 깃은 이전에 만들어진 모든 변경사항의 “스냅샷”을 저장하기 때문에 이전 시점의 어떤 버전으로 되돌릴 수도 있다.
이렇기에 프로젝트를 진행할 때 Git은 아주 유용하며 필수적으로 많이 사용한다. 프로젝트에서 내가 작업한 부분을 올리고 다른 사람이 작업한 부분을 올려 스냅샷이 저장되고 어떠한 코드도 손실되지 않고 나눠서 작업한 파일을 병합할 수 있기때문이다.
Git 기본 용어
Git을 사용하기 위해 알아야 할 용어들이 있다.
Repository : 저장소를 의미하며, 저장소는 히스토리, 태그, 소스의 가지치기 혹은 branch에 따라 버전을 저장한다. 저장소를 통해 작업자가 변경한 모든 히스토리를 확인 할 수 있다.
Working Tree : 저장소를 어느 한 시점을 바라보는 작업자의 현재 시점이다.
Staging Area : 저장소에 커밋하기 전에 커밋을 준비하는 위치이다.
Commit : 현재 변경된 작업 상태를 점검을 마치면 확정하고 저장소에 저장하는 작업이다.
Head : 현재 작업중인 Branch를 가리키는 것이다.
Branch : 가지 또는 분기점을 의미하며, 작업을 할때에 현재 상태를 복사하여 Branch에서 작업을 한 후에 완전하다 싶을때 Merge를 하여 작업을 한다.
Merge : 다른 Branch의 내용을 현재 Branch로 가져와 합치는 작업을 의미한다.
Git 기본 용어
Git을 사용하기 위해 알아야 할 용어들이 있다.
Repository : 저장소를 의미하며, 저장소는 히스토리, 태그, 소스의 가지치기 혹은 branch에 따라 버전을 저장한다. 저장소를 통해 작업자가 변경한 모든 히스토리를 확인 할 수 있다.
Working Tree : 저장소를 어느 한 시점을 바라보는 작업자의 현재 시점이다.
Staging Area : 저장소에 커밋하기 전에 커밋을 준비하는 위치이다.
Commit : 현재 변경된 작업 상태를 점검을 마치면 확정하고 저장소에 저장하는 작업이다.
Head : 현재 작업중인 Branch를 가리키는 것이다.
Branch : 가지 또는 분기점을 의미하며, 작업을 할때에 현재 상태를 복사하여 Branch에서 작업을 한 후에 완전하다 싶을때 Merge를 하여 작업을 한다.
Merge : 다른 Branch의 내용을 현재 Branch로 가져와 합치는 작업을 의미한다.