사람들은 보통 릴리즈할 때 Tag 를 사용한다.
Tag 조회하기
$
git tagv0.1
v1.3
검색 패턴을 사용하여 태그를 검색할 수 있다.
$
git tag -l 'v1.8.5*'
v1.8.5
v1.8.5-rc0
v1.8.5-rc1
v1.8.5-rc2
v1.8.5-rc3
v1.8.5.1
v1.8.5.2
v1.8.5.3
v1.8.5.4
v1.8.5.5
Tag 종류
Git 의 태그는 Lightweight 태그와 Annotated 태그로 두 종류가 있다.
Lightweight 태그는 브랜치와 비슷한데
브랜치처럼 가리키는 지점을 최신 커밋으로 이동시키지 않는다.
단순히 특정 커밋에 대한 포인터일 뿐이다.
Annotated 태그의 경우는 작성자/이메일/태그 날짜/태그 메시지도 저장한다.
Lightweight Tags
Lightweight 태그는 파일에 커밋 체크섬을 저장하는 것뿐이다.
다른 정보는 저장하지 않는다.
( -a, -s, -m 옵션을 사용하지 않는다. )
마지막 커밋한 내용에 저장되며 아래와 같이 하면 된다.
$
git tag v1.4-lw결과를 보면 아래와 같이 나오게 된다.
이전 히스토리를 검색해서 해당하는 커밋에 대해 태그할 수 도 있다.
$
git log --pretty=
oneline15027957951b64cf874c3557a0f3547bd83b3ff6 Merge branch 'experiment'
a6b4c97498bd301d84096da251c98a07c7723e65 beginning write support
0d52aaab4479697da7686c15f77a3d64d9165190 one more thing
6d52a271eda8725415634dd79daabbc4d9b6008e Merge branch 'experiment'
0b7434d86859cc7b8c3d5e1dddfed66ff742fcbc added a commit function
4682c3261057305bdd616e23b64b0857d832627b added a todo file
166ae0c4d3f420721acbb115cc33848dfcc2121a started write support
9fceb02d0ae598e95dc970b74767f19372d61af8 updated rakefile
964f16d36dfccde844893cac5b347e7b3d44abbc commit the todo
8a5cbc430f1a9c3d00faaeffd07798508422908a updated readme
$
git tag v1.2 9fceb0$
git tag -a v1.4 -m 'my version 1.4'
- a 가 Annotated 태그를 의미한다.
-m 옵션 은 메시지를 함께 저장할 때 사용한다.
-m 을 붙이지 않으면 자동으로 Git 편집기를 실행시킨다.
- 태그 메시지는 커밋 메시지와 달리 저장된다.
git show 명령으로 태그 정보와 커밋 정보를 모두 확인할 수 있다.
$
git show v1.4tag v1.4
Tagger: Ben Straub <ben@straub.cc>
Date: Sat May 3 20:19:12 2014 -0700
my version 1.4
commit ca82a6dff817ec66f44342007202690a93763949
Author: Scott Chacon <schacon@gee-mail.com>
Date: Mon Mar 17 21:52:11 2008 -0700
changed the version number
태그 push 하기 ( 온라인에 공유하기 )
git push 명령은 자동으로 리모트 서버에 태그를 전송하지 않는다.
고로 태그를 만들었으면 서버에 별도로 Push 해야 한다.
git push origin [태그 이름] 을 실행한다.
$
git push origin v1.5만약 한 번에 태그를 여러개 Push 하고 싶다면 --tags 옵션을 추가하여 git push 명령을 실행한다.
$
git push origin --tags이제 누군가 저장소에서 Clone 하거나 Pull 하면 모든 태그 정보도 함께 전송된다.
태그 Checkout 하기
태그는 브랜치와 달리 가리키는 커밋을 바꿀 수 없는 이름이라서 Checkout 해서 사용할 수 없다.
태그가 가리키는 특정 커밋 브랜치를 만들어 작업하려면
아래와 같이 새로 브랜치를 새로 생성한다.
$
git checkout -b version2 v2.0.0위 명령의 의미는 branch 를 뜨는데 이름은 bersion2 이고
참조할 태그는 v2.0.0 이라는 것이다. ( 즉 v2.0.0 에서 브랜치가 뻗어나간다. )
'SCM > Git' 카테고리의 다른 글
19. Git 허브 - Fork 하기 (0) | 2020.01.28 |
---|---|
18. Git 허브 (0) | 2020.01.28 |
16. Git 브랜치 합치기 - git rebase (0) | 2020.01.28 |
15. Git 브랜치 합치기 - git merge (0) | 2020.01.23 |
14. Git 브랜치 만들고 이동하기 - git branch, git checkout (0) | 2020.01.23 |