校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > git 優雅的撤銷中間某次提交方法

git 優雅的撤銷中間某次提交方法

熱門標簽:襄陽外呼增值業務線路解決方案 廊坊地圖標注申請入口 高德地圖標注公司位置需要錢嗎 北京外呼系統咨詢電話 海南人工外呼系統哪家好 怎么去掉地圖標注文字 合肥阿里辦理400電話號 地圖標注資源分享注冊 慶陽外呼系統定制開發

環境

git : 2+

前言

最近兩天,公司的git合并代碼時,出現了嚴重的問題,浪費很多時間;
現在記錄下;
情況是這樣的,一個同事自己的本地分支(遠程沒有),不知怎么的,有了別人開發分支的代碼,而他自己又不知道;
其在切換到主分支,并merge自己的分支,此時其已經把別人正在開發的代碼都合并到了主分支。

到了晚上準備升級時,才發現,主分支的代碼出了問題;此時版本庫是這樣的:

如圖 100047dcc這一步就有不該有的代碼;

而此時版本庫已經提交過了很多次,現在的問題就是,如何撤銷掉100047dcc提交的代碼,并且保留其他人提交的代碼。

這個問題,折騰到了晚上9點半左右,嘗試了網上給出的:

git rebase -i commit_id
//再通過將pick改為drop

但是,實際的效果是,100047dcc代碼沒了,其他人提交的代碼也沒有了!
也就是給人感覺和git reset --hard be8c6f6dd沒有什么區別!

最后因為太晚,從提交記錄上看,100047dcc之后就一個人提交了代碼,所以就執行了:

//先切一個備份分支
git branch -b master_tmp
//再執行
git reset --hard be8c6f6dd

之后,那個人(也就是我)從備份分支上把文件拷貝回來—(因為我是直接在主分支上改的,自己的分支并沒有代碼)。

第二天,我打算去拷貝文件,我執行如下操作:

yutao@yutao MINGW64 /d/sts/workspace/ggservice (master)
$ git pull
remote: Counting objects: 44, done.
remote: Compressing objects: 100% (23/23), done.
remote: Total 26 (delta 19), reused 0 (delta 0)
Unpacking objects: 100% (26/26), done.
From gitlab.gofund.cn:gg-service/ggservice
 + 1784b12...384decc master   -> origin/master (forced update)
  f8f2b19..eb33489 devyaomy  -> origin/devyaomy
 * [new branch]   master_tmp -> origin/master_tmp
Already up-to-date.

yutao@yutao MINGW64 /d/sts/workspace/ggservice (master)
$ git status
On branch master
Your branch is ahead of 'origin/master' by 796 commits.
 (use "git push" to publish your local commits)
nothing to commit, working directory clean

yutao@yutao MINGW64 /d/sts/workspace/ggservice (master)
$ git push
Total 0 (delta 0), reused 0 (delta 0)
To git@gitlab.gofund.cn:gg-service/ggservice.git
  384decc..1784b12 master -> master

簡單的說,我的操作就是兩步:
1git pull
2、git push
結果又把代碼還原回去了!

為啥呢?

雖然昨天晚上,把遠程庫的版本回退到了正確的版本,但是我的本地主分支還是最新的commit,也就是說,相比遠程庫,我本地庫是超前了多次提交,畢竟因為遠程庫回退了嘛!

這個時候,我必須也得對本地庫進行回退,回退到線上相同的commit節點才行。

這個時候,我做了以下幾個操作:

yutao@yutao MINGW64 /d/sts/workspace/ggservice (master)
$ git reset --soft 384deccaa6
$ git status
On branch master
Your branch is up-to-date with 'origin/master'.
Changes to be committed:
 (use "git reset HEAD file>..." to unstage)

    modified:  .gitignore
    modified:  conf/application.conf
    new file:  conf/hanlp.properties
    new file:  dataservice/app/ggservice/common/UserCodeEnum.java
    new file:  dataservice/app/ggservice/v1/email/action/BindEmailGG3Action.java
    new file:  dataservice/app/ggservice/v1/email/action/SendEmailCaptchaGG3Action.java
    // 文件太多不一一顯示
