[Git] 명령어 빠르게찾기
Basic
git --version
git --version
git init
git init
git clone
git clone
git clone http://
git status
git status
git add
git add
-i
대화형 모드가 시작되며 파일의 일부분만 스테이징이 가능-p
대화형 모드없이 바로 패치 모드 사용
git add .
git add src
git commit
git commit -m "<message>"
git commit -m "Which one best naver or kakao?"
git commit -C HEAD -a --amend
지정한 커밋의 로그 메시지를 다시 사용하여 기존 커밋을 수정
-c 사용시 기존 메시지를 수정할 수 있는 편집기 실행
git diff
스테이지영역과 현재 작업트리의 차이점 확인
--cached
스테이징영역과 저장소의 차이HEAD
저장소, 스테이징영역, 작업트리의 차이점을 모두 확인--stat
변경사항에 대한 통계
git diff
git mv
git mv
git mv a.txt b.txt
git checkout
git checkout
스테이징이나 커밋하지 않은 파일의 변경내용을 취소하고 원래 상태로 되돌림
git checkout b.txt
git push
git push
git push origin master
git pull
git pull
git pull origin master
git fetch
원격 저장소의 변경사항을 가져와 원격 브랜치를 갱신
git fetch
git stash
git stash
git stash pop
Log
git log
-<number>
출력 로그 갯수 설정--pretty=oneline
--pretty=format:%h %s
-p
변경된 내용 같이 출력--since="5 hours"
--before="5 hours"
--graph
브랜치 트리 출력
git log
git log -10
git log --oneline --all -- graph
git blame
git blame
git blame -L 10,15
git blame -M
Config
git config
--global 옵션은 전역 설정에 대한 옵션이며 현재 프로젝트에만 적용할 때는 설정하지 않음
git config (--global) --list
git config (--global) user.name
git config (--global) user.email
git config (--global) color.ui
터미널에 표시되는 메시지에 칼라를 설정
git config --global color.ui "auth"
git remote
git remote add <name> <url>
새로운 원격 저장소 추가
git remote add origin http://~
git remote
추가한 원격저장소 목록 확인
git remote
git remote show <name>
해당 원격 저장소의 정보 확인
git remote show origin
git remote rm <name>
원격 저장소 제거
git remote rm origin
Branch
git branch
-r
원격 저장소의 브랜치 확인-d
삭제-a
git branch
git branch <branch_name>
git branch -r
git branch -d <branch_name>
git branch -a
git branch
git branch -m
-m
존재하는 브랜치를 새로운 브랜치로 변경 ( Force! )
git branch origin_branch target_branch
git branch -m origin_branch force_target_branch
git checkout
git checkout /
git checkout -b
git checkout -t /
git checkout <branch_name>
git checkout -b <branch_name>
git checkout -t <remote_url>/<branch_name>
git merge
git merge
--squash
브랜치명의 모든 커밋을 하나의 커밋으로 만듬
git checkout master
git merge target
git tag
git tag
Commit
git revert
git revert
기존 커밋에서 변경한 내용을 취소하고 새로운 커밋 생성 (Rename 아님, Log 유지)
git revert <commit_key>
-n
바로 커밋하지 않고 --continue 옵션을 호출하여 진행--continue
-n 옵션을 진행--abort
-n 옵션을 취소
git revert -n <commit_key>
git status
===
"You are currently reverting commit <commit_key> "
~
===
git revert --continue
git revert --abort
git reset
git reset
--soft
이전 커밋을 스테이징영역으로 전환--hard
이전 커밋을 저장소와 작업트리에서 제거
# 최근 1개 커밋 취소
git reset HEAD^
git rebase
git rebase -i
-i
대화형모드로 커밋 순서를 변경하거나 합치는 작업 가능
git cherry-pick
git cherry-pick
특정 커밋만을 선택해 현재 브랜치에 커밋으로 만듬
-n
작업트리에 합치지만 커밋은 하지 않아 여러개의 커밋을 합쳐서 커밋 가능
git cherry-pick <commit_name>
SubModule
git submodule
git submodule
연관된 하위 모듈 조회
git submodule add
새로운 하위 모듈을 해당 경로에 추가
추가하고 초기화하지 않으며 커밋 해쉬 앞에 마이너스(-) 표기
git submodule init
서브모듈 초기화
git submodule update
서브 모듈 변경사항 적용
ETC
git archive
git archive --format=tar --prefix=/<branch_name || tag_name> | gzip > .tar.gz
git archive --format=zip --prefix=/<branch_name || tag_name> | gzip > .zip
해당 브랜치나 태그를 압축파일로 만듬
--prefix
압출파일이 해당폴더 안에 생성되도록 처리
git mergetool
설정에 merge.tool 값에 있는 머지툴을 찾아 실행
git gc
저장소의 로그 최적화
로그가 변경되지 않고 저장 방식만 최적화
--aggressive
더 자세하게 최적화
git rev-parse --show-toplevel
git 저장소내에 입력시 Root Dir를 반환
GitFlow
참조