Git 사용방법 정리

Gitea 서버를 구축해서 사용하고 있습니다. 보통 사용하는 CLI git사용방법을 정리합니다. 필요에따라 업데이트 되는 글 내용으로 완성된 글이 아닙니다.

Git이란?

Git은 분산 버전 관리 시스템으로, 소스 코드의 변경 사항을 추적하고 여러 개발자들 간에 협업을 용이하게 만드는 도구입니다. Git을 사용하면 파일의 추가, 수정, 삭제 등의 모든 변경 이력을 저장하고 관리할 수 있어 이전 상태로 복원하거나 협업 중 발생하는 충돌을 해결하는 데 유용합니다.


git commit 조회

# 한줄조회
$ git show --oneline -s

6cb8796 (HEAD -> main, origin/main, origin/HEAD) fixed refresh token expire.

# 최근 커밋 조회
$ git log --oneline -5

6cb8796 (HEAD -> main, origin/main, origin/HEAD) fixed refresh token expire.
210bf24 jwt토큰 만료 로그아웃동작 추가
1fb919a 게시물 상세보기, 삭제 추가
add285d 게시물 등록 기능 추가
b94f6ce nav구조 변경

commit을 추가하면 local과 romote가 달라지고, push를 하면 동기화된다.

git commit 되돌리기(복원)

로컬(origin)에서 작업을하고 원격지 main브랜치로 push를 하였습니다.
해당 기능을 폐기하고 적용을 초기화하고자 사용한 방법입니다.

로컬 commit 되돌리기

gitea 웹콘솔에서 커밋 버전을 확인하고 되돌릴 hash값을 조회합니다.

로컬의 commit 상태를 이전 상태로 되돌립니다.
새로 작성된 코드 파일은 남아있으니 파일은 직접 제거 해야합니다.

git reset --hard <commit-hash>

원격지도 되돌려줍니다.

git push origin <브랜치 > --force

branch, dev 브랜치를 이용한 관리

다양한 브랜치 전략과 방법론이 있지만 단순하게 dev와 main만 이용하고자 합니다.
혼자 작업중이자만 이전 작업에서 main을 되돌리는게 상당히 귀찮다는 것을 알게되었으므로…

branch를 생성하고 확인합니다.

생성된 branch 전환

git checkout dev

원격 저장소에 branch적용

git push origin dev

push를 하면 아래와 같이 에러가 발생할수 있습니다. 동기화가 되도록 설정합니다.


branch 병합

dev에서 작성한 코드를 main브랜치에 적용해야 됩니다.

현재 브랜치 상태 조회

git branch

병합해야되는 main브랜치로 전환

git checkout main

병합 및 push

git merge dev
git add .
git commit -m "Test, branch merge."
git push

웹 콘솔에서 잘 적용되고 CI 빌드도 정상적으로 동작되는 것을 확인 하였습니다.

CI 빌드작업은 브랜치 머지와 별개로 설정해야하는 부분 입니다. 별도 설정이 없으면 적용되지 않음.

Git 원격지 주소 설정값 변경

git remote remove origin
git remote add origin https://github.com/${ACCOUNT}/${REPOSITORY}

아래 설명하는 마이그레이션과 좀 헷갈릴 수 있음..

새로운 원격지 Git으로 Migration하기

새로운 Gitea에서 초기화하지않고 Repository를 생성

git remote를 확인

git remote -v

git remote 교체 새로운 Gitea의 Repository URL로 변경

git remote set-url origin https://gitea.example.com/admin/example.git

git push

git push --mirror

.env같은 보안에 중요한 파일을 잘못 올렸을때

git-filter-repo설치

pip install git-filter-repo
# 삭제 동작
git filter-repo --path .env.prd --invert-paths

# 안되면 강제 실행
git filter-repo --path .env.prd --invert-paths --force

# 출력결과 예시
NOTICE: Removing 'origin' remote; see 'Why is my origin removed?'
        in the manual if you want to push back there.
        (was https://gitea.icurfer.com/icurfer/butler_ddochi.git)
Parsed 84 commits
New history written in 2.17 seconds; now repacking/cleaning...
Repacking your repo and cleaning out old unneeded objects
Enumerating objects: 1125, done.
Counting objects: 100% (1125/1125), done.
Delta compression using up to 8 threads
Compressing objects: 100% (570/570), done.
Writing objects: 100% (1125/1125), done.
Completely finished after 5.01 seconds.

# 원격지 정보가 삭제되므로 다시 등록필요.
git remote add origin https://gitea.icurfer.com/icurfer/butler_ddochi.git

# 동기화
git push --set-upstream origin main

# 이전 기록들과 충돌나면 강제 실행
git push --set-upstream origin main --force

Tag 달기

git add .
git commit -m "change RS256 algorithm"
git tag -a v0.0.12 -m "release: change RS256 algorithm"
# code push
git push origin main
# tag 조회
git tag
# 원격지 tag 조회
git ls-remote --tags origin
git tag -l
# tag push
git push origin v0.0.12

Tag 삭제

# 원격지
git push origin --delete v0.0.2_r1
# 로컬
git tag -d v0.0.2_r1

GitHub

여기는 github사용 중 정리했던 내용을 작성합니다.

ssh 설정

ssh key 생성

root@c4m8d50:~# ssh-keygen -t ed25519 -C "icurfer@gmail.com"

 config 파일 생성 및 설정

root@c4m8d50:~# vi .ssh/config
 
Host github.com
HostName github.com
IdentityFile ~/.ssh/id_ed25519_pyauto
User pyauto

Host private.gitlab.com
HostName private.gitlab.com
IdentityFile ~/.ssh/id_ed25519_pyauto
User pyauto

git 설정

git config --global user.email "icurfer@gmail.com"
git config --global user.name "icurfer"

github설정
개별 레포지토리 접속 후
settings \ Deploy Keys 접속
Add deploy key에 Public key를 넣어주면 됨.


Git pull 충돌

커밋 확인

git log --oneline --graph --decorate --all --boundary

최근 커밋 삭제

git reset --soft HEAD~1

다시 git add / commit / push 실행.