除了在local reset后再push之外 有没有在remote直接reset之类的呢? 意义是不想remote有过多commit comment
学习是最好的投资!
いいえ、git restart --hard を実行してから、git Push -f のみを実行できます。 git reset --hard 然后 git push -f。
git restart --hard
git Push -f
git reset --hard
git push -f
你的问题询问的是如何撤销 remote 的 commit,唯一的办法就是本地修正然后又强制推送,并且很多人都已经提到,强制推送是非常坏的实践,除非必要或者个人未公开项目或者小团队项目(沟通成本较低)才可行。
看了你给别的回答的评论,貌似你想清理提交历史,那么 git 相比于其它 VCS 在这方面绝对是非常在行的。你可以使用 git rebase 命令对历史进行重构,可以重新排序、合并、拆分一些提交,总之完全足够清理你所谓的脏历史。如果你想要对整个历史做某些确定的修改,还有 git fileter-branch
git rebase
git fileter-branch
インターネットにアップロードしたものはすべて歴史であり、歴史は尊重されなければなりません。一度公開すると、それはインターネット上での歴史となり、歴史は尊重されなければなりません。
私のアプローチは、ローカルで正しいバージョンにロールバックしてから、それを一度プッシュすることです。以前のコミットレコードを削除したい場合は、git rebaseを使用する必要があるようです
参照: Github に間違ったコミットを送信した後の対処方法
いいえ、
git restart --hard
を実行してから、git Push -f
のみを実行できます。git reset --hard
然后git push -f
。你的问题询问的是如何撤销 remote 的 commit,唯一的办法就是本地修正然后又强制推送,并且很多人都已经提到,强制推送是非常坏的实践,除非必要或者个人未公开项目或者小团队项目(沟通成本较低)才可行。
看了你给别的回答的评论,貌似你想清理提交历史,那么 git 相比于其它 VCS 在这方面绝对是非常在行的。你可以使用
あなたの質問は、リモートコミットを元に戻す方法について尋ねています。唯一の方法は、ローカルで修正してから強制プッシュすることです。必要な場合、または個人の非公開プロジェクトや小規模なプロジェクトの場合は、強制プッシュは非常に悪い習慣であると述べています。 (通信コストを抑えて)実現可能です。git rebase
命令对历史进行重构,可以重新排序、合并、拆分一些提交,总之完全足够清理你所谓的脏历史。如果你想要对整个历史做某些确定的修改,还有git fileter-branch
git rebase
コマンドを使用して履歴を再構築できます。つまり、いわゆるダーティな履歴をクリーンアップするだけで十分です。履歴全体に特定の変更を加えたい場合は、git fileter-branch
コマンドも利用できます。これは非常に柔軟であり、試してみる価値があります。インターネットにアップロードしたものはすべて歴史であり、歴史は尊重されなければなりません。一度公開すると、それはインターネット上での歴史となり、歴史は尊重されなければなりません。
長い間悩んだ結果、アップロード後に変更すべきではないとだけ言いたいです。私のアプローチは、ローカルで正しいバージョンにロールバックしてから、それを一度プッシュすることです。以前のコミットレコードを削除したい場合は、git rebaseを使用する必要があるようです
。参照: Github に間違ったコミットを送信した後の対処方法