V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
villivateur
V2EX  ›  问与答

对于不允许 merge 只允许 rebase 的开源项目,各位怎么看?这是一个好习惯吗?

  •  
  •   villivateur · 1 天前 · 1857 次点击

    比如 https://github.com/ArduPilot/ardupilot 这个项目,明确规定只允许 rebase 不许 merge 。

    这是一个好习惯吗?

    29 条回复    2024-11-29 09:27:44 +08:00
    murmur
        1
    murmur  
       1 天前
    rebase 做出来的树一条直线,贼 tm 漂亮,我以前做过有的项目就是用 rebase
    RightHand
        2
    RightHand  
       1 天前 via Android
    当成 svn 来用呗
    kera0a
        3
    kera0a  
       1 天前 via iPhone
    无所谓吧,merge 和 rebase 合并其实没本质上的区别
    000sitereg
        4
    000sitereg  
       1 天前
    我是能 rebase 就不 merge 。rebase 的时候有冲突就处理。从常理理解,别人先提交,log 中就在我之前,一条直线很好理解。
    Wxh16144
        5
    Wxh16144  
       1 天前
    无所谓 +1, 两个都做到会用,严于律己即可,别人如何规定就遵循他的规则罢了
    malusama
        6
    malusama  
       1 天前
    没什么差别啊, 而且 rebase 漂亮多了
    zsc8917zsc
        7
    zsc8917zsc  
       1 天前
    rebase 有代码覆盖的风险啊~
    GeruzoniAnsasu
        8
    GeruzoniAnsasu  
       1 天前
    这么说,rebase 之于 merge 约等于 golang 之于 c++
    donaldturinglee
        9
    donaldturinglee  
       1 天前
    merge 的话用 git log graph 有时候脑一抽不容易看得清楚...
    zealot0630
        10
    zealot0630  
       1 天前 via Android
    当你需要 bisect 时候,就知道好处了
    jim9606
        11
    jim9606  
       1 天前 via Android   ❤️ 1
    一般用 rebase,用不了的时候采用 merge 。不能用 rebase 的原因有:
    1. 分支不是私有的,已经被多人 checkout 或者 branch,rebase 会对合作者的工作流造成破坏
    2. 需要保留原始提交的时间轨迹,例如分支发布过版本
    3. commit 带 gpg 签名,rebase 毫无疑问会破坏签名
    4. 分支差异过大,rebase 过程会大量 conflict

    svn 和 git 的根本性区别是集中式 vs 分布式,只是因为 git 的 branch 成本低所以能玩得转频繁分支的工作流
    wysnxzm
        12
    wysnxzm  
       1 天前
    回滚找不到节点的时候就老实了
    virusdefender
        13
    virusdefender  
       1 天前
    我一般 rebase master 之后再 merge
    serco
        14
    serco  
       1 天前
    从前也是 rebase ,后面遇到几次莫名代码丢了就不这么干了
    julyclyde
        15
    julyclyde  
       1 天前
    @kera0a 最终内容没区别,但是实施代价的区别极大
    julyclyde
        16
    julyclyde  
       1 天前
    @zsc8917zsc 为什么会覆盖?
    jybox
        17
    jybox  
       1 天前   ❤️ 2
    准确地说是只允许 fast forward 的 merge ,即需要合并的分支基于目标分支的最新版本,如果不是的话就需要 rebase 到最新版本再 merge 。

    除了历史看着「干净」之外,我觉得最大的好处是在 rebase 之后、merge 之前,你还有机会检查你的代码、运行测试(其他人也可以在 PR 上继续 review 、CI 也会重新运行)。而在 GitHub 上直接点 merge 的话改动就直接被合并到目标分支,没有就会再检查了(当然你可以在本地 merge 并检查)。

    很多时候即使 merge 没有冲突,代码也可能会跑不起来。
    wen20
        18
    wen20  
       1 天前
    https://jhall.io/archive/2024/01/11/when-i-dont-rebase/
    这篇说的最好,
    总结一句话:rebase 只用在自己本地分支。
    wen20
        19
    wen20  
       1 天前
    公共分支 rebase 如同沙滩拉屎,个人很方便, 然而别的伙伴需要避免踩屎。
    yooomu
        20
    yooomu  
       1 天前
    通常 feat branch 会使用 rebase ,但是往 master 合并代码时使用 merge ,这样链路非常清晰
    Rache1
        21
    Rache1  
       1 天前
    如果只想保持 master 分支整洁的话,其实 merge 的时候加个 --squash 就好了。
    newtype0092
        22
    newtype0092  
       1 天前
    @wen20 和 rebase 比起来,merge 才更像拉屎,大家都可以方便的在空地来一坨,最后这个“雷区”会越来越大。
    只能 rebase 是要求主分支迭代时严格的链式结构管理,说白了就是让并发开发的人通过额外的工作来保证 feature 被串行的 merge ,但对于其他读者,但串行的版本链肯定比并行的版本树清晰易懂的多。
    chatgptnext
        23
    chatgptnext  
       1 天前
    来一次线上事故就老实了😋
    ensonmj
        24
    ensonmj  
       1 天前 via iPhone
    squash 再 rebase ,清晰
    crysislinux
        25
    crysislinux  
       1 天前 via Android
    你自己的开发分支在有其他人参与之前随便 rebase 还是 merge 。有人参与之后就只 merge ,最后合并到 main 的时候 squash merge 清理一下。
    mayli
        26
    mayli  
       1 天前
    没太大区别…repo 制定了就遵守就好了
    tags
        27
    tags  
       1 天前
    如果是明显的特性分支合并就用 merge ,保留时间线。如果是独立的提交就用 rebase ,基于最新做改动。
    whyrookie
        28
    whyrookie  
       1 天前
    我一个人的项目,有时候可能有多个分支一同开发,通常先 rebase 再回到主分支进行 merge
    twelvechen
        29
    twelvechen  
       1 天前 via iPhone
    我们组的项目不允许使用普通 pull ,merge 必须使用 fast-forward ,也就是有冲突必须 rebase 。目前没遇到什么问题,体验良好。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2694 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 05:28 · PVG 13:28 · LAX 21:28 · JFK 00:28
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.