欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解決使用commit提交大文件無(wú)法推送到遠(yuǎn)程庫(kù)問(wèn)題及git rebase使用詳解

 更新時(shí)間:2020年07月30日 11:17:26   作者:CodeMissing  
這篇文章主要介紹了解決使用commit提交大文件無(wú)法推送到遠(yuǎn)程庫(kù)問(wèn)題及git rebase使用詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

解決這個(gè)問(wèn)題并沒(méi)有特別的(刪除提交歷史中某個(gè)文件,然后重新push),但是由于開(kāi)始的使用失誤,中間有使用git rebasegit reset命令處理,所以特此記錄下

大文件無(wú)法push到遠(yuǎn)程倉(cāng)庫(kù)

問(wèn)題

首先,故事(事故)的起因是這樣的。

某次git push(類(lèi)似測(cè)試使用,沒(méi)有分支)到遠(yuǎn)程倉(cāng)庫(kù)時(shí)發(fā)生如下無(wú)法提交大文件的報(bào)錯(cuò)(大文件是一個(gè)pdf文件)

$ git push
Enumerating objects: 204, done.
Counting objects: 100% (204/204), done.
Delta compression using up to 4 threads
Compressing objects: 100% (183/183), done.
Writing objects: 100% (187/187), 419.00 MiB | 2.21 MiB/s, done.
Total 187 (delta 21), reused 0 (delta 0)
remote: Resolving deltas: 100% (21/21), completed with 12 local objects.
remote: Powered by GITEE.COM [GNK-3.8]
remote: error: File: db501995ac30070d50bdc115a7708f9ba84332d3 403.57 MB, exceeds 100.00 MB.
remote: Use command below to see the filename:
remote: git rev-list --objects --all | grep db501995ac30070d50bdc115a7708f9ba84332d3
remote: Please remove the file from history and try again. (https://gitee.com/help/articles/4232)
To gitee.com:findmoon/xxxx.git
 ! [remote rejected] master -> master (pre-receive hook declined)
error: failed to push some refs to 'git@gitee.com:findmoon/xxxx.git'

根據(jù)提示,如下查看大文件是哪個(gè)

commit的大文件無(wú)法push到遠(yuǎn)程庫(kù)解決辦法

首先說(shuō)一下解決辦法,需要修改提交歷史,刪除已提交到本地倉(cāng)庫(kù)的大文件的提交記錄,

從commit的提交歷史中刪除指定文件的命令為git filter-branch --tree-filter 'rm -f 文件名' HEAD

如下,刪除大文件

$ git filter-branch --tree-filter 'rm -f "Electron/pdf/677969 xxxx xxx.pdf"' HEAD
Rewrite d1244f8fbc1f08b473bd498c023b09bd8ac3246b (12/12) (156 seconds passed, remaining 0 predicted)
Ref 'refs/heads/master' was rewritten

執(zhí)行刪除成功會(huì)返回Ref 'refs/heads/master' was rewritten提示,如果返回unchanged則表示沒(méi)有任何更改。

如果文件路徑包含空格需要用引號(hào)將刪除文件路徑包含起來(lái)。

然后重新push推送成功。

整體操作如下:

git filter-branch命令:

參考自git誤commit大文件導(dǎo)致不能push問(wèn)題解決

git commit后的回滾

撤銷(xiāo)已經(jīng)提交的commit有兩種方法:

使用 git reset --hard HEAD^

使用 git rebase -i HEAD~n

git reset --hard 丟棄最新的提交

代碼提交后,需求發(fā)生變化導(dǎo)致之前提交的已經(jīng)不合適,或者 代碼提交后發(fā)現(xiàn)有嚴(yán)重bug,需要回滾可是使用這個(gè)命令:

git reset --hard HEAD^

1,HEAD^ 表示 最新提交HEAD位置往回?cái)?shù)一個(gè)提交, 幾個(gè) ^ 就往回?cái)?shù)幾個(gè)提交;

2,HEAD~n 表示 最新提交HEAD位置往回?cái)?shù)n個(gè)提交

reset 命令只能回滾最新的提交。如果只想刪除指定的某個(gè)提交,而保留最新的一次或兩次commit,reset就無(wú)法做到了。

reset命令git 刪除某次指定的提交

git rebase -i 丟棄指定提交

如果想撤銷(xiāo)中間某次commit的情況,可以使用如下的命令:

git rebase -i HEAD~2(列出最新的兩次提交,然后決定對(duì)應(yīng)提交的操作)

rebase -irebase --interactive 的縮寫(xiě);

