- GitHub 계정 만들기
- Sourcetree 를 설치
- 작업은 반드시 터미널에서 진행합니다. Sourcetree와 같은 GUI도구는 중간에 과정을 생략합니다.
- 그러나 뭔가를 할 때마다 Sourcetree를 계속 보시면 Git에 대해 알 수 있고, 무슨 일이 벌어지고 있는지도 알 수 있습니다.
- Windows
- WSL2를 공부하고 설치.
- Windows terminal 설치.
- Git 명령어 수행은 CLI 환경인 terminal에서 진행.
- WSL란?
- WSL 설치 및 WSL 2로 업데이트
- Mac
- iterm2 설치 후 iterm 터미널에서 진행
brew install --cask iterm2
mkdir <생성하고 싶은 디렉토리 이름>
cd <생성한 디렉토리 이름>
git init
# 예)
~ $ mkdir test
~ $ cd test
~/test $ git init
git clone <원격 저장소 주소>
# 예) git clone https://github.com/wholemann/daily-coding-dojo.git
Sourcetree를 실행해 방금 만들거나 가져온 폴더를 추가합니다.
뭔가를 할 때마다 Sourcetree를 계속 보시면 Git에 대해 알 수 있고, 무슨 일이 벌어지고 있는지도 알 수 있습니다.
git remote
git remote -v
주의) clone으로 원격 저장소를 가져오면 origin 원격 저장소가 이미 추가된 상태입니다.
아래는 git init 후 수동으로 원격 저장소를 추가할 때 사용하는 방법입니다.
git remote add origin <내 계정의 repository 주소>
git fetch origin
git remote add upstream <PR을 보낼 원격 repository 주소>
git fetch upstream
- upstream - PR을 보내고 싶은 repository(회사에선 우리팀 repository)
- origin - upstream에서 내 계정으로 fork한 repository
먼저 PR(Pull Request)를 보내고 싶은 repository를 fork 합니다. fork를 하면 본인 계정의 GitHub에 동일한 repository가 복사됩니다.
내 계정에 동일한 repository가 복제된 걸 확인할 수 있습니다. 아래 이미지처럼 초록색 버튼을 클릭하면 나오는 창에서 주소를 복사합니다.
복사한 주소를 이용하면 내 로컬 머신에서 clone 할 수 있습니다.
주의) clone으로 원격 저장소를 가져오면 origin 원격 저장소가 이미 추가된 상태입니다.
git clone <내 계정에 fork된 repository 주소>
git remote add upstream <PR을 보낼 원격 repository 주소>
# 예)
git clone https://github.com/wholemann/git-training.git
git remote add upstream https://github.com/CodeSoom/git-training.git
PR을 보내는 과정에서 원격 저장소는 upstream. origin 2개가 필요합니다. 로컬 머신(내 컴퓨터) 관점에서 보면 내 계정의 repository도 원격이고, upstream의 repository도 원격입니다.
- upstream - PR을 보내고 싶은 repository(회사에선 우리팀 repository)
- origin - upstream에서 내 계정으로 fork한 repository
git remote -v
를 통해 upstream과 origin이 아래와 같은지 확인합니다.
~/codesoom/git-training $ git remote -v
origin git@github.com:wholemann/git-training.git (fetch)
origin git@github.com:wholemann/git-training.git (push)
upstream git@github.com:CodeSoom/git-training.git (fetch)
upstream git@github.com:CodeSoom/git-training.git (push)
git switch -c <브랜치 이름> upstream/main
upstream/main는 붙여서 쓰고, 가운데 슬래시(/)가 들어갑니다.
브랜치 이름은 작업한 내용을 표현해야 합니다. ex) login-oauth-apply
git fetch upstream
git rebase upstream/main
원하는 작업을 이 시점에 합니다.
뭔가 바뀐 점을 추가합니다.
새 파일을 추가하는 게 아니라, 파일 추가/변경/삭제란 “바뀐 점”을 추가합니다.
git add .
방금 추가한 바뀐 점을 커밋합니다.
가능하면 메시지를 우리가 나중에 찾아볼 수 있는 형태로 씁니다.
git commit
반드시 숙지하고 지키려고 노력합시다.
Commit Message Style Guide For Git
git commit 에디터는 vi 에디터를 기본적으로 씁니다.
주의) git commit -m "message" 는 쓰지 마세요. -m은 anti pattern입니다.
git push origin <브랜치 이름>
origin과 <브랜치 이름> 사이엔 공백이 들어갑니다.
GitHub에서 New Pull Request를 합니다.
Pull Request를 했지만 수정하고 싶을 때가 있습니다. 코드 리뷰 내용을 보고 반영하기 위해 고칠 때가 많은데, 해당 브랜치에 가서 Commit을 추가하고 Push만 하면 됩니다.
git switch <브랜치 이름>
변경 작업을 이 시점에 합니다.
뭔가 바뀐 점을 추가합니다.
새 파일을 추가하는 게 아니라, 파일 추가/변경/삭제란 “바뀐 점”을 추가합니다.
git add .
방금 추가한 바뀐 점을 커밋합니다.
가능하면 메시지를 우리가 나중에 찾아볼 수 있는 형태로 씁니다.
git commit
git push origin <브랜치 이름>
뭔가 새로운 작업을 하지 않아도 Pull Request가 바뀐 것을 확인할 수 있습니다.
git switch main
git fetch upstream
git rebase upstream/main
git push origin main
내 컴퓨터에 있는 브랜치 중 Merge된 것 보기
이 목록에 main도 포함된다는 점에 주의!
git branch --merge
내 컴퓨터와 원격 저장소에 있는 브랜치 중 Merge된 것 보기
이 목록에 main도 포함된다는 점에 주의!
git branch -a --merge
git branch -d <브랜치 이름>
git branch -D <브랜치 이름>
git push origin :<브랜치 이름>
https://github.com/CodeSoom/git-training
Pull Request를 이용한 협업 시작하기를 참고하여,
각자 이니셜로 만든 문서 파일(예) csh.md
)을 추가하여 위의 repository에
Pull Request를 날려봅니다.