近期在使用gitLab管理项目,在使用过程中遇到一些问题,在此整理一下。

git的基本配置在这里就不累赘了,主要讲一下如何将项目托管到gitLab ,并实现多人协作开发。尤其介绍一下如何解决冲突,合并分支。

1、将代码上传至gitLab

  1. 首先在gitLab 上创建一个仓库,在本地代码目录下,执行git init使之成为一个git仓库。也可能本身就已经是一个git仓库了。
  2. 使用git remote -v查看当前仓库绑定的远程仓库。(-v参数可以查看远程主机的网址)

$ git remote -v
origin  git@github.com:jquery/jquery.git (fetch)
origin  git@github.com:jquery/jquery.git (push)

上面的命令表明,当前只有一台远程主机,叫做origin,以及它的网址。
3. git remote add 主机名 网址用于添加远程主机

git remote add origin git@192.168.1.11:ygc/190319test.git
ygc@ygc:~/190319Test$ git remote -v
origin  git@192.168.1.11:ygc/190319test.git (fetch)
origin  git@192.168.1.11:ygc/190319test.git (push)
  1. git remote rm 主机名用于删除指定主机名的远程主机,(主机名一般默认为origin)
git remote rm origin
  1. git remote rename修改远程主机名
git remote rename  <原主机名>   <新主机名>
  1. 接下来就是git add .git commit -m "说明文字"
  2. 最后推送到远程主机git push <远程主机名> <本地分支名> :<远程分支名>

如果省略远程分支名,则表示将本地分支推送与之存在"追踪关系"的远程分支(通常两者同名),如果该远程分支不存在,则会被新建。

git push origin master

上面命令表示,将本地的master分支推送到origin主机master分支。如果后者不存在,则会被新建。

2、创建分支,用于多人开发

现在仓库中只有一个主分支master。为了多人协作开发,需要在gitLab上设置添加members。一般只有管理者是Maintainer权限。参与者一般Developer 权限。

主分支master是protected权限,Developer权限的参与者无法对其修改。这也保护了master主分支,一般参与者不能修改master主分支。

解决办法是再创建一个分支(在这里我定义分支名为dev),所有参与者共用这一个分支dev,所有的修改都在这个分支dev上,在确保无误的前提下,由管理员在gitLab上合并到主分支master上。

通过建立一个分支dev的方式开发能保证代码的稳定性,master主分支只有管理员有权限修改,所有参与者开发dev分支,当测试确定dev分支准确无误后,由管理员不定期将dev合并到master主分支上。

具体实现:

  1. 由管理员(也不一定是管理员,只要有一个人创建,大家共同使用)创建dev分支
ygc@ygc:~/onos$ git checkout -b dev
Switched to a new branch 'dev'
ygc@ygc:~/onos$ git branch
* devmaster

上面代码的意思是通过git checkout -b dev创建一个新的dev,并且将当前分支指向dev。git branch查看所有分支,当前分支标有*号
2. 通过git push origin dev将分支dev推送到远程主机

ygc@ygc:~/onos$ git checkout -b dev
Switched to a new branch 'dev'
ygc@ygc:~/onos$ git branch
* devmaster
ygc@ygc:~/onos$ git push origin dev
Total 0 (delta 0), reused 0 (delta 0)
remote:
remote: To create a merge request for dev, visit:
remote:   http://59d1500fe2bd/sangfor/onos/merge_requests/new?merge_request%5Bsource_branch%5D=dev
remote:
To git@192.168.1.11:sangfor/onos.git* [new branch]      dev -> dev
ygc@ygc:~/onos$ 

此时远程主机上也存在两个分支了

3. 当其他参与者参与开发时,他需要从远程库clone,默认情况下,他只能看到本地的master分支。