git rebase -i 不僅可以刪除commit, 還可以修改commit。 具體的可以查看rebase中提示的參數(shù)

如下執(zhí)行git rebase查看命令參數(shù):

$ git rebase -i HEAD~2
pick 71add05 20200225同步
pick 45d4805 測(cè)試刪除中間某次commit

# Rebase 36b460a..45d4805 onto 36b460a (2 commands)
#
# Commands:
# p, pick <commit> = use commit
# r, reword <commit> = use commit, but edit the commit message
# e, edit <commit> = use commit, but stop for amending
# s, squash <commit> = use commit, but meld into previous commit
# f, fixup <commit> = like "squash", but discard this commit's log message
# x, exec <command> = run command (the rest of the line) using shell
# b, break = stop here (continue rebase later with 'git rebase --continue')
# d, drop <commit> = remove commit
# l, label <label> = label current HEAD with a name
# t, reset <label> = reset HEAD to a label
# m, merge [-C <commit> | -c <commit>] <label> [# <oneline>]
# . create a merge commit using the original merge commit's
# . message (or the oneline, if no original merge commit was
# . specified). Use -c <commit> to reword the commit message.
#
# These lines can be re-ordered; they are executed from top to bottom.
#
# If you remove a line here THAT COMMIT WILL BE LOST.
#
# However, if you remove everything, the rebase will be aborted.
#
# Note that empty commits are commented out

常用的如下:

  • edit: 使用本次提交,在rebase到這次提交時(shí)候,會(huì)暫停下來(lái)等待修正
  • pick:使用本次提交,不操作修改
  • drop:刪除這次提交

如下,修改查看最近3次的提交,然后刪除(drop)倒數(shù)第三次commit,保存退出即可將倒數(shù)第三次commit中提交的所有內(nèi)容刪除

回滾最新的提交 :git resetgit rebase 命令都可以

回滾中間某次提交: git rebase 可以, git reset 不可以

如果提交已經(jīng)同步到遠(yuǎn)程倉(cāng)庫(kù),需要使用git push origin -f branch(分支名) 來(lái)將回滾也同步到遠(yuǎn)程倉(cāng)庫(kù)(master 分支謹(jǐn)慎使用 -f)

主要參考自Git回退代碼到某次commit的實(shí)現(xiàn)方法

git rebase

git rebase執(zhí)行失敗后的退出

像上面,執(zhí)行git rebase有可能導(dǎo)致失敗,具體表現(xiàn)為bash中的倉(cāng)庫(kù)標(biāo)識(shí)變?yōu)榱?code>(master|REBASE 1/10)(m/n視r(shí)eabse編輯內(nèi)容而定)

解決辦法是:執(zhí)行git rebase --abort即可退出這個(gè)錯(cuò)誤,回退到當(dāng)前分支中,且數(shù)據(jù)和文件也都能恢復(fù)。

不小心git rebase后出現(xiàn)(master|REBASE 1/10)的解決辦法

git rebase成功后的回退

上面講的是git rebase失敗后的退出(,或回退),如果成功刪除了某次commit,導(dǎo)致最終一些文件或數(shù)據(jù)丟失,如何恢復(fù)呢?

不要輕易使用 git rebase -i HEAD 刪除某次提交

git rebase -i HEAD~2中刪除某次提交的話,這次提交的所有更改和新增文件會(huì)全部取消,覆蓋本地工作目錄中的文件,也就是刪除的這次提交和本次提交的上一次提交中間的所有更改都會(huì)取消,即使pick了刪除提交的下一次提交,也無(wú)法保留(保留到最新提交時(shí)所有文件和文件夾的狀態(tài))

可以使用git reset --hard ID命令,直接恢復(fù)commit到指定的提交時(shí)刻。

git reflog查看git提交記錄

如上,可以直接看到需要恢復(fù)到的commit ID是多少。比如恢復(fù)到Id為71add05的時(shí)刻,執(zhí)行git reset --hard 71add05等待恢復(fù)。本地倉(cāng)庫(kù)和文件就能恢復(fù)到指定提交時(shí)刻。

恢復(fù)指定的某次commit成功。

git rebase 成功之后如何撤銷(xiāo)

Git rebase命令使用實(shí)戰(zhàn)

刪除文件后需要執(zhí)行git add -Agit rm <file>,將刪除添加到暫存區(qū), 如果執(zhí)行 git add. 是不行的,區(qū)別如下:

