GitHub---Git基本概念篇

如何使用git命令上传本地到github?

本系列教程主要参考github用户stormzhang,涉及到Github中基本概念,Git速成,向 GitHub 提交代码,Git 进阶, 团队合作利器:Git 分支详解, GitHub 常见的几种操作。
如果想快速学习使用git命令上传本地到github可以参考如下博客。
如何用git命令行上传本地代码到github

git_learn.jpg

GitHub 基本概念

  • Repository
    仓库,即你的项目,你想在GitHub上开源一个项目,那就必须要新建一个Repository,如果你开源的项目多了,你就拥有了多个Repositories。
  • Issue
    问题,举个例子,就是你开源了一个项目,别人发现你的项目中有bug,或者哪些地方做的不够好,他就可以给你提个Issue,即问题,提的问题多了,也就是Issues,然后你看到了这些问题就可以去逐个修复,修复ok了就可以一个个Close掉。
  • Star
    这个好理解,就是给项目点赞,但是在GitHub上的点赞远比微博、知乎点赞难的多,如果你有一个项目获得100个star都算很不容易了!
  • Fork
    这个不好翻译,如果实在要翻译我把他翻译成分叉,什么意思呢?你开源了一个项目,别人想在你这个项目的基础上做些改进,然后应用到自己的项目中,这个时候他就可以 Fork 你的项目,这个时候他的GitHub主页上就多了一个项目,只不过这个项目是基于你的项目基础(本质上是在原有项目的基础上新建了一个分支,分支的概念后面会在讲解Git的时候说到),他就可以随心所欲的去改进,但是丝毫不会影响原有项目的代码与结构。
  • Pull Request
    发起请求,这个其实是基于Fork的,还是上面那个例子,如果别人在你基础上做了改进,后来觉得改进的很不错,应该要把这些改进让更多的人收益,于是就想把自己的改进合并到原有项目里,这个时候他就可以发起一个Pull Request(简称PR) ,原有项目创建人就可以收到这个请求,这个时候他会仔细review你的代码,并且测试觉得OK了,就会接受你的PR,这个时候你做的改进原有项目就会拥有了。
  • Watch
    观察,如果你Watch了某个项目,那么以后只要这个项目有任何更新,你都会第一时间收到关于这个项目的通知提醒。
  • Gist
    有些时候你没有项目可以开源,只是单纯的想分享一些代码片段,那这个时候Gist就派上用场了!

Git速成

  1. 什么是Git?
    Git 是 Linux 发明者 Linus 开发的一款新时代的版本控制系统,那什么是版本控制系统呢?怎么理解?网上一大堆详细的介绍,但是大多枯燥乏味,对于新手也很难理解,这里我只举几个例子来帮助你们理解。
    熟悉编程的知道,我们在软件开发中源代码其实是最重要的,那么对源代码的管理变得异常重要:
    比如为了防止代码的丢失,肯定本地机器与远程服务器都要存放一份,而且还需要有一套机制让本地可以跟远程同步;
    又比如我们经常是好几个人做同一个项目,都要对一份代码做更改,这个时候需要大家互不影响,又需要各自可以同步别人的代码;
    又比如我们开发的时候免不了有bug,有时候刚发布的功能就出现了严重的bug,这个时候需要紧急对代码进行还原;
    又比如随着我们版本迭代的功能越来越多,但是我们需要清楚的知道历史每一个版本的代码更改记录,甚至知道每个人历史提交代码的情况;
    等等等类似以上的情况,这些都是版本控制系统能解决的问题。所以说,版本控制是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统,对于软件开发领域来说版本控制是最重要的一环,而Git毫无疑问是当下最流行、最好用的版本控制系统。
  2. Git安装
    Mac: https://sourceforge.net/projects/git-osx-installer/
    Windows: https://git-for-windows.github.io/
    Linux: apt-get install git
  3. Git命令列表
    git_common_usage.png
  4. Git具体命令
    第一步,我们先新建一个文件夹,在文件夹里新建一个文件(本文所有操作均基于Linux命令,Windows用户可以自己手动新建)
mkdir git_learn                 (创建文件夹git_learn)
cd     git_learn                (切换到git_learn目录)
touch    git.md                   (新建git.md文件)

注:在进行任何Git操作之前,都要先切换到Git 仓库目录下,也就是先要先切换到项目的文件夹目录下。

