转载

比较全面的 Git 学习资料整理

说明

这整个 Repository 是关于分布式版本管理工具 Git 及托管商 Github 的使用,大部分都是网友写的内容,在这里只是做一个资源的汇总和合理的安排,希望能成为最好的学习 Git 的资源,从开始入门使用,到慢慢的提高,再到理解各种原理,希望能够达成这个目标。

网络上面已经有了那么多的关于 Git 的文章,为什么还要弄一个repo来专门记录?网上的文章都是片面的,稍微全点的讲解的不够全面、深入,没能满足我对于文章的想象,所以决定自己来写。

如果你要有一些资源,希望和我一起,把这个搞起来,很简单, Fork-修改- Pull Request 就 ok。

新手入门

  • 为什么开始使用 Git 版本管理,Git VS Svn 有哪些区别?
  • 开篇:一篇适合入门学习git的资料汇总 本人的拙笔,欢迎吐槽!
  • Github-cheat-sheet 关于使用 Git 和 Github 的一些技巧汇总,中文版在此GitHub秘籍
  • Git for beginners: The definitive practical guide - from stackoverflow.com It's so useful to a beginner ,just open the url , read and practice .
  • Visual Git Cheat Sheet 通过 Git 的几个工作区 Stash、Workspace、Index、Local Repository、Upstream Repository 来汇总日常使用的 Git 命令,备忘推荐。

Git 客户端

Mac 和 Linux 系统推荐使用终端即可,Git 一开始的命令的确很多,别无它法,熟能生巧,多练习即可能够掌握日常使用的一些名利,再配合 常用命令的alias 或者强大的 zsh 终端 都能显著的提升效率,当然如果非得寻找图形化客户端,也不是没有;Windows下还是尽快熟悉客户端的使用吧,因为win下面的bash太难用了:

  • GUI Clients 官方推荐图形客户端,罗列的包括了Mac、Windows、Linux下的客户端,免费及付费的都有,你可以在这里面挑选一个就ok。
  • Git for windows 针对 Window 系统发布的客户端,集成了 Shell 窗口,方便在 Win 下面使用命令操作。
  • TortoiseGit - The coolest Interface to Git Version Control 在window下使用git,那就不得不提“乌龟”,安装了 Tortoise 后,右键图形化操作根本分辨不出来哪是 Git,哪是 Svn,很方便使用 Svn 的用户过度过来。
  • Tower2 号称最好的 Git 客户端,只有 Mac 版本,收费,集成 Github、Gitlab、Xcode等服务。
  • SourceTree 免费,功能齐全,Mac+Window 版本,集成 Github 等服务。
  • SmartGit 非商业用途免费,全平台支持,集成 Github服务。内置 SSH client ,文件比较与合并工具。

Git branch

  • A successful Git branching model 介绍日常推荐的分支开发模型,基于此模型可以通过这个小游戏来进行学习 Learn Git Branch
  • Git工作流指南完整的对比目前使用的集中式(Svn)工作流、功能分支工作流、Gitflow 工作流、Forking 工作流、Pull Request 等几种不同的模式,通俗易懂,强烈推荐看一看,如果觉的排版不好,请查看原分页文章 Git-workflow-translations
  • 熟悉的工作流后,你是否也想要在 Github 上与他人一起协同工作?那么问题来了, Github全程指南-如何高效使用?
  • Understanding the GitHub Flow This guide explains how and why GitHub Flow works 简单实用,更好的理解Github的模式。
  • Github 协同开发流程 图片很赞,简洁易懂。

Git expert

  • 项目依赖其他项目,比如公共 Css、Dll 等等,强大的 Git-submodule 优雅的解决这类问题。理解阅读 Git Tools - Submodules ,备忘或者查看命令阅读 Git Submodule Tutorial 或者 Git Submodule 使用完整教程
  • Git Submodule 的一些注意事项 一些需要理解并注意的操作