ygc@ygc:~/190319Test/test77$ git clone git@192.168.1.11:sangfor/onos.git
Cloning into 'onos'...
remote: Enumerating objects: 17295, done.
remote: Counting objects: 100% (17295/17295), done.
remote: Compressing objects: 100% (7853/7853), done.
remote: Total 17295 (delta 6372), reused 17295 (delta 6372)
Receiving objects: 100% (17295/17295), 33.69 MiB | 10.13 MiB/s, done.
Resolving deltas: 100% (6372/6372), done.
Checking connectivity... done.
ygc@ygc:~/190319Test/test77$ cd onos
ygc@ygc:~/190319Test/test77/onos$ git branch
* master
  1. 现在,他要在dev分支上开发(即使他在master主分支上开发,他也没有权限推送到远程库中),就必须创建远程origin的dev分支到本地:
ygc@ygc:~/190319Test/test77/onos$ git checkout -b dev origin/dev
Branch dev set up to track remote branch dev from origin.
Switched to a new branch 'dev'
ygc@ygc:~/190319Test/test77/onos$ git branch
* devmaster
  1. 现在,他就可以在dev上继续修改,然后时不时地把dev分支push到远程
git add .
git commit -m "tag"git push origin dev

3、获取最新代码到本地,并自动合并到当前分支,推送到远程库

有一些文章说git pull不好,建议使用git fetch和git merge,可以考虑使用这两个命令替代git pull

当一个参与者在本地开发期间,远程库如果被被的开发着push过,这当这个参与者执行git push origin dev时可能会出现:

$ git push origin dev
To github.com:michaelliao/learngit.git! [rejected]        dev -> dev (non-fast-forward)
error: failed to push some refs to 'git@github.com:michaelliao/learngit.git'
hint: Updates were rejected because the tip of your current branch is behind
hint: its remote counterpart. Integrate the remote changes (e.g.
hint: 'git pull ...') before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.

从上面代码可以看出,Git 已经提示我们,先用git pull把最新的提交从origin/dev上抓下来,然后,在本地合并,解决冲突,再推送:

$ git pull
There is no tracking information for the current branch.
Please specify which branch you want to merge with.
See git-pull(1) for details.git pull <remote> <branch>If you wish to set tracking information for this branch you can do so with:git branch --set-upstream-to=origin/<branch> dev

git pull也失败了,原因是没有指定本地dev分支与远程origin/dev分支的链接,根据提示,设置dev和origin/dev的链接:

$ git branch --set-upstream-to=origin/dev dev
Branch 'dev' set up to track remote branch 'dev' from 'origin'.

然后在git pull

$ git pull
Auto-merging env.txt
CONFLICT (add/add): Merge conflict in env.txt
Automatic merge failed; fix conflicts and then commit the result.

这回git pull成功,但是合并有冲突(如果没有冲突,就可以执行下一步了),需要手动解决(找到冲突的地方,确定最终版本)。

解决完冲突后,再次git add.git commit -m "提示语"git push origin dev

4、解决冲突

产生冲突的原因是当你在本地开发过程中,其他开发者向远程库有了新的提交。当你把最新的远程库拉到本地后,会对比现在的远程库的版本与你最后一次从远程看拉下来的版本。

5、将dev合并到master上

这个过程是在gitLab 上进行,不再细说。

