git工作流程总结

版权声明:本文为博主原创文章,如有问题,请不吝指出,转载注明出处: https://blog.csdn.net/c851204293/article/details/82431847

git工作流程总结

1.1初始化源仓库
创建project之后会有如下基本操作提示,根据需要初始化源仓库代码:

# Command line instructions 命令行指令
# Git global setup git全局设置
$ git config --global user.name “your name”
$ git config --global user.email “your email”

# Create a new repository 创建新仓库
$ git clone [url]
$ cd [dir]
$ touch README.md
$ git add README.md
$ git commit -m "add README"
$ git push -u origin master

# Existing folder 现有文件夹
$ cd [existing_folder]
$ git init
$ git remote add origin [url]
$ git add .
$ git commit
$ git push -u origin master

# Existing Git repository 现有git仓库
$ cd [existing_repo]
$ git remote add origin [url]
$ git push -u origin –all
$ git push -u origin --tags

初始化都会在远程仓库创建master分支,之后再基于master添加develop分支,这两条分支作为这个项目的常驻分支。

1.2git push & git pull 推送/拉取分支

git push与git pull是一对推送/拉取分支的git命令。
git push 使用本地的对应分支来更新对应的远程分支。

$ git push <远程主机名> <本地分支名>:<远程分支名>

注意: 命令中的本地分支是指将要被推送到远端的分支,而远程分支是指推送的目标分支,即将本地分支合并到远程分支。
如果省略远程分支名,则表示将本地分支推送与之存在”追踪关系”的远程分支(通常两者同名),如果该远程分支不存在,则会被新建。
如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支,这条命令是删除远程master分支。

$ git push origin :master
# 等同于
$ git push origin --delete master

上面命令表示删除origin主机的master分支。
如果当前分支与远程分支之间存在追踪关系(即分支名相同),则本地分支和远程分支都可以省略。

$ git push origin

上面命令表示,将当前分支推送到origin主机的对应分支。

最后,git push不会推送标签(tag),除非使用–tags选项。

$ git push origin --tags

git pull 获取并合并其他的厂库,或者本地的其他分支。
git pull 与 git push操作的目的相同,但是操作的目标相反。命令格式如下:

git pull <远程主机> <远程分支>:<本地分支>

如果省略本地分支,则将自动合并到当前所在分支上。如下:

git pull origin master

1.3功能开发
在本地对应功能分支上,新功能开发期间涉及到的基本操作:

# 切换分支
$ git checkout <分支名>
# 查看当前工作状态,比如变更的文件
$ git status
# 添加当前工作新增文件
$ git add <需要添加的文件>
# 提交代码到远程仓库
$ git commit –m “本次提交说明信息” <需要提交的文件>
# 将本次commit内容推到远程仓库功能分支
$ git push origin 本地分支名:远程分支名

1.4拉取远程仓库代码
本地操作拉取远程仓库代码,同步develop分支:

# 克隆远程仓库代码
$ git clone + <远程仓库地址----ssh或http>
$ git clone [email protected]:demo/mvcdemo.git

在这里插入图片描述
Clone之后会在本地克隆一个远程仓库的项目,默认初始分支master;

接下来,在本地新建个develop分支,并同步远程仓库develop分支代码:

# 新建本地develop分支
$ git checkout –b develop
# 同步远程develop分支
$ git pull origin develop:develop

在这里插入图片描述

1.5多人协作推送冲突解决

  1. 首先,可以试图用git push origin <branch-name>推送自己的修改;
  2. 如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并;
  3. 如果合并有冲突,则解决冲突,并在本地提交;
  4. 没有冲突或者解决掉冲突后,再用git push origin <branch-name>推送就能成功!

注:如果git pull提示no tracking information,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream-to <branch-name> origin/<branch-name>

1.6总结

  1. 在master中add commit push .gitignore;
  2. 在master上新建develop分支,并跳转到develop分支;在master上新建develop分支,并跳转到develop分支;
  3. 在develop分支上搭建项目框架,add commit push 项目框架;在develop分支上搭建项目框架,add commit push 项目框架;
  4. 在develop上新建feature-cgh分支;在develop上新建feature-cgh分支;
  5. 在feature-cgh分支上作业,add commit 更改的内容;在feature-cgh分支上作业,add commit 更改的内容;
  6. 将feature-cgh分支合并到develop上去,并推送至远程develop上;将feature-cgh分支合并到develop上去,并推送至远程develop上;
  7. 将本地develop分支合并至master上,并推送至远程develop上。将本地develop分支合并至master上,并推送至远程develop上。

猜你喜欢

转载自blog.csdn.net/c851204293/article/details/82431847