Git 书籍

  • Pro Git 作者Scott Chacon是 Github 的员工,Git 的布道者,这本书被誉为 Git 学习圣经,中间有好多插图描述的浅显易懂,挺适合详细学习下的,最新英文第二版《 Pro Git (Editon 2) 》;
  • Git-internals-pdf 老外写的,很给力,从目录上面包括安装使用以及设计原理都有讲解,有机会看看。Pdf 电子版本直接下载地址Git-internals.pdf
  • Git Community Book 汇聚了 Git 社区的很多精华, 并对 Git 的对象模型原理等做了解释,可以深入的了解下 Git 原理。pdf电子版本直接下载地址 Git Community Book.pdf
  • Git权威指南 国内版本控制咨询顾问蒋鑫先生的原创书籍,原生中文叙述,更容易理解,查看 作者写书的缘由
  • Git Reference 中文 为学习与记忆 Git 使用中最重要、最普遍的命令提供快速翻阅,可作为参考资料。
  • Git Magic - a guide from standord 斯坦福大学Git学习指南,适合快速入门。

Git 效率提升

  • Git flow 工具
  • Git flow 中文备忘清单
  • 一个很有意思的学习 Git 的小游戏 http://pcottle.github.io/learnGitBranching/
  • Git completion 终端 Git 命令的 Tab 键补全功能,比如打开终端,输入 git che ,按 Tab 键,则会出现 check-attr/check-ignore/checkout 等等的选项,支持 Bash、Zsh 等 Shell,使用方法(以 Bash Shell 为例):下载链接中相应的版本到用户目录下,修改 ~/.bashrc 文件 ,加入 source ~/git-completion.bash ,使得每次打开终端时都执行一次 git-completion.bash 脚本,来完成git 命令的 Tab 补全。或者采用这种方法 Quick Tip: Autocomplete Git Commands and Branch Names in Bash
  • .gitignore template 各种语言、各种编辑器的 .gitignore 文件模板,当你进行某些语言的开发时候,直接使用相应的模板即可,省去自己写的时间(还不全),当然你也可以去贡献自己的模板,不知道 .gitignore ? 简单讲就是不让git跟踪某些文件,详情阅读: http://git-scm.com/docs/gitignore PS: 推荐使用 .gitignore_global 文件进行全局过滤,比如mac下的 .DS_Store 文件,省去在每个 Repo 下进行设置 .gitignore 文件了。全局模板参考: https://github.com/github/gitignore/tree/master/Global

Git extensions

  • Git 的大文件支持Git LFS : Git在对大文件进行版本管理的时候,速度上是很慢的,一个帮助处理大文件的扩展插件,在 GithubHelp Working with large files 中提到,不建议对大文件如日志、database等使用Git进行版本控制,如果非要有这种需求,则建议使用 Git LFS 。

实践备忘

  • 常用命令手册 Git 日常开发常用命令整理 ,日常开发中的利器,可以当做备忘录来使用,推荐 :+1:
  • 总是使用 git merge --no-ff 而不是 git merge ,记录下分支的变更历史。 详情 http://stackoverflow.com/questions/9069061/what-is-the-difference-between-git-merge-and-git-merge-no-ff
  • 恰当的使用 git pull --rebase 避免不必要的merge记录。 详情 http://stackoverflow.com/questions/2472254/when-should-i-use-git-pull-rebase 「You should use git pull --rebase when your changes do not deserve a separate branch」

  • Git-flight-rules 一些日常使用中的场景,比如提交错了分支、提交时的用户名邮箱不对、丢弃某些提交、未提交的代码直接提交到另外一个分支等等,很实用。

  • How to undo (almost) anything with Git 撤销一切,汇总各种回滚撤销的场景,加强学习。
  • 怎样在一台电脑上同时使用公司 GitLab 和 Github 的服务? 由于公司团队使用 GitLab 来托管代码,同时,个人在 Github 上还有一些代码仓库,可公司邮箱与个人邮箱是不同的,由此产生的 SSH key 也是不同的,这就造成了冲突 ,文章提供此类问题的解决方案。
  • 如何书写提交信息 当项目越来越大,提交信息越来越复杂的时候,如何书写好提交信息就变得至关重要,这篇文章的作者总结出7条准则。
  • Commit message 和 change log编写规范-阮一峰 良好的 commit log 好处大大的多。 AngularJS Git Commit Message Conventions
  • git-recipes @童仲毅 整理翻译的一些优秀文章。
  • githug Git your game on. 使用通关游戏的形式来练习git的一些命令,非常有趣。
原文  https://github.com/xirong/my-git
正文到此结束
Loading...