컴퓨터 튜토리얼 컴퓨터 지식 Git은 diff, 스냅샷 또는 기록을 커밋합니까?

Git은 diff, 스냅샷 또는 기록을 커밋합니까?

Feb 19, 2024 am 11:39 AM
git 제출하다 빠른 이동

Git 提交是差异、快照还是历史记录?

나는 Git 커밋이 어떻게 구현되는지 이해하기 쉽지만 다른 사람들이 커밋을 어떻게 보는지는 이해하기 어렵습니다. 그래서 나는 마스토돈에 관해 다른 사람들에게 몇 가지 질문을 했습니다.

Git 제출에 대해 어떻게 생각하시나요?

사람들에게 Git 커밋에 대해 어떻게 생각하는지 묻는 매우 비과학적인 설문조사를 실시했습니다. 스냅샷인지, 차이점인지, 아니면 이전의 모든 커밋 목록인지? (물론 셋 다라고 생각하는 게 합리적이지만 사람들의 메인이 궁금하네요

결과는 다음과 같습니다.

  • 51% 차이
  • 42% 스냅샷
  • 4% 이전 커밋 내역
  • 3% “기타”

Difference와 Snapshot에서 두 옵션의 비율이 얼마나 가까운지 놀랐습니다. 사람들은 또한
“내가 보기에는 커밋이 다른 것 같지만 실제로는 스냅샷으로 구현된 것 같아요”,
“내가 보기에는 커밋이 스냅샷인 것 같지만 내 생각에는 실제로는 차이의 형태로 나타납니다.” 나중에 제출이 실제로 어떻게 구현되는지에 대해 자세히 설명하겠습니다.

더 나아가기 전에 "차이" 또는 "스냅샷"이란 무엇을 의미하나요?

차이점은 무엇인가요?

내가 말하는 "차이"는 아마도 매우 분명할 것입니다. 차이점은 달릴 때 얻게 되는 것입니다 git show COMMIT_ID . 예를 들어, 다음은 rbspy 프로젝트의 오타 수정입니다:

으아악

GitHub에서 볼 수 있습니다: https://github.com/rbspy/rbspy/commit/24ad81d2439f9e63dd91cc1126ca1bb5d3a4da5b

스냅샷이란 무엇인가요?

"스냅샷"이란 "실행할 때 얻는 모든 파일git checkout COMMIT_ID"을 의미합니다.

Git은 일반적으로 제출된 파일 목록을 "트리"(예: "디렉토리 트리")로 참조하며 위에 제출된 모든 파일을 GitHub에서 볼 수 있습니다.

https://github.com/rbspy/rbspy/tree/24ad81d2439f9e63dd91cc1126ca1bb5d3a4da5b (/tree/ 而不是 /commit/입니다)

Git이 어떻게 구현되는지 설명하는 것이 정말 맞는 표현인가요?

Git 학습에 관해 제가 듣는 가장 일반적인 조언은 아마도 "Git가 내부적으로 사물을 어떻게 표현하는지 배우면 모든 것이 더 명확해질 것입니다"라는 것입니다. 나는 분명히 이 관점을 많이 좋아합니다(이 블로그를 한동안 읽어보신 분이라면 제가 그것을 좋아한다는 것을 아실 것입니다

하지만 Git을 배우는 방법이 생각만큼 잘 안됐어요! 일반적으로 나는 "좋아, Git
커밋은 스냅샷이고 상위 커밋에 대한 포인터가 있고 브랜치는 커밋에 대한 포인터이고..."라고 신나게 설명하기 시작했지만 도움을 주려고 노력 중입니다. 사람들은 그 설명이 별로 유용하지 않다고, 아직도 이해하지 못한다고 말할 것입니다. 그래서 다른 옵션을 찾아봤습니다.

하지만 먼저 내부 구현에 대해 이야기해 보겠습니다.

Git이 내부적으로 커밋을 표현하는 방법 - 스냅샷

내부적으로 Git은 커밋을 스냅샷으로 나타냅니다(각 파일의 현재 버전의 "트리"를 저장함). 저는 Git 저장소에 있습니다. 파일은 어디에 있나요? 이에 대해 에서 썼지만 여기에 내부 형식에 대한 매우 간단한 개요가 있습니다.

제출 표현은 다음과 같습니다.

으아악

그리고 이 트리 개체를 보면 이 커밋의 저장소 루트 아래에 있는 모든 파일/하위 디렉터리 목록이 표시됩니다.

으아악

이는 Git 커밋을 체크아웃하는 것이 항상 빠르다는 것을 의미합니다. Git이 어제 커밋을 체크아웃하는 것은 백만 개의 커밋을 체크아웃하는 것만큼 쉽습니다. 커밋은 전혀 diff로 저장되지 않기 때문에 Git은 현재 상태를 확인하기 위해 10,000개의 diff를 다시 적용할 필요가 없습니다.

스냅샷은 packfile

을 사용하여 압축됩니다.

방금 Git 커밋은 스냅샷이라고 했는데 누군가 "내 생각엔 커밋은 스냅샷인데 구현의 차이인 것 같아"라고 하면
그것도 사실이에요! Git
커밋은 익숙한 diff 형식으로 표시되지 않습니다(이전 커밋과의 diff로 디스크에 저장되지 않음). 그러나 기본적인 직관은 10,000
을 수행하려는 경우입니다. line file 500번 편집하고 500개의 파일을 저장하는 것은 비효율적입니다.

Git에는 파일을 diff로 저장하는 방법이 있습니다. 이를 "팩파일"이라고 하며 Git은 디스크 공간을 절약하기 위해 주기적으로 데이터를 팩파일로 가비지 수집합니다. Git은 저장소를 git clone할 때 데이터를 압축합니다.

여기서는 팩파일 작동 방식을 완전히 설명할 공간이 부족합니다(Aditya Mukerjee의 "Unpacking Git packfiles"는 작동 방식을 설명하는 데 제가 가장 좋아하는 기사입니다). 그러나 델타의 작동 방식과 차이점과의 차이점에 대한 이해를 간략하게 요약할 수 있습니다.

  • 객체는 "원본 파일" 및 "델타"에 대한 참조로 저장됩니다.
  • 델타는 "0~100바이트를 읽은 다음 'hello there' 바이트를 삽입한 다음 120~200바이트를 읽습니다."와 같은 일련의 명령입니다. 원본 파일에서 새로운 텍스트를 모아줍니다. 따라서 "삭제"라는 개념은 없으며 복사 및 추가만 가능합니다.
  • 델타 레벨이 적은 것 같아요. Git이 주어진 객체를 얻기 위해 얼마나 많은 델타 레벨을 거쳐야 하는지 확인하는 방법을 모르지만, 일반적으로 많지 않다는 느낌이 듭니다. 아마 10층도 안 되는 걸까요? 그래도 실제로 알아내는 방법을 알고 싶습니다.
  • 원본 파일은 이전 커밋에서 가져온 것일 필요는 없으며 무엇이든 가능합니다. 어쩌면 나중에 커밋할 수도 있을까요? 잘 모르겠습니다.
  • 변경 사항을 계산하는 데 "올바른" 알고리즘은 없습니다. Git에는 대략적인 경험적 방법이 있을 뿐입니다

차이점을 살펴보면 실제로 뭔가 이상한 일이 일어나고 있습니다

커밋의 차이점을 확인하기 위해 git show SOME_COMMIT실행할 때 실제로 일어나는 일은 약간 반직관적입니다. 내 이해는 다음과 같습니다.

  • Git은 팩 파일을 살펴보고 변경 사항을 적용하여 이 커밋과 상위 커밋의 트리를 다시 빌드합니다.
  • Git은 두 디렉터리 트리(현재 커밋의 디렉터리 트리와 상위 커밋의 디렉터리 트리) 간의 차이점 비교를 수행합니다. 일반적으로 거의 모든 파일이 정확히 동일하기 때문에 이 방법은 빠릅니다. 따라서 git은 거의 항상 아무것도 하지 않고 동일한 파일의 해시만 비교할 수 있습니다.
  • 마지막으로 Git이 차이점을 보여줄 것입니다
  • 그래서 Git은 변경 사항을 스냅샷으로 변환한 다음 차이를 계산합니다. 차이 같은 것에서 시작해서 차이 같은 것으로 끝나기 때문에 조금 이상하게 느껴지지만 변화의 정도와 차이는 사실 완전히 다르기 때문에 이해가 된다.

    그렇기는 하지만 Git 저장소는 스냅샷으로 커밋을 저장하고 packfile은 디스크 공간을 절약하고 복제 속도를 높이기 위한 구현 세부 사항일 뿐이라고 생각합니다. 실제로 packfile이 어떻게 작동하는지 알 필요는 없었지만 Git 스냅샷이 디스크 공간을 너무 많이 차지하지 않고 커밋하는 방법을 이해하는 데 도움이 되었습니다.

    Git의 "잘못된" 이해: 커밋은 차이가 있습니다.

    Git의 "실수"에 대한 일반적인 이해는 다음과 같습니다.

    • 커밋은 이전 커밋을 기반으로 한 diff로 저장됩니다(상위 커밋과 작성자 및 메시지에 대한 포인터 포함).
    • 커밋의 현재 상태를 얻으려면 Git은 이전의 모든 커밋을 처음부터 다시 적용해야 합니다.

    이러한 이해는 물론 잘못된 것입니다(실제로 커밋은 스냅샷 형식으로 저장되고 차이점은 이러한 스냅샷에서 계산됩니다). 그러나 나에게는 매우 유용하고 의미가 있는 것 같습니다! 병합 커밋에 대해 생각하면 조금 이상하지만 병합 커밋의 첫 번째 상위 커밋에 따른 차이일 뿐이라고 말할 수도 있습니다.

    이러한 오해는 가끔 매우 유용하다고 생각하며 일상적인 Git 사용에는 문제가 되지 않는 것 같습니다. 우리가 가장 많이 사용하는 것(차이점)을 가장 기본적인 요소로 만드는 점이 정말 마음에 듭니다. 제게는 매우 직관적입니다.

    저는 다음과 같이 Git에 대한 유용하지만 "잘못된" 다른 이해에 대해서도 생각해 왔습니다.

    • 커밋 정보를 편집할 수 있습니다. (실제로 편집할 수 없습니다. 동일한 커밋을 복사하여 새 정보를 제공하면 이전 커밋이 여전히 존재합니다.)
    • 커밋은 다른 베이스로 이동할 수 있습니다(마찬가지로 복사됩니다)

    나는 Git에 대해 많은 "잘못된" 이해가 있지만 Git 사용자 인터페이스에서 주로 지원되며 대부분의 경우 문제를 일으키지 않는다고 생각합니다. 그러나 변경 사항을 취소하려고 하거나 문제가 발생하면 혼란스러울 수 있습니다.

    제출물을 차이점으로 생각하면 얻을 수 있는 이점

    Git에서는 커밋이 스냅샷이라는 것을 알고 있지만 대부분의 경우 커밋을 차이점으로 생각하는 이유는 다음과 같습니다.

    • 대부분의 경우 내가 만들고 있는 변경 사항에 집중합니다. 만약 코드 한 줄만 변경한다면 분명히 전체 코드 베이스의 현재 상태보다는 해당 코드 줄에 대해 주로 생각하게 될 것입니다.
    • GitHub에서 Git 커밋을 클릭하거나 git show를 사용하면 차이점을 확인할 수 있습니다. 따라서 이는 제가 익숙하게 본 것입니다.
    • 저는 리베이스를 많이 사용합니다. 차이점을 다시 적용하는 것이 전부입니다

    커밋을 스냅샷으로 처리하면 얻을 수 있는 이점

    그러나 나는 때때로 다음과 같은 이유로 커밋을 스냅샷으로 생각합니다.

    • Git은 파일 이동으로 인해 혼동되는 경우가 많습니다. 때로는 파일을 이동하고 편집하는데 Git이 해당 파일이 이동되었음을 인식하지 못하고 대신
      로 표시됩니다. "old.py가 제거되고 new.py가 추가되었습니다". Git은 스냅샷만 저장하기 때문에 "Move old.py -> new.py"라고 하면
      이때 old.py와 new.py의 내용이 유사하므로 추측일 뿐입니다.
    • 이렇게 하면 git checkout COMMIT_ID무엇을 하는지 더 쉽게 이해할 수 있습니다(10,000개의 커밋을 다시 적용한다는 생각이 스트레스를 줍니다)
    • 병합 커밋은 말 그대로 무엇이든 될 수 있기 때문에 나에게는 스냅샷처럼 보입니다(단지 새로운 스냅샷일 뿐입니다!). 병합 충돌을 해결할 때 왜 임의의 변경이 이루어질 수 있는지, 충돌을 해결할 때 주의를 기울여야 하는 이유를 이해하는 데 도움이 되었습니다.

    제출에 대한 기타 이해

    Mastodon의 답변 중 일부도 언급되었습니다:

    • 이메일, GitHub 풀 요청, 동료와의 대화 등 커밋에 대한 "추가" 대역 외 정보
    • '차이'를 '이전 상태 + 이후 상태'로 생각하세요
    • 물론 많은 사람들은 상황에 따라 제출물을 다르게 봅니다

    덜 모호한 커밋에 대해 이야기할 때 사람들이 사용하는 다른 단어:

    • "수정"(스냅샷에 더 가깝습니다)
    • "패치"(diff와 더 유사함)

    그렇습니다!

    Git에 대한 사람들의 이해가 서로 다르기 때문에 이해하기 어렵습니다. 특히 까다로운 점은 "잘못된" 이해가 종종 매우 유용함에도 불구하고 사람들은 "잘못된" 정신 모델을 경계하는 데 너무 열심이어서 일부 Git 해석자가 맞설 것이라는 두려움 때문에 "잘못된" 아이디어를 공유하기를 꺼린다는 것입니다. 나와서 그들이 왜 틀렸는지 설명하십시오. (이 Git
    통역사는 일반적으로 좋은 의미를 갖고 있지만, 상관없이 부정적인 영향을 미칠 수 있습니다.)

    하지만 많이 배웠어요! 커밋에 대해 어떻게 이야기해야 할지 아직 완전히 확신할 수는 없지만 결국에는 알아낼 것입니다.

    Git 커밋에 대해 이야기해주신 Marco Rogers, Marie Flanagan 및 Mastodon의 모든 분들께 감사드립니다.

    위 내용은 Git은 diff, 스냅샷 또는 기록을 커밋합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

    본 웹사이트의 성명
    본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

    핫 AI 도구

    Undresser.AI Undress

    Undresser.AI Undress

    사실적인 누드 사진을 만들기 위한 AI 기반 앱

    AI Clothes Remover

    AI Clothes Remover

    사진에서 옷을 제거하는 온라인 AI 도구입니다.

    Undress AI Tool

    Undress AI Tool

    무료로 이미지를 벗다

    Clothoff.io

    Clothoff.io

    AI 옷 제거제

    AI Hentai Generator

    AI Hentai Generator

    AI Hentai를 무료로 생성하십시오.

    인기 기사

    R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
    1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. 최고의 그래픽 설정
    1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
    1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. 채팅 명령 및 사용 방법
    1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

    뜨거운 도구

    메모장++7.3.1

    메모장++7.3.1

    사용하기 쉬운 무료 코드 편집기

    SublimeText3 중국어 버전

    SublimeText3 중국어 버전

    중국어 버전, 사용하기 매우 쉽습니다.

    스튜디오 13.0.1 보내기

    스튜디오 13.0.1 보내기

    강력한 PHP 통합 개발 환경

    드림위버 CS6

    드림위버 CS6

    시각적 웹 개발 도구

    SublimeText3 Mac 버전

    SublimeText3 Mac 버전

    신 수준의 코드 편집 소프트웨어(SublimeText3)

    H5 프로젝트를 실행하는 방법 H5 프로젝트를 실행하는 방법 Apr 06, 2025 pm 12:21 PM

    H5 프로젝트를 실행하려면 다음 단계가 필요합니다. Web Server, Node.js, 개발 도구 등과 같은 필요한 도구 설치. 개발 환경 구축, 프로젝트 폴더 작성, 프로젝트 초기화 및 코드 작성. 개발 서버를 시작하고 명령 줄을 사용하여 명령을 실행하십시오. 브라우저에서 프로젝트를 미리보고 개발 서버 URL을 입력하십시오. 프로젝트 게시, 코드 최적화, 프로젝트 배포 및 웹 서버 구성을 설정하십시오.

    hadidb : 파이썬의 가볍고 수평 확장 가능한 데이터베이스 hadidb : 파이썬의 가볍고 수평 확장 가능한 데이터베이스 Apr 08, 2025 pm 06:12 PM

    HADIDB : 가볍고 높은 수준의 확장 가능한 Python 데이터베이스 HadIDB (HADIDB)는 파이썬으로 작성된 경량 데이터베이스이며 확장 수준이 높습니다. PIP 설치를 사용하여 HADIDB 설치 : PIPINSTALLHADIDB 사용자 관리 사용자 만들기 사용자 : createUser () 메소드를 작성하여 새 사용자를 만듭니다. Authentication () 메소드는 사용자의 신원을 인증합니다. Fromhadidb.operationimportuseruser_obj = user ( "admin", "admin") user_obj.

    부트 스트랩이 수정 된 후 결과를 보는 방법 부트 스트랩이 수정 된 후 결과를 보는 방법 Apr 07, 2025 am 10:03 AM

    수정 된 부트 스트랩 결과를보기위한 단계 : Bootstrap 파일이 올바르게 참조되도록 브라우저에서 직접 HTML 파일을 엽니 다. 브라우저 캐시를 지우십시오 (Ctrl Shift R). CDN을 사용하는 경우 개발자 도구에서 CSS를 직접 수정하여 효과를 실시간으로 볼 수 있습니다. 부트 스트랩 소스 코드를 수정 한 경우 로컬 파일을 다운로드하여 교체하거나 Webpack과 같은 빌드 도구를 사용하여 빌드 명령을 다시 실행하십시오.

    Vue Pagination 사용 방법 Vue Pagination 사용 방법 Apr 08, 2025 am 06:45 AM

    Pagination은 큰 데이터 세트를 작은 페이지로 나누어 성능 및 사용자 경험을 향상시키는 기술입니다. VUE에서 다음 내장 방법을 페이징에 사용할 수 있습니다. 총 페이지 수를 계산하십시오 : TotalPages () Traversal 페이지 번호 : V-For Directive 현재 페이지를 설정하려면 : CurrentPage 현재 페이지 데이터 가져 오기 : currentPagedAta ()

    Prometheus MySQL Expler를 사용하여 MySQL 및 MariaDB 액 적을 모니터링하십시오 Prometheus MySQL Expler를 사용하여 MySQL 및 MariaDB 액 적을 모니터링하십시오 Apr 08, 2025 pm 02:42 PM

    MySQL 및 MariaDB 데이터베이스의 효과적인 모니터링은 최적의 성능을 유지하고 잠재적 인 병목 현상을 식별하며 전반적인 시스템 신뢰성을 보장하는 데 중요합니다. Prometheus MySQL Expler는 능동적 인 관리 및 문제 해결에 중요한 데이터베이스 메트릭에 대한 자세한 통찰력을 제공하는 강력한 도구입니다.

    부트 스트랩의 자바 스크립트 동작을 보는 방법 부트 스트랩의 자바 스크립트 동작을 보는 방법 Apr 07, 2025 am 10:33 AM

    Bootstrap의 JavaScript 섹션은 정적 페이지에 활력을주는 대화식 구성 요소를 제공합니다. 오픈 소스 코드를 살펴보면 작동 방식을 이해할 수 있습니다. 이벤트 바인딩은 DOM 작업 및 스타일 변경을 유발합니다. 기본 사용에는 JavaScript 파일의 도입 및 API 사용이 포함되며 고급 사용법은 사용자 정의 이벤트 및 확장 기능이 포함됩니다. 자주 묻는 질문에는 버전 충돌과 CSS 스타일 충돌이 포함되며, 코드를 두 번 확인하여 해결할 수 있습니다. 성능 최적화 팁에는 주문형로드 및 코드 압축이 포함됩니다. 부트 스트랩 자바 스크립트를 마스터하는 핵심은 설계 개념을 이해하고 실제 응용 프로그램을 결합하며 개발자 도구를 사용하여 디버깅 및 탐색하는 것입니다.

    부트 스트랩 프레임 워크를 구축하는 방법 부트 스트랩 프레임 워크를 구축하는 방법 Apr 07, 2025 pm 02:54 PM

    부트 스트랩 프레임 워크 빌딩 안내서 : 부트 스트랩을 다운로드하여 프로젝트에 연결하십시오. 필요한 요소를 추가하기 위해 HTML 파일을 만듭니다. 부트 스트랩 메쉬 시스템을 사용하여 반응 형 레이아웃을 만듭니다. 버튼 및 양식과 같은 부트 스트랩 구성 요소를 추가하십시오. 부트 스트랩을 사용자 정의할지 여부를 결정하고 필요한 경우 스타일 시트를 컴파일하십시오. 버전 제어 시스템을 사용하여 코드를 추적하십시오.

    git은 github와 동일합니까? git은 github와 동일합니까? Apr 08, 2025 am 12:13 AM

    Git과 Github도 같은 것이 아닙니다. GIT는 버전 제어 시스템이며 GitHub는 GIT 기반 코드 호스팅 플랫폼입니다. GIT는 코드 버전을 관리하는 데 사용되며 Github은 온라인 협업 환경을 제공합니다.

    See all articles