news 2026/5/30 17:41:04

Git - 多人协作流程

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Git - 多人协作流程

目录

多人协作流程

分支推送协作

分支拉取协作

删除远程分支


多人协作流程

1.开发者A:在远程仓库中有一个testgit1仓库,点击管理 -> 左侧仓库成员管理 -> 申请列表 -> 邀请用户,将连接复制,发送给邀请的用户。

2.开发者B:接受邀约后,可在仓库中看到开发者A的仓库。

3.开发者A:

  • 点击管理 -> 左侧仓库成员管理中查看到仓库中的其他成员,并赋予身份(例如:管理者、开发者、测试者等),不同的身份有不同的管理权限。
  • 拉取远程仓库到本地仓库,使两个仓库内容基本一致。
  • 起项目框架,写内容,经本地仓库推送到远程仓库中。

4.开发者B:

  • 开发者B不能在testgit1仓库本仓库中进行操作(重点),如果在这个仓库中操作,就使修改了开发者A的库;
  • 点击Fork,选中自己,点击确定
  • 点击头像 -> 个人主页 -> 仓库,会发现变成了两个库,一个是开发者A的库(开发者A/testgit1),一个是开发者B的库(开发者B/testgit1),应该在生成的开发者B的这个库中操作。
  • 将这个库克隆下来,然后进行添加用户、邮箱,和远程仓库连接,写代码文件。
  • vi B.txt,然后提交,并推送到远程仓库(若有冲突,将远程仓库拉取到本地仓库,并解决冲突)。
  • 要同步给开发者A,在唱K中,选中Pull Requests -> 新建Pull Request

5.开发者A:

  • 开发者A在 【开发者A/testgit1】 这个库中,并不能看到开发者B提交的内容。
  • Pull Requests会接收到请求 -> 点进去,进行审核 -> 没问题,点击审核通过,测试通过
  • 点击合并分支,然后点击Pull RequestPull Request
  • 此时,就能看到开发者B添加的内容

6.开发者C:

  • 与开发者B一样进入开发者A的仓库后,点击Fork,生成一个自己的库(开发者C/testgit1)
  • 进入【开发者C/testgit1】仓库,点击仓库后的刷新,刚刚开发者A操作合并开发者B的内容,这里会显示。

到处,多人协同操作流程完毕。


分支推送协作

在testgit1仓库上操作:

1. 创建dev分支

// 创建分支并切换到分支 git checkout -b dev

2. 推送分支

  • git push无法把分支dev推送到远程仓库
  • 方法一:使用下面的命令推送分支
    • // 方法一 git push --set-upstream origin dev
    • 同时本地也关联了远程分支dev
    • git branch -av
  • 方法二:使用带 -u 参数的命令
    • // 方法二 git push -u origin dev

分支拉取协作

在testgit01仓库上操作:

  • 发现有远程分支,但是没有本地的dev分支

  • 这时可以创建本地的dev分支,此刻也可以修改本地分支的名字

  • 创建分支并且切换到dev分支上,而且该分支和远程分支dev关联

  • 方法一:使用 -b 参数

    • // git checkout -b 本地分支名 远程仓库名/远程分支名 git checkout -b dev origin/dev
  • 方式二:使用 --track 参数

    • // git checkout --track 远程仓库名/远程分支名 git checkout --track origin/dev2

删除远程分支

在testgit01仓库上操作:

1. 删除本地仓库分支dev2

  • 删除之后,会发现远程的分支dev2关联还在
  • git branch -d dev2

2. 删除远程分支关联

  • git push origin --delete dev2

在testgit1仓库上操作:

3. 通过另一个用户来查看本地对应的远程分支的时候可以看到远程分支的变化

  • git remote show origin

4. 查看origin远程对于的分支

  • git remote prune origin
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/29 17:07:31

springboot图书个性化推荐系统(11482)

有需要的同学,源代码和配套文档领取,加文章最下方的名片哦 一、项目演示 项目演示视频 二、资料介绍 完整源代码(前后端源代码SQL脚本)配套文档(LWPPT开题报告)远程调试控屏包运行 三、技术介绍 Java…

作者头像 李华
网站建设 2026/5/29 6:56:04

springboot网页时装购物系统(11483)

有需要的同学,源代码和配套文档领取,加文章最下方的名片哦 一、项目演示 项目演示视频 二、资料介绍 完整源代码(前后端源代码SQL脚本)配套文档(LWPPT开题报告)远程调试控屏包运行 三、技术介绍 Java…

作者头像 李华
网站建设 2026/5/22 18:20:12

定时刷新已经登录过的网页c#

1、日常工作中,登录内部系统往往需要输入用户名、密码、短信验证码,但是如果30分钟不操作,会自动退出,为避免频繁登录,可以使用c#写一个自动刷新指定网址页面的程序。找来找去,这个最好用 using System; us…

作者头像 李华
网站建设 2026/5/22 1:40:41

Kafka 消息不丢失全攻略:从生产到消费的全链路保障

Kafka 消息不丢失全攻略:从生产到消费的全链路保障 引言 Kafka 以其高吞吐和可靠性在分布式消息系统中广泛应用,但很多人以为 Kafka 默认就能“绝对不丢消息”。事实上,Kafka 的设计目标是高性能 + 可配置的可靠性,要做到真正的“不丢失”,需要从 生产者、Broker、消费者…

作者头像 李华
网站建设 2026/5/28 18:57:41

多线程循环打印123(个人题解golang版)

刷面筋看到这么一道手搓题,看网上题解大部分都是java的,就以我的理解用go实现了(ai好笨啊,也可能是我不会用,问的全是错的最后还得自己手搓),纯古法手搓版:var num atomic.Int64 // …

作者头像 李华