使用git在项目中的一些经验相关推荐

  1. git在项目中的实际运用

    项目中只运用git版本管理的情况下: 1.创建分支命令: git branch (branchname) 切换分支命令: git checkout (branchname) 当你切换分支的时候,Git ...

  2. 项目中的技巧经验汇总

    1. 若将一个view作为子视图添加到window中,则当设备的方向变换时,该视图不会随之变化,也就是所不会响应设备的方向变化事件. 如:"图片放大视图","报纸选择视图 ...

  3. git在项目中常用命令和项目流程中涉及到步骤分析

    GIT git的组成:分布式,版本控制,软件 svn是集中式版本控制,而git是分布式版本控制 问价拷贝 本地版本控制 集中式版本控制 分布式版本控制 第一阶段:生成版本,扩展功能,版本回滚 命令: ...

  4. Git在项目中40个常用命令详解

    前言 git对于大家应该都不太陌生,熟练使用git已经成为程序员的一项基本技能,尽管在工作中有诸如 Sourcetree这样牛X的客户端工具,使得合并代码变的很方便.但找工作面试和一些需彰显个人实力的 ...

  5. git在项目中忽略包node_modules依赖包和git 指令常用汇总

    1.在项目拉起依赖包时提交git时, 通过在项目根目录中创建文件.gitignoe 并在文件中添加忽略的文件名如: node_modules node_modules/ # 下面自己配置使用的 忽略文 ...

  6. Git忽略项目中的指定的文件

    使用IDE开发具体的java总会随着编译产生一些临时文件,比如:*.class.iml(使用idea产生的配置文件)..DS_Store(mac系统的).target文件夹,使用git status命 ...

  7. 【随手记录】git 克隆项目中时出现fatal: unable to access ‘https://github 类错误

    问题描述:当使用git clone 克隆项目时遇到问题:fatal: unable to access 'https://github.com/XXX': Failed to connect to X ...

  8. 项目管理手记(四) DRP项目中软件系统架构的比较

    项目管理手记(四) DRP项目中软件系统架构的比较                                                                   Drate(at ...

  9. 项目中使用粘性布局不起作用_项目中的 Git 使用规范

    祖师爷 Linus 在创造了伟大的 Linux 之后,又创造了应用最广泛的代码管理工具 -- Git,极大地提高了程序员的生产力. 现如今大部分项目都在使用 Git 作为代码管理工具,不论是在代码管理 ...

最新文章

  1. PingCode Wiki 多人实时协同编辑功能发布
  2. Qt rviz 机器人
  3. 爬虫python需要什么软件-python的爬虫流程是什么?这是编程小白必须要了解的
  4. 再谈新浪微博架构——视频观后笔记
  5. win7 php mysql扩展名_win7下MySQL 5.1.73安装过程(图解)并在php.ini中启用相关扩展。...
  6. 设计模式:结构型模式总结
  7. boost::stable_sort相关的测试程序
  8. lgg6 android 9,LG G6的18:9屏幕用起来到底是什么样
  9. matlab用解析法求二自由度阻尼系统的自由振动(先求系统状态方程
  10. 数据可视化的图表实现
  11. growup怎么读_growup..是什么意思
  12. Web项目部署到阿里云
  13. NRF24L01无线通信模块使用示例和调试心得总结
  14. 继电保护整定值计算软件_电力系统继电保护整定计算与应用实例
  15. 视频I帧/P帧/B帧
  16. The first GAN——Generative Adversarial Nets
  17. 发送广播失败 Parcelable encountered IOException writing serializable object (name =xxxx).
  18. sort-选择排序法
  19. URL传参小用法获取url中的参数
  20. C++结课大作业——职工管理系统

热门文章

  1. Java:判断外面天气,如果下雨,男性带黑色雨伞,女性带红色雨伞;如果晴天,如果高于温度30度,男性戴墨镜,女性涂防晒霜(控制选择结构if、if else语句及其嵌套结构)
  2. SICK激光扫描仪(LD-LRS3601与LMS511)使用小结
  3. hdu 4262 Juggler 这题真是跟小丑一般。。。
  4. VS2015程序工程的ICO图标研究
  5. MP4学习(五)ts-mp4源码阅读(3)ftyp box的解析
  6. linux 自己做桌面,自己动手量身定做Linux系统的桌面
  7. mysql_check_MySQL中check的用法
  8. 使用python爬取全国所有热门景点数据---去哪儿网
  9. 《青山翠影》叁 爱情的模样 | 似懂非懂
  10. 中国人民大学于坤教授:以社会支持体系提升就业力 | 牛客大咖说