yutao@yutao MINGW64 /d/sts/workspace/ggservice (master)
$ git reset --hard 384deccaa6

上面敲了很多命令,其實真正只需要git reset --hard 384deccaa6即可。

git reset --hard 384deccaa6

接下來,我開始復制粘貼,從備份分支上,把代碼拷貝下。
真的操蛋,這等于是增加工作量啊!

revert 撤銷某次提交

到了下午,又有個同事干了類似我上午的操作。把不該有的代碼提交上去了!
這就麻煩了,雖然遠程庫回退了!結果是要求凡是pull最新代碼的人,都得進行本地回退的操作。
否則,就沒完沒了!

到了晚上,對著備份分支進行測試,終于找到了優雅的解決辦法!

這就是revert命令

該命令就是為撤銷某次提交而存在的;

首先,我是明白100047dcc這次提交是有問題的,這是問題的源頭;
也就是說,只要我們把這次提交的給撤銷了,就不會有問題了!

步驟 一

$ git revert 100047dcc
error: Commit 100047dccb58f3ee5e27b0dfaf5c02ac91dc2c73 is a merge but no -m option was given.
fatal: revert failed

結果報錯了,報了一個Commit is a merge but no -m option was given.

為什么呢?

如果100047dcc這只是一個普通的提交,其實是不會報錯的!
但是,這是一個merge的提交。

那么在撤銷時,git并不知道我要撤銷具體哪次!如下圖:

這個時候,怎么辦呢?

我的做法

步驟二

yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp)
$ git revert 100047dcc -m 1
error: could not revert 100047d... Merge branch 'master' of gitlab.gofund.cn:gg-service/ggservice into wjs
hint: after resolving the conflicts, mark the corrected paths
hint: with 'git add paths>' or 'git rm paths>'
hint: and commit the result with 'git commit'

我執行了這樣的一個操作:

git revert 100047dcc -m 1

參數 -m 就是指定要撤銷的那個提價,從左往右,從1開始數;也就是我撤銷的是ca4a7ff999

接著其把代碼沖突,然后我就解決沖突,保留主分支的代碼,去掉那個人的代碼。

解決完沖突后,我執行如下操作:

yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp|REVERTING)
$ git add -A

yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp|REVERTING)
$ git status
On branch master_tmp
Your branch is up-to-date with 'origin/master_tmp'.
You are currently reverting commit 100047d.
 (all conflicts fixed: run "git revert --continue")
 (use "git revert --abort" to cancel the revert operation)

Changes to be committed:
 (use "git reset HEAD file>..." to unstage)

    modified:  dataservice/app/ggservice/v1/datacentre/action/GetIncomeDistributeAction.java
    //文件太多省略。。。

yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp|REVERTING)
$ git commit -m "ceshi"
[master_tmp d2ae829] ceshi
 18 files changed, 95 insertions(+), 396 deletions(-)

我上面執行的語句其實就是:

$ git add -A
$ git commit -m "ceshi"

步驟三

yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp)
$ git revert 100047dcc -m 2
error: could not revert 100047d... Merge branch 'master' of gitlab.gofund.cn:gg-service/ggservice into wjs
hint: after resolving the conflicts, mark the corrected paths
hint: with 'git add paths>' or 'git rm paths>'
hint: and commit the result with 'git commit'

也就是執行:

$ git revert 100047dcc -m 2

即 撤銷be8c6f6dde的提交,這個時候也會提示代碼沖突了,

接著和上面一樣,解決沖突,在提交:

yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp|REVERTING)
$ git status
On branch master_tmp
Your branch is ahead of 'origin/master_tmp' by 1 commit.
 (use "git push" to publish your local commits)
You are currently reverting commit 100047d.
 (fix conflicts and run "git revert --continue")
 (use "git revert --abort" to cancel the revert operation)

