Git & GitLab 使用及规范

http://www.myexception.cn/software/1891171.html ;

www.MyException.Cn  网友分享于:2015-04-19

Git安装配置及基本使用

  1. 从官网下载安装包,手动完成安装。
  2. 打开Git Bash命令行工具,执行命令ssh-keygen -t rsa -C Email-Addresss生成一个密钥对。
  3. 登录到GitLab,点击右上角你的用户头像,点击Edit Profile settings,点击SSH Keys,点击Add SSH Key,填写Title栏,复制用户目录下.ssh/id_rsa.pub文件的内容到Key,点击Add Key
  4. 点击右上角的New project,填写完成后点击Create project新建一个仓库,点击Activity,点击SSH后复制SSH边上栏里的地址。
  5. 打开Git Bash命令行工具,切换到一个合适的目录,使用命令git clone 刚才复制的URL克隆创建的仓库。
  6. 进入目录cd 仓库名,执行命令git config --global user.email your-email
    git config --global user.name your-name,设置你的个人信息。
  7. 执行命令:
    echo "#Description" > README.md,添加一个文件
    git status,查看当前状态,发现有未跟踪文件
    git add .,当前目录所有文件添加到暂存区
    git diff,比较当前工作区和暂存区有何不同
    git status,查看当前状态,发现有文件未提交
    git commit -m "注释",把暂存区内容提交到本地仓库
    git push -u origin master,把本地仓库的提交推送到远程仓库
    git log,查看提交日志

Git本地分支管理

  1. 分支的创建、合并、删除
    git branch,显示所有分支
    git branch b1,从当前分支创建一个叫b1的分支
    git checkout b1,切换到b1分支
    git checkout -b b1,相当于以上两条命令的组合
    git checkout master,切换到master主分支
    git merge b1,把b1分支的代码合并到master上
    git branch -d b1,删除b1分支,不能在被删除分支上执行

Git Tag标签管理

  1. 标签的创建、删除
    git tag t1,从当前分支创建一个名为t1的标签
    git tag -d t1,删除名为t1的标签

GitLib权限管理

GitLib有五种身份权限,分别是:

  • Owner 项目所有者,拥有所有的操作权限
  • Master 项目的管理者,除更改、删除项目元信息外其它操作均可
  • Developer 项目的开发人员,做一些开发工作,对受保护内容无权限
  • Reporter 项目的报告者,只有项目的读权限,可以创建代码片断
  • Guest 项目的游客,只能提交问题和评论内容

具体参见GitLab权限,为项目添加成员时可指定成员的身份权限。


命名规则

  • 每次提交必须写明注释,如果是修复Bug,请加上Bug号
  • 创建特性分支,名称要以f-开头,加上特性名
  • 创建发布分支,名称要以r-开头,加上预发布版本号
  • 创建Bug修复分支,名称要以b-开头,加上Bug号
  • 创建标签,名称要以t-开头,加上发布版本号
  • 合并分支时必须使用--no-ff参数,以保留合并历史轨迹

分支模型

整体流程图:


主要分支(保护分支)

  • master 主分支,稳定代码,为生产环境做准备的
  • develop 开发分支,为开发服务
    分支关系类似下图:

辅助分支


特性分支

从develop分支创建,用于特性开发,完成后要合并回develop分支。
操作过程:
git checkout -b newfeature develop,从develop分支创建newfeature特性分支
git checkout develop,开发完成后,需要合并回develop分支,先切换到develop分支
git merge --no-ff newfeature,合并回develop分支,必须加--no-ff参数
git branch -d newfeature,删除特性分支
git push origin develop,把合并后的develop分支推送到远程仓库
分支关系类似下图:


发布分支

从develop分支创建,用于预发布版本,允许小bug修复,完成后要合并回develop和master。
操作过程:
git checkou -b release-1.2 develop,创建一个发布分支
git checkout master,切换到master分支,准备合并
git merge --no-ff release-1.2,把release-1.2分支合并到master分支
git tag 1.2,从master分支打一个标签
git checkou develop,切换到develop分支,准备合并
git merge --no-ff release-1.2,把release-1.2分支合并到develop分支
git branch -d release-1.2,删除这个发布分支


修复分支

从master分支创建,用于生产环境上的Bug修复,完成后要合并回develop和master。
操作过程:
git checkout -b hotfix-1.2.1 master,从master分支创建一个Bug修复分支
git checkout master,切换到master分支,准备合并
git merge --no-ff hotfix-1.2.1,合并到master分支
git tag 1.2.1,为master分支创建一个标签
git checkout develop,切换到develop分支,准备合并
git merge --no-ff hotfix-1.2.1,合并到develop分支
git branch -d hotfix-1.2.1,删除hotfix-1.2.1分支
分支关系类似下图:


Git协同模型


SVN式集中协同模型

适用于小型项目,参与人员较少的项目,每个开发者均可向仓库推送代码


金字塔模型

适用于大型项目,参与人员较多,并且等级划分严明,代码需要逐级审核的项目
仅核心开发人员可以向仓库推送代码,开发人员只能从仓库拉取代码,开发人员的代码需先推送给核心开发人员审核通过后,合并之后才能推送,一般情况下是使用 GitHubPull Request的方式

Git GitLab 使用及规范相关推荐

  1. git 提交_GIT提交规范的使用和总结

    Why 在接手新项目时候 你希望看到git的commit记录是这样的? 还是这样的?? WTF!? 听说鱼的记忆只有7秒钟, 但是我看人的记忆也不怎么样,反正我能记清楚之前写的代码细节,最多只有7天 ...

  2. Git 语法、使用规范及常见bug总结

    分享一下个人总结的git语法.使用规范以及碰到问题的debug(自己感觉能覆盖90%的内容). 觉得有用的话,帮忙点个赞吧_(手动加狗头) 史上最全Git 语法和规范总结 分支管理常见命令 Login ...

  3. git指令快捷 idea_IDEA+Git+Gitlab使用详细教程

    GitLab 安装踩坑 502错误码和访问卡顿解决办法 Gitlab对内存的要求高,我的服务器Centos 7+2核心+2G内存,频繁报502错误,访问也很卡.原因可能是可用内存太少. # free ...

  4. 末学者笔记--Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站

    Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站 一.Jinkens安装                                                ...

  5. Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署动态网站(二)--技术流ken

    项目前言 在上一篇博客<Jenkins+Git+Gitlab+Ansible实现持续化集成一键部署静态网站(一)--技术流ken>中已经详细讲解了如何使用这四个工具来持续集成自动化部署一个 ...

  6. 解决 git@gitlab.com: Permission denied (publickey,gssapi-with-mic,password)

    设备信息 系统:win10 git 版本:git version 2.33.1.windows.1 OpenSSH_8.8p1, OpenSSL 1.1.1l 24 Aug 2021 问题描述 按照常 ...

  7. 持续集成/持续部署(1)Git Gitlab

    DevOps简介 DevOps是一种理念 理念共同协作 指让开发测试运维更好的沟通和协作 自动化一切重复的工作 把时间节省下来交于人与人之间的沟通 只注重技术不注重成本不是devops所提倡的 git ...

  8. git@gitlab invalid privatekey

    ssh git代码报错 Caused by: org.eclipse.jgit.errors.TransportException: git@gitlab invalid privatekey 用ss ...

  9. Git问题:windows下git@gitlab.com: Permission denied (publickey)问题

    问题描述: git clone和git push的时候都出现了这个问题 git@gitlab.com: Permission denied (publickey) 于是就网上各种搜索解决方案,这个试那 ...

最新文章

  1. Android中应用百度地图API开发地图APP实例-显示百度地图
  2. 其实昨天去加班也没有干什么事情,就只有3个人
  3. 使用firefox遇到的问题
  4. C#调用vbs脚本实现Windows版Siri
  5. mysql数据库的设计
  6. 东方第一等幻象骑士团
  7. AJAX Toolkits -- DropShadow
  8. python pymysql实例_Python使用pymysql模块操作mysql增删改查实例分析
  9. UML建模之活动图介绍(Activity Diagram)
  10. 轻松搞定C语言中复杂的声明
  11. CorelDRAW哪个版本好用实用强x4/X8/2019/2020/2021
  12. 3个结点的树和有3个结点的二叉树的所有不同的形态
  13. python logging日志模块以及多进程日志
  14. java模拟京东登陆_模拟登陆京东并访问我的订单
  15. Flume自定义拦截器
  16. 【Windows】Windows装机软件
  17. Java设计模式:Build模式
  18. 142 推荐系统架构(淘宝和京东)
  19. SQL数据库临时表创建和临时表拼接查询
  20. 输入半径r,求周长L和面积s

热门文章

  1. leetcode算法题--子集
  2. 16 开机自动登录脚本_创建计划任务自动运行程序---运维无人值守
  3. adams齿轮齿条怎么定义接触_在SolidWorks里对标准齿轮、齿条的修改应用
  4. 单例模式和HttpContext线程内唯一
  5. JavaScript PHP模仿C#中string.format效果
  6. Python标准模块—Regular Expressions
  7. Spring学习的切入点
  8. AIR for IOS开发问题小结
  9. Vs2008不能调试的问题
  10. One Day-XML:XSLT