git add -A 保存所有的修改(包括刪除的文件、新增文件、已有文件的修改變更)git add . 保存新的添加和修改,但是不包括刪除git add -u 保存修改和刪除,但是不包括新建文件。

到此這篇關(guān)于記一次使用commit提交大文件無(wú)法推送到遠(yuǎn)程庫(kù)解決問(wèn)題過(guò)程及git rebase使用的文章就介紹到這了,更多相關(guān)commit提交大文件git rebase使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • GIT如何修改賬號(hào)密碼重新登錄和保存密碼

    GIT如何修改賬號(hào)密碼重新登錄和保存密碼

    這篇文章主要介紹了GIT如何修改賬號(hào)密碼重新登錄和保存密碼問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • json顯示日期帶T問(wèn)題的解決方法

    json顯示日期帶T問(wèn)題的解決方法

    使用json顯示日期時(shí),細(xì)心的朋友會(huì)發(fā)現(xiàn)帶T字母,就是天數(shù)跟小時(shí)數(shù)之間出現(xiàn)了一個(gè)T,下面為大家介紹下具體的解決方法
    2013-10-10
  • Tortoise Git(烏龜git)常用命令總結(jié)

    Tortoise Git(烏龜git)常用命令總結(jié)

    Git作為一個(gè)復(fù)雜的版本控制系統(tǒng),命令之多,即使經(jīng)常使用,一些命令也記不住,一般只記住幾個(gè)常用的命令,本文主要介紹了Tortoise Git(烏龜git)常用命令總結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-08-08
  • 怎樣刪除Git中緩存的用戶名和密碼

    怎樣刪除Git中緩存的用戶名和密碼

    這篇文章主要介紹了怎樣刪除Git中緩存的用戶名和密碼問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • 瀏覽器緩存知識(shí)小結(jié)及應(yīng)用分析

    瀏覽器緩存知識(shí)小結(jié)及應(yīng)用分析

    了解瀏覽器的緩存命中原理,是開(kāi)發(fā)web應(yīng)用的基礎(chǔ),本文著眼于此,學(xué)習(xí)瀏覽器緩存的相關(guān)知識(shí),總結(jié)緩存避免和緩存管理的方法,結(jié)合具體的場(chǎng)景說(shuō)明緩存的相關(guān)問(wèn)題。希望能對(duì)有需要的人有所幫助
    2017-03-03
  • 在MAUI中使用Masa?Blazor的方法

    在MAUI中使用Masa?Blazor的方法

    這篇文章主要介紹了在MAUI中使用Masa?Blazor,探索一下如何在MAUI中使用Masa?Blazor,開(kāi)頭介紹了什么是MAUI,需要的朋友可以參考下
    2022-04-04
  • 代碼著色之SyntaxHighlighter項(xiàng)目(最流行的代碼高亮)

    代碼著色之SyntaxHighlighter項(xiàng)目(最流行的代碼高亮)

    dp.SyntaxHighlighter。它可以在網(wǎng)頁(yè)中對(duì)各種程序源代碼語(yǔ)法進(jìn)行加亮顯示。支持當(dāng)前流 行的各種編程語(yǔ)言:C#、CSS、C++、Delphi、Java、JavaScript、PHP、Python、Ruby、SQL、Visual Basic、XML / HTML等
    2014-04-04
  • wap開(kāi)發(fā)中如何有效的利用緩存減少消息的傳送量

    wap開(kāi)發(fā)中如何有效的利用緩存減少消息的傳送量

    由于WAP信道帶寬的限制,我們?cè)诰帉?xiě)WAP應(yīng)用的時(shí)候都希望最大限度地減少消息的傳送量。
    2010-06-06
  • 教你用PyTorch部署模型的方法

    教你用PyTorch部署模型的方法

    這篇文章主要介紹了用PyTorch部署模型的相關(guān)知識(shí),演示了使用PyTorch最近發(fā)布的新工具torchserve來(lái)進(jìn)行PyTorch模型的部署的相關(guān)知識(shí),需要的朋友可以參考下
    2022-02-02
  • Sublime?Text?4?安裝Package?Control的詳細(xì)步驟

    Sublime?Text?4?安裝Package?Control的詳細(xì)步驟

    最近換了臺(tái)電腦安裝了Sublime?Text?4但是按照之前的方法Package?Control怎么也安裝不上,查閱很多資料多次嘗試發(fā)現(xiàn)Sublime?Text?4可以直接安裝不需要之前那些步驟,下面小編把安裝步驟分享給大家,需要的朋友參考下吧
    2022-01-01

最新評(píng)論