這個答案解釋了通常 git commit SHA 是根據各種引數生成的。但是,我想知道:如何指定自定義/特定/特定 git commit sha(在 Bash 中)?
例如,假設有人想要使用以下 sha 創建并推送到 Git 的提交:
1e23456ffd118db9dc04caf40a442040e5ec99f9
(為簡單起見,假設人們可以假設它是一個獨特的 sha)。
XY 問題是兩個不同 Git 服務器之間的手動鏡像腳本。簡單地擁有相同的提交 SHA 比在 Git 服務器之間保持提交的映射更方便。這是因為如果我可以跳過source服務器的某些提交,手動鏡像會更有效率(節省計算時間和服務器帶寬)。然而,這意味著父提交target服務器中的更改,相對于服務器中的相同提交source。反過來,這將意味著 SHA 更改,這將需要我跟蹤source和target服務器中sha 的映射。簡而言之,簡單地覆寫提交的 sha 會更方便target 服務器,而不是確保兩個服務器具有完全相同的提交(對于實際鏡像的少數提交)。
uj5u.com熱心網友回復:
提交 SHA 不僅僅是基于這些引數“正常”生成的,根據定義,它是這些引數的散列。“SHA”是用于生成它的散列演算法的名稱。
與其嘗試更改提交哈希,不如尋找一種有效的方法來跟蹤它們。一種方法類似于git svn等插件的作業方式:
- 將提交復制到鏡像時,將原始提交哈希記錄為新提交的提交訊息的一部分。
- 可能,由于您“跳過”原始存盤庫中的提交,因此每個新提交都應該有多個源哈希,因為它會像這些提交的“擠壓”一樣起作用。
- 有一個腳本來處理
git log和提取這些記錄的提交哈希的結果。然后,在確定要從源復制哪些新提交時,可以使用它來代替真正的提交哈希。
但是,請確保這一切都是值得的:如果最終的更改都包含在內,則 git 現有的重復資料洗掉和壓縮可能意味著“跳過”提交的開銷相當低。
uj5u.com熱心網友回復:
由于您已經在問題中概述了您有處理分歧的方法,因此我假設這個問題實際上并且僅此:
我想知道:如何指定自定義/特定/特定 git commit sha(在 Bash 中)?
而不是“或者你有任何其他想法可以代替我使用”。
有了這個問題,答案其實很簡單:
你不能。
Git 不只是計算提交 ID,因為這只是所選實作的副產品。它的完成方式是git 設計的核心概念。
提交 id 是根據提交的內容計算的,正如您所觀察到的,這包括到父級的鏈接。更改父級但保持其他所有內容相同,提交 ID 仍會更改。
這是版本控制系統的分布式部分如何作業的核心,不能更改。
您根本無法更改提交的 id 并使其內容保持不變。這是設計使然
有一些嘗試通過仔細構建最終具有相同 id 的不同提交來進行提交沖突。
這是一次成功的嘗試(碰撞):https : //www.theregister.com/2017/02/23/google_first_sha1_collision/
第一次計算 SHA-1 哈希沖突。只需要五個聰明的大腦……和 6,610 年的處理器時間
我不相信有人已經設法進行任意提交,然后用它來定位特定的提交 ID。沖突是通過根據非常具體的標準同時操縱兩個提交來精心構建的,以便它們到達相同的 id,但該 id 不是由研究選擇的。
TL;DR:這是不可能的
不過,產生的沖突的凈影響是,Git 將在某個時候遠離 SHA-1,轉而使用一個比我們今天擁有的系統產生更長、“更安全” (tm) 哈希的系統。由于 Git 還希望與現有存盤庫向后兼容,因此這項作業尚未完全完成。
uj5u.com熱心網友回復:
從 CodeCaster 的評論來看,我似乎可以在 `git commit -m "some message" 中使用提交訊息中的自由選擇位來確保提交的 sha 以特定值結束。
但是,根據 Lasse V. Karlsen 的評論,我認為這種方法需要非線性計算資源。我沒有詳細說明這一點,但是我想象/假設隨著提交歷史的增長,提交訊息的 (limited (5mb) ) 可自由選擇位的相對影響變得更小。我想這可以解釋為什么在提交訊息中利用這些可自由選擇的位會變得昂貴。
所以在實踐中,答案似乎是:“你可以(也許,如果你花費大量計算資源),但你不應該。”。
uj5u.com熱心網友回復:
如何指定自定義/特定/特定 git commit sha(在 Bash 中)?
一個不能。正如您所說,提交哈希是通過將各種值散列在一起而構建的值,重點是唯一標識特定提交。您可以在不同的時間在不同的機器上提交相同的檔案集,最終會得到不同的提交哈希。
確保您在兩臺不同機器上具有相同提交的方法是git pull(或類似)從一臺機器到另一臺機器的提交。您不必移動所有提交——例如,您可以壓縮它們或僅挑選某些提交。
轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/380604.html
