gerrit 不能推送 merge

本文详细介绍了在使用Gerrit进行代码推送时遇到“nonewchanges”错误的原因及解决方案,强调了在Gerrit环境下应使用rebase而非merge的工作流程,通过具体的git命令操作步骤,帮助读者解决类似的推送失败问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

git merge后推送到远程老是报错:

Total 0 (delta 0), reused 0 (delta 0)
remote: Processing changes: refs: 1, done
To ssh://xxx@gerrit.xxx.cn:8090/xxx
 ! [remote rejected] HEAD -> refs/for/dev (no new changes)
error: failed to push some refs to 'ssh://xxx@gerrit.xxx.cn:8090/xxx'

解决方案:

git rebase
  Cannot rebase: You have unstaged changes.//如果本地文件有更改,会让先暂存
//暂存代码
git stash
// 每次 push 前
git pull --rebase
git push origin HEAD:refs/for/master
// gerrit review
git pull
git stash pop

gerrit 不允许 merge 后提交,需使用 rebase 方式,所以本地 pull 以 rebase 方式进行,如:git pull –rebase

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值