Changes to be committed:
 (use "git reset HEAD file>..." to unstage)

    modified:  .gitignore
    deleted:  conf/hanlp.properties
    deleted:  dataservice/app/ggservice/common/UserCodeEnum.java
    deleted:  dataservice/app/ggservice/v1/email/action/BindEmailGG3Action.java
    deleted:  dataservice/app/ggservice/v1/email/action/SendEmailCaptchaGG3Action.java
    deleted:  dataservice/app/ggservice/v1/email/service/EmailCaptchaService.java
    deleted:  dataservice/app/ggservice/v1/expert/action/GetExpertOfStockAssessAction.java
    modified:  dataservice/app/ggservice/v1/expert/service/ExpertGG3Service.java
    modified:  dataservice/app/ggservice/v1/ggmtoolbox/action/GetMyStockLabelInfoAction.java
    modified:  dataservice/app/ggservice/v1/ggmtoolbox/action/UpdateUserTokenInfoAction.java
    modified:  dataservice/app/ggservice/v1/ggmtoolbox/service/AppDOSInfoService.java
    modified:  dataservice/app/ggservice/v1/ggmtoolbox/service/UserInfoService.java
    modified:  dataservice/app/ggservice/v1/graph/action/GetStockPlateComponentAction.java
    modified:  dataservice/app/ggservice/v1/graph/service/StockPlateService.java
    // 文件太多省略。。。

yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp|REVERTING)
$ git add -A

yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp|REVERTING)
$ git status
On branch master_tmp
Your branch is ahead of 'origin/master_tmp' by 1 commit.
 (use "git push" to publish your local commits)
You are currently reverting commit 100047d.
 (all conflicts fixed: run "git revert --continue")
 (use "git revert --abort" to cancel the revert operation)

Changes to be committed:
 (use "git reset HEAD file>..." to unstage)

    modified:  .gitignore
    modified:  conf/application.conf
    deleted:  conf/hanlp.properties
    deleted:  dataservice/app/ggservice/common/UserCodeEnum.java
    deleted:  dataservice/app/ggservice/v1/email/action/BindEmailGG3Action.java
    deleted:  dataservice/app/ggservice/v1/email/action/SendEmailCaptchaGG3Action.java
    deleted:  dataservice/app/ggservice/v1/email/service/EmailCaptchaService.java
    deleted:  dataservice/app/ggservice/v1/expert/action/GetExpertOfStockAssessAction.java
    modified:  dataservice/app/ggservice/v1/expert/service/ExpertGG3Service.java
    modified:  dataservice/app/ggservice/v1/ggmtoolbox/action/GetMyStockLabelInfoAction.java
    modified:  dataservice/app/ggservice/v1/ggmtoolbox/action/UpdateUserTokenInfoAction.java
    modified:  dataservice/app/ggservice/v1/ggmtoolbox/service/AppDOSInfoService.java
    modified:  dataservice/app/ggservice/v1/ggmtoolbox/service/UserInfoService.java
    modified:  dataservice/app/ggservice/v1/graph/action/GetStockPlateComponentAction.java
    modified:  dataservice/app/ggservice/v1/graph/service/StockPlateService.java
    modified:  dataservice/app/ggservice/v1/hq/action/GetStockHistoryDynamicAction.java
    modified:  dataservice/app/ggservice/v1/keybordspirit/action/GetMyGroupStockIndexAction.java

yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp|REVERTING)
$ git commit -m "使用revert 版本號 -m 1或者2同時進行撤銷某次提交測試"
[master_tmp 236da00] 使用revert 版本號 -m 1或者2同時進行撤銷某次提交測試
 95 files changed, 2093 insertions(+), 10011 deletions(-)
 delete mode 100644 conf/hanlp.properties
 delete mode 100644 dataservice/app/ggservice/common/UserCodeEnum.java
 delete mode 100644 dataservice/app/ggservice/v1/email/action/BindEmailGG3Action.java
 delete mode 100644 dataservice/app/ggservice/v1/email/action/SendEmailCaptchaGG3Action.java
 delete mode 100644 dataservice/app/ggservice/v1/email/service/EmailCaptchaService.java
 delete mode 100644 dataservice/app/ggservice/v1/expert/action/GetExpertOfStockAssessAction.java
 delete mode 100644 dataservice/app/ggservice/v1/mobile/action/BindMobileGG3Action.java
 delete mode 100644 dataservice/app/ggservice/v1/mobile/action/SendMobileCaptchaGG3Action.java
 rewrite dataservice/app/ggservice/v1/mystocktags/service/MyStockTagService.java (82%)
 delete mode 100644 dataservice/app/ggservice/v1/report/action/GetAuthorRankListAction.java
 delete mode 100644 dataservice/app/ggservice/v1/report/action/GetAuthorRecommendReportListAction.java
 delete mode 100644 dataservice/app/ggservice/v1/report/action/GetHonoraryAuthorListAction.java
 delete mode 100644 dataservice/app/ggservice/v1/report/action/GetHotIndustryListAction.java
 delete mode 100644 dataservice/app/ggservice/v1/report/action/GetHotStockListAction.java
 delete mode 100644 dataservice/app/ggservice/v1/report/action/GetHotThemeListAction.java
 delete mode 100644 dataservice/app/ggservice/v1/report/action/GetOrganRankListAction.java
 delete mode 100644 dataservice/app/ggservice/v1/report/condition/AuthorOrganRankCondition.java
 delete mode 100644 dataservice/app/ggservice/v1/report/condition/HotReportCondition.java
 delete mode 100644 dataservice/app/ggservice/v1/report/service/HotReportService.java
 delete mode 100644 dataservice/app/ggservice/v1/usergg/action/AutoLoginAction.java
 delete mode 100644 dataservice/app/ggservice/v1/usergg/action/BindOuterChannelAction.java
 delete mode 100644 dataservice/app/ggservice/v1/usergg/action/EmailRegisterAction.java
 delete mode 100644 dataservice/app/ggservice/v1/usergg/action/GetUserAction.java
 delete mode 100644 dataservice/app/ggservice/v1/usergg/action/IsAccountExistAction.java
 delete mode 100644 dataservice/app/ggservice/v1/usergg/action/LoginAction.java
 delete mode 100644 dataservice/app/ggservice/v1/usergg/action/LogoutAction.java
 delete mode 100644 dataservice/app/ggservice/v1/usergg/action/OuterChannelLoginAction.java
 delete mode 100644 dataservice/app/ggservice/v1/usergg/action/RegisterAction.java
 delete mode 100644 dataservice/app/ggservice/v1/usergg/service/LoginService.java
 delete mode 100644 dataservice/app/ggservice/v1/usergg/service/RegisterService.java
 delete mode 100644 dataservice/app/ggservice/v1/usergg/service/UserCommonUtils.java
 delete mode 100644 dataservice/app/ggservice/v1/usergg/service/UserService.java

即:

$ git add -A
$ git commit -m "使用revert 版本號 -m 1或者2同時進行撤銷某次提交測試"

可以看出刪除掉了那個人提交的文件。

最后一步

yutao@yutao MINGW64 /d/sts/workspace/ggservice (master_tmp)
$ git push

這樣就把那個人提交錯誤的代碼給刪除了,其他人的本地分支也不需要版本回退了!
一次改好,到處OK!

總結

當想撤銷中間某次提交時,強烈建議使用revert命令,而不是reset
git reset –hard commit_id 雖然可以回退遠程庫,但是其要求pull最新代碼的每個人的本地分支都要進行版本回退。這樣就增加工作量了!

正確的步驟:

git revert commit_id
//如果commit_id是merge節點的話,-m是指定具體哪個提交點
git revert commit_id -m 1
//接著就是解決沖突
git add -A
git commit -m ".."
git revert commit_id -m 2
//接著就是解決沖突
git add -A
git commit -m ".."
git push

其中git revert commit_id -m 數字是針對,merge提交點的操作。
如果是普通的提交點,不需要這么麻煩。

