什么是Git


Git是一个版本控制系统(Version Control System,VCS)。

版本控制是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统。

多年前,我在法国做第一个实习时(2011年),那时候自己编程还在入门阶段,根本没听过版本控制系统。

那时候真是蠢(现在也没好到哪里去),每次修改多一点的代码,就要复制、黏贴整个项目目录。因此,公司的电脑里有着几十个项目的副本(简直了)。

前不久,我看到公司的一个实习生也在做和我多年前同样的事。而且我们问他,他说没听说过版本控制系统...

现在,我用Git也有几年了吧。绝对是越用越爽,不用不爽;一朝使用,爱不释手。

每天到公司第一件事,开电脑;第二件事,在终端中切换到项目目录,然后输入Git命令。

有了版本控制系统,就可以不用担心文件丢失,不小心误修改文件等等“事故”,而且你可以随便回到历史记录的某个时刻。

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

它们的原理类似下图:

集中式版本控制系统

而Git或Mercurial这类分布式版本控制系统, 才是现代的首选。因为分布式的优势绝对显著。

在分布式版本控制系统里,客户端并不只提取最新版本的文件快照,而是把代码仓库完整地镜像下来。

这么一来,任何一处协同工作用的服务器发生故障,事后都可以用任何一个镜像出来的本地仓库恢复。因为每一次的提取操作,实际上都是一次对代码仓库的完整备份。

分布式版本控制系统

现在,Google, Facebook, Microsoft等世界级公司每天在用Git。

众所周知,IT界大牛很多, 但是大牛中的大牛稀少。

Linus Torvalds就是其中之一。

Linus Torvalds不但开创了Linux操作系统(当然了, 开源社区对Linux贡献极大, 参看我的【Linux探索之旅】开宗明义+第一部分第一课:什么是Linux?), 而且他发明了Git版本控制系统。

现在的Android系统底层就是基于更改过的Linux系统,你说Linus Torvalds是不是贡献极大。

Git的诞生很有趣:

2005年Linux 内核开发社区正面临严峻的挑战:他们不能继续使用 BitKeeper(一个分布式版本控制系统) 了(原因是当时Bitkeeper 著作权所有者决定收回授权,内核开发团队与其协商无果),而又没有其他的 SCM (Software Configuration Management)可满足他们的分布式系统的需求。

Linux 之父 Linus Torvalds 接受了这个挑战,决定开发一个新的版本控制系统。周末他消失了,新的一周,Git 问世了。LT就是威武。

Atlassian为Git做了一个10年的纪录图。

https://www.atlassian.com/git/articles/10-years-of-git/

Git配置和常用命令


安装Git很简单,在Ubuntu等Debian族的Linux系统上,只要输入下面命令:

sudo apt-get install git-all

关于安装Git,可以看这个链接

https://git-scm.com/book/zh/v2/%E8%B5%B7%E6%AD%A5-%E5%AE%89%E8%A3%85-Git

安装完Git就可以对其做一些配置。

Git有一个工具被称为git config,它允许你获得和设置配置变量;这些变量可以控制Git的外观和操作的各个方面。这些变量可以被存储在三个不同的位置:

  1. /etc/gitconfig 文件:包含了适用于系统所有用户和所有库的值。如果你传递参数选项’--system’ 给 git config,它将明确的读和写这个文件。

  2. ~/.gitconfig 文件 :具体到你的用户。你可以通过传递--global 选项使Git 读或写这个特定的文件。

  3. 位于git目录的config文件 (也就是 .git/config) :无论你当前在用的库是什么,特定指向该单一的库。每个级别重写前一个级别的值。因此,在.git/config中的值覆盖了在/etc/gitconfig中的同一个值。

我的Git config(配置)列表:

我的Git config(配置)列表

这个配置就在你的个人目录的.gitconfig(有一个点哦, 不用ls -al是看不到的)文件中, 你可以用vim来打开编辑内容 (vim ~/.gitconfig), 我的内容如下

