git rebase 合并多个 commit 后,无法 push 到 origin 上
git 上有 5 条 commit 记录,我用 git rebase 将 5 条 commit 记录合并成了 1 条,这时使用 git push -f origin main 进行推送却报错:
git push -f origin develop
Enumerating objects: 48, done.
Counting objects: 100% (48/48), done.
Delta compression using up to 12 threads
Compressing objects: 100% (19/19), done.
Writing objects: 100% (26/26), 4.52 KiB | 385.00 KiB/s, done.
Total 26 (delta 12), reused 0 (delta 0), pack-reused 0
remote: GitLab: You are not allowed to force push code to a protected branch on this project.
To xxx.xxx.xxx.git
! [remote rejected] develop-norm -> develop (pre-receive hook declined)
error: failed to push some refs to ' xxxx.xxxx.xxxx.git'
You are not allowed to force push code to a protected branch on this project.
You are not allowed to force push code to a protected branch on this project.
发起合并请求呗
gitlab 默认会对主分支执行保护,禁止强制推送到主分支,你可以选择关闭这个选项或者不要这么做,只在自己的私有的分支上 rebase ,不要在主分支上执行 rebase,就正常的做 merge 好了。
Git Rebase itself is not seriously dangerous. The real danger cases arise when executing history rewriting interactive rebases and force pushing the results to a remote branch that's shared by other users. This is a pattern that should be avoided as it has the capability to overwrite other remote users' work when they pull. www.atlassian.com/git/tutorials/rewriting-history/git-rebaserebase 本地用用就好,如果要推到远程仓库会在别人 pull 的时候导致他的自己写的内容丢失如果这个项目完全只有你自己用,那你删了旧项目新建个新项目更方便
正常情况下,就不应该 push -f origin mainrebase 用自己的的分支 rebase ,然后 提 MR/PR 去 main 或者其他受保护分支真要 Squash commit 并且像 main 推,那也是在 MR/RP 里做,Gitlab 本来就支持这个操作
push -f
我整天让 githubbot rebase ,罪过罪过
rebase -i 适合你自己的开发分支整理提交,你自己用随便怎么整。不要在公共分支上用 rebase -i
rebase 到 origin/main 就不会有任何问题,也不需要强推
公共分支禁止 rebase ,小心被队友暴打
你得有权限,并且需要强制 push
+65535 ,我原来就有同事 rebase ,然后差点儿被我们暴打。我就不明白了,为啥都这么喜欢 rebase, rebase, rebase ,难道用 merge 就违法吗
在自己分支上 rebase 可以使 commit line 干净一些
不是管理员不要在公共分支上强推分支保护就是为了规避这种问题的特殊需求的话,临时开放下权限
rebase 之后一般会 force push ,如果 rebase 到 force push 提交完成之间有人 push ,会挤掉然后丢失
应该非保护分支(公共分支),rebase with 其它分支的后,提交上去,再 MR 过去。这种问题就是 git flow 姿势不对
已经说的很清楚了:You are not allowed to force push code to a protected branch on this project. 在自己分支 rebase ,提 merge request 到 master 或者你的 main 分支
公共分支使用 merge ,在自己分支上使用 rebase 别人的代码
知道 push -f 命令,却不知道分支可以禁止强制推送,楼主的情况像极了跟着别人的半吊子教程去操作/搞事的人。
可以了,设置中临时允许强制推送,推送成功,感谢各位大佬!
rebase 后要 push -f ,一般用于发布前把 master 分支最新修改合并进开发分支且使开发分支的提交记录清爽,如果开发分支也不允许 push -f 的话,就不能用 reabse
我认为 rebase -i 跟 rebase 完全不是一回事也没必要混到一起说平时使用 pull --rebase 或者用 rebase 正确合并两个分支不会需要用到 force push与 merge 不同,rebase 是有顺序的
即使 --force 也要用 --force-with-lease
自己私人的项目,并且完全没有别人 clone 过,可以强制 push ,其它情况不建议。
通过 PR 方式来 force push, 这样既可以保护 main/master, 也方便以 PR 为单位管理功能开发。
哈哈哈,仔细看看报错,就是不允许强推,在多人合作和项目开发里,release 和 master/main 是有保护的,都是自己分支上 rebase 成一个 commit ,或者 git pull --rebase origin/master 后再 push -f 的
根据当前地址位置 查询周围 5 公里的博物馆 ,怎么拿当前的经纬度?如果 android 自带 的 GPS 定位存在定位不到的现象,有没有什么好的方法??? 国内几家地图商量…
使用群辉自带的虚拟机装一个 openwrt ,然后作为一个旁路网关使用。 设置群辉的 ip 为静态 ip ,网关设置为 openwrt 的 IP 地址,就可以使用 openwr…
换机问题又跑到我头上了。(本人双持,Apple 发在另个帖子里) 目前还在坚守高通 835 的小米 6 。但随着时间推移,想把米 6 扔柜子锁了。换一个好点的高通 865 或…