这个时候我们先随便操作一个命令,比如 git status,可以看到如下提示(别纠结颜色之类的,配置与主题不一样而已):
non_git_repository.png
  • git init 初始化 git 仓库
  • git status
    git_status.png

    git status 这个命令顾名思义就是查看状态,这个命令可以算是使用最频繁的一个命令了,建议大家没事就输入下这个命令,来查看你当前 git 仓库的一些状态。
    默认就直接在master分支,关于分支的概念后面会提,这时最主要的是提示 git.md 文件Untracked files,就是说git.md这个文件还没有被跟踪,还没有提交在 git 仓库里呢,而且提示你可以使用git add 去操作你想要提交的文件。

  • git add

    上面提示 git.md 文件还没有提交到 git 仓库里,这个时候我们可以随便编辑下 git.md 文件,然后输入 git add git.md, 然后再输入git status:
    git_add_status.png
    此时提示以下文件Changes to be committed, 意思就是a.md文件等待被提交,当然你可以使用git rm --cached 这个命令去移除这个缓存。
  • git commit
    接着我们输入git commit -m 'first commit',这个命令什么意思呢? commit 是提交的意思, -m代表是提交信息,执行了以上命令代表我们已经正式进行了第一次提交。
    这个时候再输入git status,会提示nothing to commit。
    git_commit.png
    注意:安装好git后,在命令行或终端中使用下面的命令可以设置git自己的名字和电子邮件。这是因为Git是分布式版本控制系统,所以,每个机器都必须自报家门:你的名字和Email地址。git config命令的–global参数,用了这个参数,表示你这台机器上所有的Git仓库都会使用这个配置,当然也可以对某个仓库指定不同的用户名和Email地址。配置好之后可以使用git config -l查看配置。
  • git log 查看所有commit记录
  • git add & git commit
    看到这里估计很多人会有疑问,我想要提交直接进行 commit不就行了么,为什么先要再add一次呢?首先 git add 是先把改动添加到一个[暂存区],你可以理解成是一个缓存区域,临时保存你的改动,而git commit才是最后真正的提交。这样做的好处就是防止误提交,当然也有办法把这两步合并成一步,不过后面再介绍,建议新手先按部就班的一步步来。
  • git branch 查看、创建(git branch name)分支
    branch即分支的意思,分支的概念很重要,尤其是团队协作的时候,假设两个人都在做同一个项目,这个时候分支就是保证两人能协同合作的最大利器了。举个例子,A, B俩人都在做同一个项目,但是不同的模块,这个时候A新建了一个分支叫a, B新建了一个分支叫b,这样A、B做的所有代码改动都各自在各自的分支,互不影响,等到俩人都把各自的模块都做完了,最后再统一把分支合并起来。
    执行 git init 初始化git仓库之后会默认生成一个主分支 master,也是你所在的默认分支,也基本是实际开发正式环境下的分支,一般情况下 master 分支不会轻易直接在上面操作的,你们可以输入git branch 查看下当前分支情况:
    如果我们想在此基础上新建一个分支呢,很简单,执行 git branch a就新建了一个名字叫 a 的分支,这时候分支a跟分支master是一模一样的内容,git checkout a可以切换到分之a。git checkout -b a表示新建分支a,并直接切换。
  • git merge 合并分支
    合并分之分两步:第一步是切换到 master分支,如果你已经在了就不用切换了,第二步执行git merge a,意思就是把a分支的代码合并过来,不出意外,这个时候a分支的代码就顺利合并到 master 分支来了。为什么说不出意外呢?因为这个时候可能会有冲突而合并失败,留个包袱,这个到后面进阶的时候再讲。
  • git branch -d a 删除分支a
  • git branch -D a 强制删除分支a
  • git tag 查看历史tag记录
    git tag v1.0表示给代码打上版本标签,git checkout v1.0 ,切换到v1.0tag的代码状态了。

本系列内容转载总结自原创作者stormzhang,其
个人博客: http://stormzhang.com
GitHub: https://github.com/stormzhang
知乎: stormzhang
微博: googdev

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容

  • 前言 Git使用教程 Git是什么 Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。 ...
    90后的思维阅读 894评论 0 0
  • 1.GitHub 有什么用 学习优秀的开源项目开源社区一直有一句流行的话叫「不要重复发明轮子」,某种意义上正是因为...
    Clemente阅读 1,422评论 1 14
  • (预警:因为详细,所以行文有些长,新手边看边操作效果出乎你的预料) 一:Git是什么? Git是目前世界上最先进的...
    axiaochao阅读 1,921评论 1 8
  • 声明:这篇文章来源于廖雪峰老师的官方网站,我仅仅是作为学习之用 Git简介 Git是什么? Git是目前世界上最先...
    横渡阅读 3,941评论 3 27
  • Add & Commit git init 初始化一个 Git 仓库(repository),即把当前所在目录变成...
    冬絮阅读 4,774评论 0 8