參考地址:
[Git高級教程(二)] 遠程倉庫版本回退方法
https://www.cnblogs.com/ShaYeBlog/p/5368064.html
https://blog.csdn.net/hongchangfirst/article/details/49472913

到此這篇關于git 優雅的撤銷中間某次提交方法的文章就介紹到這了,更多相關git 撤銷某次提交內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • git rebase 成功之后撤銷的操作方法
  • Git撤銷&回滾操作(git reset 和 get revert)
  • git如何撤銷commit的方法(未push)
  • Git使用小技巧之回滾與撤銷詳解
  • 基于Git的常用撤銷技巧與解決沖突方法(推薦)
  • Git 撤銷操作、刪除文件和恢復文件
  • Git里多種撤銷操作的最佳方法

標簽:商丘 臺州 哈密 綿陽 株洲 鶴崗 鎮江 平頂山

巨人網絡通訊聲明:本文標題《git 優雅的撤銷中間某次提交方法》,本文關鍵詞  git,優雅,的,撤銷,中間,某次,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《git 優雅的撤銷中間某次提交方法》相關的同類信息!
  • 本頁收集關于git 優雅的撤銷中間某次提交方法的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    夜夜嗨av一区二区三区四季av | ...av二区三区久久精品| 欧美久久久久久久久中文字幕| 色88888久久久久久影院按摩| 9久草视频在线视频精品| 99re免费视频精品全部| 成人免费黄色大片| 99视频一区二区| 色噜噜久久综合| 欧美三级视频在线观看 | 一区二区三区免费网站| 亚洲卡通欧美制服中文| 亚洲乱码国产乱码精品精98午夜| 亚洲免费视频成人| 亚洲一区二区三区四区在线观看| 一区二区三区电影在线播| 亚洲高清在线精品| 免费人成在线不卡| 国产激情偷乱视频一区二区三区| www.爱久久.com| 精品视频全国免费看| 日韩视频一区二区三区在线播放| 精品久久久久久久久久久久久久久| 久久先锋资源网| 国产精品二三区| 午夜精彩视频在线观看不卡| 久久www免费人成看片高清| 国产成人av一区二区三区在线 | 国产精品网站在线观看| 亚洲男人的天堂在线观看| 亚洲国产美国国产综合一区二区 | 久久综合久久鬼色中文字| 国产色爱av资源综合区| 亚洲精品国产品国语在线app| 日韩高清国产一区在线| 成人丝袜高跟foot| 717成人午夜免费福利电影| 国产区在线观看成人精品| 亚洲激情六月丁香| 国产精品123区| 欧美日韩一区久久| 中文久久乱码一区二区| 日本女优在线视频一区二区| 99久久精品国产导航| 91精品国产综合久久久久| 国产精品网站一区| 奇米综合一区二区三区精品视频| 国产91露脸合集magnet | 国产亚洲婷婷免费| 亚洲aaa精品| 波多野洁衣一区| 欧美www视频| 亚洲一区二区三区免费视频| 国产高清精品网站| 91麻豆精品国产91久久久使用方法 | 成人手机在线视频| 欧美精品一区二区三区蜜臀 | 久久综合色婷婷| 肉色丝袜一区二区| 色网综合在线观看| 国产欧美日韩激情| 激情五月播播久久久精品| 欧美老女人第四色| 亚洲国产毛片aaaaa无费看| 成人精品在线视频观看| 久久久噜噜噜久噜久久综合| 石原莉奈在线亚洲二区| 欧美日韩一区二区电影| 国产精品视频免费看| 国产一区二区免费视频| 欧美精品一区二区三区蜜桃视频 | 亚洲一区二区不卡免费| www.亚洲精品| 国产精品日韩成人| 成人激情动漫在线观看| 中文字幕高清不卡| 高清不卡在线观看| 国产精品久久久久久户外露出 | 亚洲欧美日本韩国| 99久久国产综合精品女不卡| 中文字幕精品在线不卡| 成人在线综合网| 国产精品色婷婷| 99re这里只有精品首页| 亚洲免费在线观看视频| 欧美中文字幕久久 | 日韩欧美中文字幕制服| 国产一区二区不卡| 中文天堂在线一区| 在线影院国内精品| 日本亚洲电影天堂| 欧美成人精品二区三区99精品| 精品系列免费在线观看| 欧美激情综合五月色丁香| 不卡av在线免费观看| 中文字幕一区二区三区在线观看 | 色婷婷综合久久久中文字幕| 亚洲一卡二卡三卡四卡无卡久久 | 欧美国产97人人爽人人喊| 99国产麻豆精品| 五月综合激情婷婷六月色窝| 日韩欧美精品在线| 国产福利一区在线| 一区二区三区高清在线| 日韩视频一区二区| 成人深夜视频在线观看| 亚洲精品国产精品乱码不99 | 亚洲国产一区二区三区| 欧美精品一区二区高清在线观看 | 欧美顶级少妇做爰| 国产成人在线视频网站| 亚洲综合在线观看视频| 欧美一区二区视频网站| 92国产精品观看| 蜜臀av性久久久久av蜜臀妖精| 亚洲国产精品激情在线观看| 在线免费观看不卡av| 国产精品一级片| 五月激情六月综合| 国产精品毛片无遮挡高清| 91精品国产综合久久精品| a在线欧美一区| 精品一区二区精品| 亚洲综合清纯丝袜自拍| 国产偷国产偷精品高清尤物 | 韩国理伦片一区二区三区在线播放| 国产精品国产三级国产普通话99 | 成人欧美一区二区三区小说 | 欧美日韩在线观看一区二区| 国产白丝精品91爽爽久久| 午夜精品久久久久久久| 国产精品国产三级国产| 久久综合久久久久88| 欧美精品丝袜中出| 色乱码一区二区三区88| 粉嫩在线一区二区三区视频| 美国三级日本三级久久99| 亚洲午夜私人影院| 樱桃视频在线观看一区| 中文av字幕一区| 国产欧美一区二区在线观看| a级高清视频欧美日韩| 国产成人8x视频一区二区| 青青青伊人色综合久久| 五月天网站亚洲| 一区二区三区在线视频免费 | 91丨porny丨国产| 粉嫩嫩av羞羞动漫久久久| 精品亚洲欧美一区| 精品一区二区三区av| 久久电影网电视剧免费观看| 日本成人在线电影网| 午夜精品久久久久久久久| 亚洲色图第一区| 亚洲女同女同女同女同女同69| 国产精品国产自产拍高清av | 亚洲精品国产一区二区三区四区在线| 欧美国产精品一区二区三区| 日本一区二区成人在线| 国产精品久久久久婷婷| 国产精品高潮呻吟| 国产精品青草综合久久久久99| 久久久精品影视| 国产日韩欧美a| 国产精品国产三级国产有无不卡 | 亚洲成av人片一区二区梦乃| 一区二区三区在线观看视频| 一区二区三区四区在线播放| 一区二区三区日韩欧美| 午夜一区二区三区视频| 久久99九九99精品| 粉嫩av一区二区三区| a亚洲天堂av| 欧美军同video69gay| 精品三级在线观看| 久久久美女毛片| 亚洲欧美偷拍另类a∨色屁股| 香蕉久久一区二区不卡无毒影院| 美脚の诱脚舐め脚责91| 国产69精品久久99不卡| 一本大道久久a久久综合| 欧美日韩成人一区| 精品国产伦理网| 国产精品久久久久久久岛一牛影视| 亚洲精品视频一区| 久久99热国产| 色哟哟日韩精品| 欧美电影免费观看高清完整版在线观看| 久久久噜噜噜久久中文字幕色伊伊| 亚洲欧美一区二区在线观看| 日韩精品成人一区二区在线| 国产成a人亚洲精| 欧美无砖砖区免费| 国产日韩欧美高清在线| 午夜精品福利在线| 成人av综合在线| 欧美成人精品1314www| 一区二区在线电影| 国产成人精品免费网站| 在线电影国产精品|