-> pathspec 'testA' is in submodule 'A'라는 에러 메세지 발생
결과적으로 하위 디렉토리를 git으로 관리할경우 하위 디렉토리는 독립적으로 분리되며, 따로 관리해주어야 한다는 것을 알수있었다.
그러면 planA로 만들기 귀찮아서 planB처럼 하려고 하면 나중에 관리하기 더욱 귀찮아진다는 것. 따라서 현재 내 상황(데탑/노트북 왔다갔다 하기 귀찮아서 git으로 관리하려는 상황)에서는 Plan A가 적합하다.
그러면 PlanB 처럼 따로 하위프로젝트를 git으로 관리하는 경우가 있는데, 왜 이렇게 불편하게 독립적으로 관리할까?
우선 이렇게 하위 프로젝트를 git으로 따로 관리하는 것을 submodule이라고 한다. 불리는 이름과 같이 모듈을 독립적으로 관리하기 위함이다.
공통모듈은 여러 프로젝트에 동시 적용 가능하다는 범용성을 갖추어야 한다. 이런 공통 모듈의 경우 범용적으로 적용될 수 있는 코드만 수정하여 사용하도록 독립적으로 관리해야 효율적으로 공통모듈을 관리할 수 있다.
가령 공통모듈을 독립적으로 관리 안한다고 했을때를 가정해보자
프로젝트 A에서 공통모듈을 가지고 온 후 A프로젝트 환경에 적합하게 수정 후 commit을 치면 공통모듈 또한 변경이 된다. 그러면 이 공통 모듈은 더이상 공통모듈이 아닌 A프로젝트에서만 사용 가능하게 된다. 따라서 공통모듈을 독립적으로 관리한다면 A프로젝트에서 공통모듈 코드를 수정 후 A프로젝트 repository로 push해도 공통모듈에는 적용이 안되기 때문에, 안전하게 공통모듈을 관리할 수 있게 되는 것이다.
tag 작성 : git tag -a {tag id} -m "{tag message}" tag 확인 : git tag tag push : git push {Remote Address} {tag id} commit log에서 tag 확인 : git log --decorate tag 삭제 : git tag -d {tag id} OR git tag --delete {tag id}
그래서 오늘은 속성 git tag 긋기!
tag를 긋는 이유는 아주아주 간단 합니다.
어느 버전인지를 알아보기 위함이죠
현재 어느 Commit까지 Release가 되었는지, 아니면 어느 시점부터 프로젝트가 다른 프로젝트와 Merge가 되었는지 등을 확인하기 위한 용도 입니다.
다음 아래 사진과 같은 commit log에 git tag를 작성하는 방법을 알아보겠습니다.
그림 1. git tag 긋기 01
1. tag 작성하기
위 사진에 화살표로 표기 된 commit에 새로운 Project의 시작점이라고 표기하기 위해서 "ERP_HR/Salary_Management_ver.1.0.1"를 그어보겠습니다
$git tag -a {tag id 입력} -m "{사용할 메세지 입력}" 예제 사용 명령어 : git tag -a ERP_HR/Salary_Management_ver.1.0.1 -m "ERP_HR/Salary_Management_ver.1.0.1"
그림 2. git tag 작성하기
2. tag 확인하기
이상이 없이 태그가 작성되면 작성되었는지 확인 합니다. 확인 명령어는 : git tag
그림 3. git tag 확인하기
3. 작성한 tag commit log에서 확인
이제 다시 commit log를 보면 아래 사진과 같이 tag가 표기 됩니다. 참고로 tag log까지 같이 보려면 $git log --decorate 이렇게 옵션을 줘야 표기 됩니다.
그림 4. commit log에서 작성한 tag 보기
4. tag push 하기
현재는 저의 작업 폴더에만 tag가 작성된것 이기 때문에, git tag를 작성해도 Remote로 Push 해주어야 합니다.
명령어는 일반 push와 동일합니다만, 작성한 tag만 push할 경우 $ git push {remote name} {tag id} 로 작성 합니다.
위 예제의 경우 $git push origin ERP_HR/Salary_Management_ver.1.0.1 라고 입력 하면 되겠져?
그림 5. tag push
이렇게 뜨면 완료!
tag의 장점은 checkout할 경우 tag id로도 가능하다는 것 입니다. 그래서 체크 포인트를 잘 작성하면 트러블 이슈 관리에 도움이 되겠죠!
1) 개인 노트북으로 프로그래머스 코딩테스트 문제를 Eclipse를 이용해 풀고있었다. 2) 그러던 중 데스크톱과 연동을 하면 좋을 것 같아서 Git으로 관리하기로 결정 3) 이미 사용하던 프로젝트 Repository와 어떻게 연동할까!?
- 순서 요약 정리 (git Bash 사용함)
1. 먼저 내 github 홈페이지에 새로운 Repository를 만든다. 2. 이것을 git Bash를 켜고 내가 관리할 폴더에 Clone 한다. 3. 여기에 기존 프로젝트중 필요한 것들을 clone한 폴더로 복사한다. 4. 복사 후 폴더로 들어간 다음 git status로 상태를 보면 다음과 같이 방금 변경 된 내용들이 출력 될 것이다. 5. 이것을 모두 add 한다. 6. 그 다음 commit 이후 push 하면 끝!!!
시작
1. 먼저 내 github 홈페이지에 새로운 Repository를 만든다.
그림 1. github 홈페이지에 new Repository 생성
2. 이것을 git Bash를 켜고 내가 관리할 폴더에 Clone 한다.
그림 2. git clone
clone 방법은 " git clone https://github.com/{Repo 주소}/{Repo 이름.git} {사용할 프로젝트 이름} "을 입력하면 위 사진처럼 clone 된다.
3. 여기에 기존 프로젝트중 필요한 것들을 clone한 폴더로 복사한다.
그림 3. 기존 프로젝트 clone 받은 폴더로 복사
4. 복사 후 폴더로 들어간 다음 git status로 상태를 보면 다음과 같이 방금 변경 된 내용들이 출력 될 것이다.
그림 4. git status
5. 이것을 모두 add 한다.
그림 5. git add
6. 그 다음 commit 이후 push 하면 끝!!!
기존 프로젝트와 새로운 Project를 Merge 하는것이 아닌 이유는, 기존 프로젝트의 양이 엄청 적었기 때문에 걍 새로 추가하는게 더 빠를 것이라고 판단했기 때문이다.
Eclipse에서 UI를 이용해서 하는 방법도 물론 있지만, 개인적으로 Bash로 관리하는게 편함 프로젝트 두개를 합치는 방식은 나중에 할일이 생길때 정리하겠음.
하지만 저는 급하게 프로젝트 만들거나 혼자서 놀다가 갑자기 생각안날때를 대비해서 정리하도록 하겠습니다.
정리하려는 내용은 개념 기반입니다. 제가 Git을 관리할때 리눅스 서버에서 관리를 했기때문에 'Git Bash'를 이용하여 예제를 만들 것 입니다.
결론적으로 Git 관리 tool선택은 개념이 똑같기 때문에 무엇을 선택하든 상관이없습니다. (개발환경 내 Git 관리(ex. Spring git 연동관리/ Working tree/ GitHub Desktop... 등) tool을 이용해서 관리해도 되지만, 전 터미널에서 관리하는게 편합니다. 취존부탁ㅎ)
목차 1. git --help 2. git init 2-1. git 저장소(repository) 만들기 2-2. bare 저장소(bare repository) 만들기 3. git clone 3-1. git clone 사용 4. repository 생성 요약정리
1. git --help
Q. git을 사용할때 명령어가 생각이 안난다면?
A. git --help 치면 아래 사진처럼 다 나옵니다.
사진 1. git --help
그래서 1장에 정리할 내용은? start a working area부분
clone과 init 입니다.
2. git init
'git init' 은 .git 이라는 하위 폴더를 생성하여 해당 폴더를 git으로 관리할 수 있게 해주는 명령어 입니다. .git 폴더 내에는 프로젝트 관리를 위해 필요한 내용을 담는 내용물로 구성되어 있습니다.
git으로 프로젝트를 관리하려면 git으로 관리할 프로젝트에 'git init' 명령어를 통해 초기화 하여 관리할 수 있게 됩니다.
사진 2. git init 사용
위 사진에서 보듯이 'git init' 명령어를 사용하게 되면 .git 이라는 폴더가 생성 됩니다. .git 폴더 내에는 git 관리에 필요한 파일들이 있습니다.
git init 명령어를 통해 .git이 생성 되면 해당 프로젝트는 git으로 관리할 수 있게 되는 것이죠!
2.1 git 저장소(repository) 만들기
그런데, 새로 만들 폴더를 저장소(repository)로 만드려면, repo를 가르키는 master가 필요하고, 이것은 최초 1회 commit을 통해 생성할 수 있습니다. 그렇기 때문에 아래 사진처럼 ReadMe.txt 파일을 add하고 commit을 함으로써 저장소가 생성이 된 것입니다!
사진 3. git repository 생성
git의 사용 목적은 다수의 사용자들과 함께 프로젝트를 진행하기 위함입니다.
프로젝트 용량이 커지게 되면, 전체 프로젝트를 왔다갔다 저장소로 옮기기 힘들어 집니다.
그렇기 때문에 원격 저장소는 실제 작업 파일을 가지고 있는 일반 저장소(repository) 보다는 프로젝트의 정보와 변경 사항만 적용이되는 bare repository가 원격 저장소로 적합합니다.
2.2 bare 저장소(bare repository) 만들기
bare repositroy를 만드는 법은 간단합니다. 아래와 같은 명령어로 만들 수 있습니다. $ git clone --bare {프로젝트 이름} {프로젝트이름.git} //(사진 4. 참고) .git 이름표를 붙이는 이유는 bare repo라는것을 알기 위함입니다.
사진 4. bare repository 생성
이렇게 생성된 bare repository는 기존 저장소와 내용물이 다릅니다.
사진 5. bare repo 내용물
내용물 대신 프로젝트의 정보를 담고있는 파일들로 저장이 되어 있습니다.
그렇기 때문에 프로젝트의 실제 작업물을 담고있는 no bare 저장소에 비해 변경 사항만 저장되는 bare저장소는 가볍기 때문에 원격저장소로 두기 적절합니다.
그러면, bare repo에서 변경된 내용은 어떻게 저장되는가? 하면 위 사진의 object 폴더 내에 저장이 됩니다. (물론 사람이 알아볼수있게는 안써있음)
3. git clone
git clone이란 저장소(Repository)로 부터 프로젝트를 복제하는 것을 말합니다.
이 개념을 이해 하려면 아래 사진을 보면 됩니다.
사진 6. git 관리 형태
간단하게 보면 각 컴퓨터들은 저장소로 수정한 내용을 push하고, pull 받으며 버전을 동일하게 유지합니다. 이러한 과정 덕분에 모든 컴퓨터들은 협업이 가능해지게 되는 것 입니다.
3.1 git clone 사용법
Q. 그럼 git clone은 언제 사용할까요?
A. git clone을 사용하는 것은 일반적으로 2가지 입니다.
1) bare repository를 생성할 때 (최초 생성할때 사용) 2) 저장소에 있는 Project를 내 PC에 설치할때 (자주 사용)
실질적으로 clone은 2번 경우에 자주 사용됩니다.
진행중인 프로젝트에 투입하게 되는 경우, 저장소에 있는 프로젝트를 내 컴퓨터에 설치해야 하는 경우가 많기 때문입니다.
- 사용법은 ?
git clone 사용법은 간단합니다. 아래와 같은 형태로 사용합니다.
git clone {프로토콜} {프로젝트 주소}.git
구체적으로 Git에서는 Local, HTTP, SSH, Git 이렇게 4가지 프로토콜을 지원합니다. 따라서 이 프로토콜에 맞게 명령어를 입력하면 clone 할 수 있습니다.
ssh 예제) $git clone ssh://{서버 계정}@{서버 주소}:/{저장소 위치/받을 프로젝트 이름}.git