git revert 和 git reset 的區(qū)別
git revert是用一次新的commit來回滾之前的commit
git reset是直接刪除指定的commit
在回滾這一操作上看,效果差不多。但是在日后繼續(xù)
merge以前的老版本時有區(qū)別。因為git revert是用一次**逆向的commit** 中和之前的提交,因此日后合并老的branch時,導(dǎo)致這部分改變不會再次出現(xiàn)git reset是把某些commit在某個branch上刪除,因而合并老的branch再次merge時,這些被回滾的commit應(yīng)該還會被引入git reset是把HEAD向后移動了一下,而git revert是HEAD繼續(xù)前進,只是新的commit的內(nèi)容和要revert的內(nèi)容正好相反,能夠抵消要被revert的內(nèi)容
git revert
git revert 撤銷 某次操作,此次操作之前和之后的 commit 和 history 都會保留,并且把這次撤銷作為一次最新的提交
* git revert HEAD 撤銷前一次 commit
* git revert HEAD^ 撤銷前前一次 commit
* git revert commit (比如:fa042ce57ebbe5bb9c8db709f719cec2c58ee7ff)撤銷指定的版本,撤銷也會作為一次提交進行保存。
git revert 是提交一個新的版本,將需要 revert 的版本的內(nèi)容再反向修改回去,版本會遞增,不影響之前提交的內(nèi)容
總結(jié)
要保留歷史 commit,使用 git revert!
要刪除歷史 commit,使用 git reset!