[user]    name = Enming Xie    email = enming.xie@blabla.fr
[color]    ui = auto
[alias]    st = status    pl = pull --ff-only    ps = push    co = checkout    ci = commit    df = difftool    cp = cherry-pick    ca = commit --amend    br = branch    l = log --stat    last = log -1    lg = log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit    up = push origin    lf = log --follow -p    aa = ls-files --modified    su = status -uno    cm = commit -m    uf = push origin -f    cl = clean -fdx    fe = fetch --prune    cf = clean -fdx    bd = branch -D    cb = checkout -b
[push]    default = simple
[core]    editor = vim    pager = less -+F
[diff]    tool = meld
[difftool]    prompt = false
[merge]    tool = meld
[init]    templatedir = ~/.git_template

因为我比较喜欢偷懒(程序员需要学会偷懒好么), git命令有几个太长的, 我就用alias(别名)来替代了, 这样平时输入git命令就快了很多, 简直飞起!

我最常用的Git命令(全名,没用alias之前):

git checkoutgit statusgit checkout -bgit commitgit diffgit addgit clean -fdxgit fetch --prunegit pull --ff-onlygit branch -Dgit pushgit mergegit rmgit rebasegit resetgit revertgit push origin :yourbranch

Git必看书籍


Pro Git这本书(也可以看其电子版)绝对是Git入门和进深的不二选择。

我的同桌说:他进公司时,被要求先读两遍这本书。

英文版:

https://git-scm.com/book/en/v2

中文版:

https://git-scm.com/book/zh/v2

Github


Github 和 Git 是两回事。

Git是版本控制系统,Github是在线的基于Git的代码托管服务。

GitHub是2008年由Ruby on Rails编写而成。GitHub同时提供付费账户和免费账户。这两种账户都可以创建公开的代码仓库,但是付费账户也可以创建私有的代码仓库。

为什么现在Github这么火,以至于世界顶级公司和项目的源码很多都托管在Github上,首先:

颜值高!

现在这世代还是得看看颜值的。你说Sourceforge等代码托管网站也年岁很久了,为什么没有Github那么火呢?

关键是Github长得好看(你长这么好看,说什么都是对的)。

对比Github和Sourceforge

Github

Sourceforge

反正我看了Github再来看Sourceforge的主页,我已经不想用Sourceforge了。

软件的颜值体现了设计者的审美观以及设计能力。

2011年,Github已经取代Sourceforge,成为最活跃的代码交流社区。这意味着在Open Source Community(开源社区),Git取代了SVN已经成为事实。

而且,Github现在都快成为程序员简历的一个重要加分条件了。

如果你的简历里放上你的Github链接,招聘者通过你对开源项目的贡献和你自己的项目代码,就可以对你的水准了解大概(我还没把我的项目都放到Github上,慢慢来吧)。

Linus Torvalds的Github页面

https://github.com/torvalds

Gitlab


Github有个小缺陷 (也不能算是缺陷吧), 就是你的repo(repository的缩写,表示“仓库”)都需要public(公开), 如果你想要创建private(私人)的repo, 那得付钱。

不过, 幸好, Gitlab解决了这个问题, 可以在上面创建免费的私人repo。

比如我们公司就是用Gitlab来管理项目的(【程序员】项目经理如何调动组员积极性)。

我在公司的Gitlab

可以看到,我是从2015年10月12日在Ercom公司工作的,一直活跃度还不错(必须为中国人争光么,我可是组里最努力的)。

再看我个人的Gitlab账户页面,至今只有几个项目,因为大部分都开源在Github上。

我的个人Gitlab

要创建Gitlab的新项目很简单,和Github类似,只要点击New Project按钮,填写基本信息即可。

创建项目按钮

填写Gitlab项目信息

可以看到,项目的默认属性是Private(私人的),当然,你也可以选择Public(公开的)或Internal(内部的)。

怎么样,Github和Gitlab很酷吧。

作者:程序员联盟
链接:http://www.jianshu.com/p/8d497989f704
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

转载于:https://www.cnblogs.com/lmg-jie/p/7640637.html

