Gitlab使用

作者: 夏末m | 来源:发表于2017-02-08 22:47 被阅读631次

    转载请注明出处:http://www.jianshu.com/p/02166072c389

    1. 什么是Gitlab

    Gitlab是免费的、开源的基于Git的代码管理平台。Gitlab使用Rails开发,使用PostgreSQL或MySQL数据库,Redis作缓存,代码托管在github上。

    自己搭建私有代码仓库,Gitlab是首选。

    2. Gitlab、Github、SVN区别

    2.1 svn

    svn是集中化的版本控制系统,只有一个单一的集中管理的服务器,保存所有文件的修订版本,协同工作的人们通过客户端连到这台服务器,取出最新的文件或者提交更新。

    gitlab_svn.png

    2.2 Git

    Git是免费、开源的分布式版本控制系统,是一种工具,每个终端都是一个仓库,客户端并不知道提供最新版本的文件快照,而是把原始的代码仓库完整的镜像下来。每一次的提取操作,实际都是一次对代码仓库的完整备份。
    Bitkeeper, Mercurial也是运行在分布式模式上的。

    gitlab_git.png

    2.3 Git vs SVN

    话说Svn与Git的区别(以后别再问我了)
    为什么用Git

    2.4 Github vs Gitlab

    两者都是基于web的Git repositories(仓库),拥有流水线型的web开发流程,它们为开发团队存储、分享、发布、测试和合作web开发项目提供了中心化的、云存储的场所。Git版本控制——对于多人共同开发一个project来说非常重要——它提供了分享开源项目的平台。
    GitLab拥有更多的特性,它可以让开发团队拥有更多的安全性和灵活性的选择。
    GitLab拥有GitHub拥有的一切,但他拥有更多——让团队对它们的repositories拥有更多的控制,它的特色在于:

    • 非常便捷的用户界面,在同一界面上获取到:projects,最近的projects,用户,最近的用户,群组和状态;
    • 允许设置仓库权限是公用的还是私有的。(Github也可以设置仓库为私有,但是需要付费。另外企业版很贵。)
    • “Snippet support”让用户分享一个project的部分代码,而不是整个project。
    • 受保护的分支是一种提升代码安全性的新方法,它们允许用户设置project的获取权限,所以一个团队中只有特定的人可以push,force push或者删除一个分支的代码。
    • Authentication levels更进一步的提升安全性,允许用户给人读写以外的权限。举例来说,你可以给一个组员跟踪变动的权限却不给他获取代码的权限。
    • 你可以设置获取到团队的整体的改进进度,而不是你个人的进度。
    • 开发者通过打上“仍在进行中”状态标签让其他成员知道代码没有完成,从而阻止未完成的代码合并到其他的代码中。
    • “innersourcing”公司的资源如果员工不再权限范围内,将不知道这个资源的存在。

    3. Gitlab使用

    • 对于管理员来说,需要安装、配置、添加项目等,这个网上有很多文章,暂时先不写了。
    • 对于普通员工来说,只需要注册、配置SSH密钥就能使用Gitlab了。

    3.1 注册

    普通员工根据公司提供的用户名、邮箱注册。注册成功后可以修改用户名、邮箱,也可以注销账户。

    3.2 配置SSH key

    Git仓库之间的代码传输协议主要使用SSH协议,SSH(Secure Shell)是一个提供数据通信安全、远程登录、远程指令执行等功能的安全网络协议。
    关于SSH的介绍可以看下面的文章:
    SSH原理简介
    SSH原理与运用(一):远程登录
    数字签名是什么?
    Gitlab官网上有配置SSH key的详细步骤:SSH
    以Window为例:
    需要在命令行操作,打开Git Bash(没有安装过Git的,可以到这里下载~)
    首先检测是否已经有SSH key

    type %userprofile%\.ssh\id_rsa.pub
    

    如果返回一串以ssh-rsa开头的字符串,说明已经有SSH key,可以直接使用。
    否则,就要生成新的SSH key
    生成新的SSH key,可以使用如下命令:

    ssh-keygen -t rsa -C "你的邮箱"
    

    回车,会提示输入key存储的文件名,可以直接回车,使用默认的位置,默认在C:\Users\Administrator.ssh。
    然后会提示输入口令(passphrase),可以不输入,如果担心私钥的安全,可以设置一下,设置之后要牢记,以后提交的时候需要输入这个口令。
    以后如果想修改这个口令,可以使用这个命令:

    ssh-keygen -p <keyname>
    

    现在就可以在C:\Users\Administrator.ssh看到生成的两个文件了。id_rsa是私钥,id_rsa.pub是公钥。
    登录Gitlab,在Profile Settings => SSH-Keys输入公钥,标题随意,就可以使用Gitlab了。

    4. Git Flow

    Git工作流指南
    基于git的源代码管理模型——git flow

    5. Gitlab使用遇到的问题

    To be continued...

    参考:
    GitHub vs GitLab:它们有什么区别?
    Gitlab的使用
    Gitlab 简单配置使用

    关于其他的代码托管网站,可以看看:
    GitHub & Bitbucket & GitLab & Coding 的对比分析
    Gogs:可能是比Gitlab更好的选择

    相关文章

      网友评论

        本文标题:Gitlab使用

        本文链接:https://www.haomeiwen.com/subject/zfavittx.html