(二)Git在公司中团队内合作和跨团队合作和分支操作的全部流程(一篇就够)

(一)Git连接GitHub的全部流程https://blog.csdn.net/m0_65992672/article/details/132333727

团队内协作

项目经理通过git push将代码推送到远程仓库【也就是git、gitee等代码托管中心】,推完以后组员可以通过git clone克隆下来代码,如果组员修改了代码想要推到远程仓库的话,需要项目经理将组员添加到当前项目团队中,组员可以得到登录代码托管中心的密码和账号,此后就可以git push将代码推到远程仓库,当项目经理觉得你代码没有问题后就会将组员的代码git pull到自己的本地,然后推送到远程仓库【注意:组员修改代码都是在自己的分支上】

邀请合作伙伴加入团队

1)选择邀请合作者

2)填入想要合作的人

3 ) 复 制 地 址 并 通 过 微 信 钉 钉 等 方 式 发 送 给 该 用 户 , 复 制 内 容 如 下 :

https://github.com/atguiguyueyue/git-shTest/invitations

4 )在 atguigulinghuchong 这个账号中的地址栏复制收到邀请的链接,点击接受邀请。

5 )成功之后可以在 atguigulinghuchong 这个账号上看到 git-Test 的远程仓库。

然后就可以进行克隆进行修改,然后push到仓库中

克隆操作

远程库地址复制:

克隆操作:

idea中克隆

【注意:组员修改代码都是在自己的分支上】

分支操作

创建一个分支

master -> New Branch

填写分支名称,Create

创建分支成功后,会自动切换到创建的分支

可以看出GitHub上git仓库多了一个分支

通常情况下,一个项目可能有多个分支,由多个开发人员开发,每个开发者会创建自己的分支,然后将代码合入到主分支

下面我们就来看看,如何将代码合入主分支

第一步 拉取主分支最新代码

因为我们要合入代码到主分支master,所以先拉取master分支的最新代码,防止合入时产生冲突

选择master分支

拉完代码可能会有冲突,我们处理完冲突后,切换到master分支

Git合并分支逻辑

主分支中将分支的代码合入时不需要处理冲突了,因为之前在分支上拉取了主分支代码处理过冲突了,但是在多开发者的共同开发的情况下,这不是一定的,因为在我们将多位开发者的多份代码合入主分支时,如果此时有人提交了的代码和你提交的代码有交集,就有可能导致冲突发生,但这种情况下,概率比较低,一般来说,每个开发者负责的开发任务一般没有交集,即使别人提的代码,很少会影响到你提交的代码,但是如果有冲突,解决一下也可以

一般企业开发中会规定一个统一的合入代码时间,这样,合入代码时就可以专心解决合入中少量的冲突问题(有时甚至没有冲突),而不用关心,合入中途还有新代码的合入(一般也会限制开发者不能直接提代码到主分支,由某人统一合入开发者们申请合入的代码),也就是说合入代码前只拉取一次最新的主分支代码,然后合入各分支代码

下面为合并分支代码的具体步骤

master -> zj -> Merge 'zj' into 'master'

在主分支中将zj分支合并到master主分支中

在主分支合入完分支代码后,还需要将本地仓代码推送给GitHub,这样以后别人拉取主分支代码时,就是最新的代码了

注:在提交代码时,都要考虑下是否需要先拉取下最新代码,以防产生冲突

将分支推送到远程仓库

冲突合并

首先yka分支新增一条数据提交了

现在切换到master

master在同一位置新增一条数据并提交

现在在主分支中把yka分支合并到master分支中

就会出现合并合并冲突

特殊符号:<<<<<<< HEAD 当前分支的代码 ======= 合并过来的代码 >>>>>>> hot-fix

切换到yka分支中合并主分支

两个分支就一致了

将分支推送到远程仓库

跨团队协作

A团队先发送和团队一个远程仓库地址,B团队搜索这个地址进行fork操作到自己的仓库中【两个团队的代码通过fork互通】,B团队将A团队远程库的代码克隆下来到本地仓库,修改完成以后通过git push将修改后的代码推到自己B团队的远程库中,然后B团队发送一个Pull request请求给A团队【提示A团队拉取代码,但A团队需要审核这个代码】审核通过之后,A团队通过merge将B团队修改的代码合并到A团队的远程库,然后A团队就可以将新代码pull到自己的本地库中

不需要邀请别人加入自己的团队

将远程仓库的地址复制发给邀请跨团队协作的人,比如东方不败,张三李四

以下操作流程:张三把项目仓库地址发送给李四,李四先搜索地址在进行fork操作把张三的项目拿到自己的仓库中,李四在进行修改项目,修改完成后push到自己的仓库中,李四在进行pull request操作,争夺张三同意,同意之后李四改的数据才会提交到张三仓库中

【1】张三把远程库的地址发给李四:

项目的地址:

https://github.com/zhaoshanshan3366/GitResp2.git

【2】李四进行fork操作:

李四进入到账号后:复制地址:https://github.com/zhaoshanshan3366/GitResp2.git

然后点击下面的fork操作:

这样就等同于创建了一个自己的远程仓库。但是这个远程仓库等同于是一个分支远程仓库,你可以随便操作,并不会影响源仓库,但是如果你的修改,更新想要融合到源仓库中,就需要提交申请了。


fork完之后就把张三的项目复制到李四的仓库中了


【3】然后李四就可以克隆到本地,并且进行修改,修改完成后push到自己仓库中:

克隆操作

远程库地址复制:

克隆操作:

idea中克隆

也可以进行上面团队内合作的分支操作

分支操作

【4】李四修改完内容进行pull request操作,给张三发送请求,争夺张三同意,同意之后李四改的数据才会提交到张三仓库中:



【5】张三进行审核操作,同意之后李四改的数据才会提交到张三仓库中:

可以互相留言:

查看具体提交的内容:

确定通过以后,可以进行合并,李四修改的内容就与张三合并了

相关推荐
墨理学AI1 小时前
GitHub 桌面版配置 |可视化界面进行上传到远程仓库 | gitLab 配置【把密码存在本地服务器】
gitlab·github·github 桌面版
刘大辉在路上3 小时前
突发!!!GitLab停止为中国大陆、港澳地区提供服务,60天内需迁移账号否则将被删除
git·后端·gitlab·版本管理·源代码管理
AI理性派思考者8 小时前
【保姆教程】手把手教你在Linux系统搭建早期alpha项目cysic的验证者&证明者
后端·github·gpu
wy02_12 小时前
Linux下载RabbitMQ,并解决Github拒绝访问443的问题
linux·rabbitmq·github
落落鱼201312 小时前
cenos如何升级git到2以上版本
git
Domain-zhuo13 小时前
Git常用命令
前端·git·gitee·github·gitea·gitcode
aPurpleBerry13 小时前
解决 fatal: detected dubious ownership in repository at ‘XXXX‘ 问题
github
sin220113 小时前
git自己模拟多人协作
git
vvw&16 小时前
如何在 Ubuntu 22.04 上安装 Graylog 开源日志管理平台
linux·运维·服务器·ubuntu·开源·github·graylog
HelloGitHub18 小时前
跟着 8.6k Star 的开源数据库,搞 RAG!
开源·github