Git总结

作者: _赖笔小新 | 来源:发表于2015-05-03 17:43 被阅读7941次

    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>:可以删除一个本地标签

    相关文章

      网友评论

      • 遗失的理想:比svn好用多了~就是不太好理解……
      • 傅简书: :cry: 没什么可以见人的项目共享到代码库,反倒可以利用git给自己本地的文件做版本管理。

      本文标题:Git总结

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