git合作开发流程

2023-10-12 07:50
文章标签 流程 git 合作开发

本文主要是介绍git合作开发流程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、创建项目与管理

创建项目和管理项目都是管理账号需要做的事情,如果只是合作开发不进行管理,只需要浏览第二部分的内容即可。

1.创建项目

登录代码托管网站,点击添加项目,如下图所示:


填写相应的项目信息,如下图所示:


完成会生成项目的url,复制url后面会使用到,使用指令时需要注意每个项目的都不一样,如下图所示:


在本地创建项目文件,并创建项目说明文件“README.md”,如下图所示:


打开git执行如下命令操作
初始化git bash客户端,进入创建的项目文件夹执行如下命令(也可以想项目文件夹中右键打开,省去cd命令)

git init

把文件添加到缓冲区,并添加注释信息

git add README.md
git commit -m "first commit"

注:在 Linux 系统中,commit 信息使用单引号 ',Windows 系统,commit 信息使用双引号 "
推送创建的仓库,其中url是之前复制的

git remote add origin url
git push -u origin master

执行以上命令操作后,项目便创建成功了,如下图所示:

2.添加协作者

点击仓库设置,添加协作者,及协作者的操作权限,如下图所示:


这样简单的git项目就创建完成了。能访问到项目的协作者便可以开始项目的编写了。

3.合并请求管理

当有人发起合并请求时,会有相应的信息提醒,可以查看具体的请求说明,如下图所示:


查看明细后,如果觉得没问题后,点击合并请求即可完成代码的合并。如下图所示:


合并完成后,协作人员只需要拉取一下主分支的代码即更新本次更改的内容。

二、git仓库使用

1.派生主分支

登录协作者的账号即可使用相应的项目,如下图所示:


选择自己需要的项目并单击进入,此时便可以看到克隆的url,合作中不建议直接克隆主分支的项目,需要派生自己的分支,如下图所示:


派生完成后会发现项目的路径与主分支的不同,复制个人派生的url,如下图所示:

2.配置远程仓库

打开git bash 使用git clone url命令克隆分支仓库,其中url是个人派生出来的url

git clone url

添加远程仓库fork的上游主库,其中rul是主分支的url

git remote add upstream url

查看仓库的设置地址

git remote -v

能看到origin和upstream的地址,则说明配置成功,如图所示:


到此仓库配置已经完成,接下来便可以进行开发了。

2.更新本地仓库

每次编写代码时,记得同步远程仓库到本地资源库,保证本地仓库和远程仓库的代码一直性

git pull upstream master
git pull origin master

注意:其中origin是更新个人分支到本地仓库,upstream是更新主分支到本地资源库,因为个人分支的代码多数只能自己更改,一般情况下个人分支的代码和本地基本一致所以更新origin的频率会少一些。主要是主分支由于协作的人较多,代码变动很大。

3.提交代码

提交代码之前记得再次同步主分支的代码,也就是说执行以下步骤是记得使用git pull upstream master,这样能保证在合并时避免和主分支的代码产生冲突。
添加所有更新至本地缓存

git add .

查看缓存区状态

git status	

提交到说明,便于版本管理

git commit -m "提交说明"

提交到远程个人仓库(个人仓库名+分支名)

git push origin master

这样已经完成代码的提交,提交完成后还需要将自己分支的代码合并到主分支。

4.代码合并

去远程管理仓库进入到个人分支,点击创建合并请求,如下图所示:


选择需要合并到的分支以及拉去代码的位置,如下图所示:


完成后点击创建合并请求并填写合并请求的说明已经更改代码的功能,便于管理员对代码进行管理。如
下图所示:


到此个人开发的流程已经完成了,最后只需要理员同意合并请求便可以在主分支看到个人更改的代码。

https://zhidao.baidu.com/question/335497018719976165.html
https://itbbs.pconline.com.cn/soft/54647674.html
https://blog.csdn.net/yunkeyi/article/details/118723957
https://xueqiu.com/4824316523/190386793
https://tieba.baidu.com/p/7447939785
https://weibo.com/ttarticle/p/show?id=2309404658896513138937
https://www.meipian.cn/3pi3y1en?share_depth=1
https://www.acfun.cn/a/ac30256273
https://www.im286.net/thread-24269515-1.html
https://blog.51cto.com/weixincrm/3087358
https://blog.csdn.net/yunkeyi/article/details/118729971
https://xueqiu.com/4824316523/190428524
https://zhuanlan.zhihu.com/p/389655713
http://www.360doc.com/content/21/0714/16/74567251_986534984.shtml