Git,Github和Gitlab简介和基本使用相关推荐

  1. 项目管理工具之Git/GitHub/Gitee/Gitlab

    一 Git 概述 Git 是一个免费的.开源的分布式版本控制系统,可以快速高效地处理从小型到大型的各种项目. Git 易于学习,占地面积小,性能极快. 它具有廉价的本地库,方便的暂存区域和多个工作流分 ...

  2. SVN Git GitHub Gitee GitLab区别

    目前的最常用的版本控制中心有两种:SVN和Git: SVN和Git都只是一个命令行工具,用于代码的存储和版本控制 版本控制中心 仓库区(Repository) SVN 集中式版本控制系统 中央服务器( ...

  3. Git,Github和Gitlab简介和使用方法

    什么是Git Git是一个版本控制系统(Version Control System,VCS). 版本控制是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统. 多年前,我在法国做第一 ...

  4. git github gitlib gitlab

    为什么80%的码农都做不了架构师?>>>    git 是一种版本控制系统,是一个命令,是一种工具  gitlib 是用于实现git功能的开发库  github 是一个基于git实现 ...

  5. 超详细的Git学习记录(Git基础内容/IDEA集成Git/GitHub/Gitee/GitLab及Centos7部署GitLab)

    超详细的Git学习笔记 从B站搜到的尚硅谷视频学习了Git,记录了一下学习的内容,收获很大 学习地址: https://www.bilibili.com/video/BV1vy4y1s7k6?p=11 ...

  6. git github gitlib gitlab分别是什么,有什么区别?

    git 是一种版本控制系统,是一个命令,是一种工具,类似于SVN gitlib 是用于实现git功能的开发库 github 是一个基于git实现的在线代码仓库,包含一个网站界面,向互联网开放 gitl ...

  7. Git GitHub Gitee GitLab

    Git Git 常用命令 git --version 查看 git 版本 git config --global user.name 用户名 设置用户签名 git config --global us ...

  8. Git 与 GitHub 、GitLab 区别(学习笔记)

    目录 1 版本控制系统 1.1 Git介绍 1.2 版本控制系统类型 1.2.1 分布式版本控制工具 1.2.2 集中式版本控制工具 2 Git GitHub 与GitLab 的关系 2.1 Git ...

  9. git、github、gitlab、gitee都是什么?

    各种git git 是一种版本控制系统,是一个命令,是一种工具. github 是一个基于git实现在线代码托管的仓库,向互联网开放,企业版要收钱. gitlab 类似于 github,一般用于在企业 ...

最新文章

  1. PyTorch 学习笔记(六):PyTorch hook 和关于 PyTorch backward 过程的理解 call
  2. Activiti——HelloWorld-模拟流程执行(三)
  3. 最优化——单纯形法,单纯形表的求取
  4. 使用C#进行Word 2002和Excel 2002编程
  5. 内置的进制转换的方法---小笔记
  6. C语言的特点与创建的基本步骤是什么
  7. 云计算解决方案——电信行业
  8. python 反射和动态加载_Python的反射
  9. HttpClient Get请求实例
  10. vivado 亚稳态_VIVADO时序约束及STA基础
  11. 新手建站虚拟主机与云服务器应该如何选择?
  12. Office 2007 打开故障 The setup controller has encountered a problem during instll
  13. docker-安装、使用centos7镜像
  14. 人脸关键点检测之PFLD
  15. 《iOS移动开发从入门到精通》图书连载2:如何成为一名iOS开发者
  16. C语言scanf为啥有时候要输入两次(解析)
  17. python抢课_python实现强智科技教务系统抢课(两种方法)
  18. 怎样将腾讯视频qlv格式转换成mp3音频
  19. 数据库实验三 数据查询一
  20. esp-01s接入天猫精灵与relay继电器控制电灯

热门文章

  1. div中有元素刷新不出来_DNF:神话罐子来了!500个不渝材料就能换,但你刷新不出来...
  2. html实现全屏效果原理,HTML5 实现全屏效果
  3. 字符串 mysql索引,长字符串的MySQL索引
  4. c++中报错预处理器指令后有意外标记 - 应输入换行符
  5. 网站文章中如何设置关键词才更有利于SEO优化?
  6. 如何良好的展现网站优化效果?
  7. java开发一年多少钱_4年Java程序员:月薪不过3万,就不要拿命换钱了
  8. 缓存大小_CPU中的L1,L2和L3缓存之间的区别:缓存是如何工作的?
  9. css3.0动画,CSS3.0实现霓虹灯按钮动画特效的示例代码
  10. 潘通色卡tcx电子版_【收藏】最全“潘通色卡电子版”,只带手机对色一步到位!...