변경 내용 되돌리기
GitLab에서 개별 커밋 또는 전체 병합 요청을 되돌릴 수 있습니다. Git에서 커밋을 되돌리면 원본 커밋에서 수행된 모든 작업을 뒤집는 새로운 커밋이 생성됩니다.
- 원본 커밋에 추가된 줄은 제거됩니다.
- 원본 커밋에서 제거된 줄은 다시 추가됩니다.
- 원본 커밋에서 수정된 줄은 이전 상태로 복원됩니다.
여러분의 되돌린 커밋은 여전히 프로젝트의 접근 제어 및 프로세스의 영향을 받습니다.
병합 요청 되돌리기
병합 요청이 병합된 후에는 병합 요청의 모든 변경 사항을 되돌릴 수 있습니다.
전제 조건:
- 병합 요청을 편집하고 저장소에 코드를 추가할 수 있는 프로젝트 내 권한이 있어야 합니다.
-
프로젝트는 병합 메서드 Merge Commit을 사용해야 하며, 이는 프로젝트의 설정 > 병합 요청에서 설정됩니다.
GitLab 16.9 이상에서는 당신이 제출한 커밋이 스쿼시되거나 병합 요청에 단일 커밋이 있는 경우에만 GitLab UI에서 빠른 전진된 커밋을 되돌릴 수 있습니다.
아래 단계를 따르세요:
- 왼쪽 사이드바에서 검색 또는 이동을 선택하고 프로젝트를 찾습니다.
- Code > 병합 요청를 선택하고 병합 요청을 식별합니다.
- 병합 요청 보고 영역으로 스크롤하고 병합 요청이 병합된 시간을 보여주는 보고서를 찾습니다.
- Revert를 선택합니다.
- Revert in branch에서 변경 사항을 되돌릴 브랜치를 선택합니다.
- 원하는 경우 새 병합 요청 시작을 선택하여 새로운 병합 요청을 시작할 수 있습니다.
- Revert를 선택합니다.
병합 요청을 되돌리고 난 후 Revert 옵션이 더 이상 표시되지 않습니다.
커밋 되돌리기
저장소의 모든 커밋을 현재 브랜치 또는 새 병합 요청으로 되돌릴 수 있습니다.
전제 조건:
- 병합 요청을 편집하고 저장소에 코드를 추가할 수 있는 프로젝트 내 권한이 있어야 합니다.
- 해당 커밋이 이미 되돌려지지 않았을 경우, 이 경우 Revert 옵션이 표시되지 않습니다.
아래 단계를 따르세요:
- 왼쪽 사이드바에서 검색 또는 이동을 선택하고 프로젝트를 찾습니다.
- 커밋이 포함된 병합 요청을 알고 있다면:
- Code > 병합 요청를 선택한 다음 병합 요청을 선택합니다.
- 커밋을 선택한 다음 되돌리려는 커밋의 제목을 선택합니다. 이렇게 하면 병합 요청의 맥락에서 커밋이 표시됩니다.
- 보조 메뉴 아래에 커밋
00001111
보기라는 메시지가 표시됩니다. 여기서00001111
은 커밋의 해시입니다. 커밋 해시를 선택하여 커밋 페이지를 표시합니다.
- 커밋이 어디에서 유래되었는지 모르는 경우:
- Code > 커밋을 선택합니다.
- 커밋의 제목을 선택하여 커밋에 대한 전체 정보를 표시합니다.
- 오른쪽 상단에서 옵션을 선택한 다음 Revert를 선택합니다.
- Revert in branch에서 변경 사항을 되돌릴 브랜치를 선택합니다.
- 원하는 경우 새 병합 요청 시작을 선택하여 새 병합 요청을 시작할 수 있습니다.
- Revert를 선택합니다.
다른 부모 커밋으로 병합 커밋 되돌리기
병합 커밋을 되돌릴 때, 일반적으로 병합한 브랜치(일반적으로 main
)가 항상 첫 번째 부모입니다.
다른 부모로 병합 커밋을 되돌리려면 명령줄에서 커밋을 되돌려야 합니다:
- 되돌릴 부모 커밋의 SHA를 식별합니다.
- 되돌릴 커밋의 부모 번호를 식별합니다. (첫 번째 부모의 경우 기본값은 1입니다.)
-
이 명령어를 수정하여 사용하세요.
2
를 부모 번호로,7a39eb0
을 커밋 SHA로 대체합니다.git revert -m 2 7a39eb0