Git总结

Git和GitHub一直在用,但是没有详细学习过,只会几个简单的命令,做一些提交上传的操作。这几天公司没项目,比较闲,就把Git的原理和命令详细看了一遍。

Git的官方网站是 http://git-scm.com/

《Git Pro》是一本好书,详细覆盖了Git的方方面面,所有你遇到的关于Git的内容都可以在上面找到。而且它免费,有中文版和英文版

《Git Pro》英文版 在线阅读</br>
《Git Pro》中文版在线阅读

书是好书,就是太厚。花时间。而且如果没有任何Git的操作体验,直接看这本书头会比较大。所以我看了会就没看了。在网上找到另外一篇教程,详细介绍了Git的日常使用,不罗嗦,讲的都是项目中经常用到的功能。

教程作者是廖雪峰。你可以在这里找到这篇教程 教程地址</br>
他还写了一个配套的iOS App。有兴趣的也可以下载支持。

这边把学到的知识做个总结:

以下内容来自原上面提到的教程

基本命令

  • git init :初始化仓库
  • git add <filename> :添加未跟踪文件到暂存区 或 添加修改的文件到暂存区
  • git rm <filename> :将文件从git跟踪列表中删除
  • git commit -m ‘commit log’ :提交一个版本到git
  • git log :查看所有的提交历史记录
  • git status :查看当前git的状态
  • git checkout — <file> :撤销工作目录文件的修改
  • git reset HEAD <file> :取消暂存

版本管理

  • git reset –hard HEAD^ :版本回退上一个版本
  • git reset –hard HEAD^^ :版本回退上上个版本
  • git reset –hard HEAD~100 :版本回退前一百个版本
  • git reflog :查看操作记录,可以找到所有历史commit
  • git diff HEAD — <file> :命令可以查看工作区和版本库里面最新版本的区别

远程管理

  • git clone git@github.com:michaelliao/gitskills.git :将远程库下载下来
  • git remote add origin git@server-name:path/repo-name.git :添加远程库地址
  • git push -u origin master :提交的远程库
  • git remote -v:查看远程库信息
  • git push origin branch-name:从本地推送分支,如果推送失败,先用git pull抓取远程的新提交
  • git checkout -b branch-name origin/branch-name:在本地创建和远程分支对应的分支,本地和远程分支的名称最好一致
  • git branch –set-upstream branch-name origin/branch-name:建立本地分支和远程分支的关联
  • git pull:从远程抓取分支,如果有冲突,要先处理冲突

分支

  • git branch:查看分支
  • git branch <name>:创建分支
  • git checkout <name>:切换分支
  • git checkout -b <name>:创建并切换分支
  • git merge <name>:合并某分支到当前分支
  • git branch -d <name>:删除分支
  • git log –graph:命令可以看到分支合并图

在实际开发中,我们应该按照几个基本原则进行分支管理: 首先,master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活; 那在哪干活呢?干活都在dev分支上,也就是说,dev分支是不稳定的,到某个时候,比如1.0版本发布时,再把dev分支合并到master上,在master分支发布1.0版本; 你和你的小伙伴们每个人都在dev分支上干活,每个人都有自己的分支,时不时地往dev分支上合并就可以了。

标签 Tag

  • git tag <name>:用于新建一个标签
  • git tag -a <tagname> -m “blablabla…”可以指定标签信息
  • git tag -a v0.1 -m “version 0.1 released” 3628164
  • git tag:可以查看所有标签
  • git push origin <tagname>:可以推送一个本地标签
  • git push origin –tags:可以推送全部未推送过的本地标签
  • git push origin :refs/tags/<tagname>:可以删除一个远程标签
  • git tag -d <tagname>:可以删除一个本地标签
    原文作者:_赖笔小新
    原文地址: https://www.jianshu.com/p/aa31f524d57c
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