https://itbbs.pconline.com.cn/soft/54648088.html
https://www.acfun.cn/a/ac30269473
https://blog.51cto.com/weixincrm/3102416
https://www.im286.net/thread-24269672-1.html
https://blog.csdn.net/yunkeyi/article/details/118761960
https://xueqiu.com/4824316523/190428524
https://www.meipian.cn/3pk1u0a3?share_depth=1
https://zhuanlan.zhihu.com/p/390000872
https://tieba.baidu.com/p/7449752459
https://weibo.com/ttarticle/p/show?id=2309404659261006282919
 

三、git其他指令

1.强制拉取覆盖

强制拉取个人分支,并覆盖本地仓库,主要用于自己删除本地文件后无法通过更新下载已删除的文件时使用,当然可以回滚至上一版本。

git fetch --all
git reset --hard origin/master
git pull

2.本地指令

git config --list									#查看配置信息
git init											#初始化仓库
git add 1.txt										#添加文件至缓存
git add .											#添加所有文件至缓存
git rm 1.txt										#删除文件
git status											#查看仓库状态
git commit –m "test"								#提交说明
git rm 1.txt										#删除文件
git commit -m “test”								#删除相应的提交	
git diff a.txt										#查看a.txt文件更改的内容
git log												#查看提交记录
git reset --hard HEAD^								#回滚上一个版本
git reset --hard HEAD~n								#回滚n个版本
git xxx --help										#查看指令帮助

3.本地仓库上传至远程仓库

git pull origin master								#拉取远程主分支
git pull --rebase origin master						#拉取本地分支
git push -u origin master							#提交代码至个人分支
git push -u -f origin master						#强制上传代码至个人分支

4.远程仓库指令

git clone url										#克隆仓库
git remote add										#添加/关联一个远程仓库,默认名是origin
git remote remove origin							#删除远程库的 origin 别名
git remote add upstream url							#添加一个将被同步给fork远程的上游仓库
git fetch upstream									#从上游仓库fetch分支和提交点,传送到本地,并会被存储在一个本地分支 upstream/master
git remote											#查看远程库的别名
git remote –v										#查看远程库的别名和仓库地址
git push origin master								#把本地 master 分支推送到别名为 origin 的远程库
git branch											#查看当前所有的分支,默认只有master 分支
git branch test										#创建 test 分支
git branch –d test									#删除 test 分支
git checkout test									#从当前分支切换到 test 分支
git checkout –b dev									#创建 dev 分支,并切换到 dev 分支上
git merge dev										#在当前分支上合并 dev 分支
git merge upstream/master							#把 upstream/master 分支合并到本地 master 上
git merge upstream/dev								#把 upstream/dev 分支合并到本地 dev 上

注:由于本次的文档是在本地编写的,后来图片不小心被我删除了,所以我在PDF文档中截屏的,导致图片有点模糊,希望小伙伴们不要建议。

这篇关于git合作开发流程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/194397

相关文章

IDEA中新建/切换Git分支的实现步骤

《IDEA中新建/切换Git分支的实现步骤》本文主要介绍了IDEA中新建/切换Git分支的实现步骤,通过菜单创建新分支并选择是否切换,创建后在Git详情或右键Checkout中切换分支,感兴趣的可以了... 前提:项目已被Git托管1、点击上方栏Git->NewBrancjsh...2、输入新的分支的

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

git stash命令基本用法详解

《gitstash命令基本用法详解》gitstash是Git中一个非常有用的命令,它可以临时保存当前工作区的修改,让你可以切换到其他分支或者处理其他任务,而不需要提交这些还未完成的修改,这篇文章主要... 目录一、基本用法1. 保存当前修改(包括暂存区和工作区的内容)2. 查看保存了哪些 stash3. 恢

spring-gateway filters添加自定义过滤器实现流程分析(可插拔)

《spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔)》:本文主要介绍spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔),本文通过实例图... 目录需求背景需求拆解设计流程及作用域逻辑处理代码逻辑需求背景公司要求,通过公司网络代理访问的请求需要做请

使用JavaConfig配置Spring的流程步骤

《使用JavaConfig配置Spring的流程步骤》JavaConfig是Spring框架提供的一种基于Java的配置方式,它通过使用@Configuration注解标记的类来替代传统的XML配置文... 目录一、什么是 JavaConfig?1. 核心注解2. 与 XML 配置的对比二、JavaConf

IDEA实现回退提交的git代码(四种常见场景)

《IDEA实现回退提交的git代码(四种常见场景)》:本文主要介绍IDEA实现回退提交的git代码(四种常见场景),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.已提交commit,还未push到远端(Undo Commit)2.已提交commit并push到