好的,在看到PJ Hyett的这篇文章后,我决定跳到最后,使用Git。

所以我需要的是Git初学者实用指南。“初学者”被定义为知道如何处理他们的编译器,在某种程度上理解Makefile是什么,并且在没有很好地理解它的情况下接触了源代码控制。

“实用”被定义为这个人不想详细了解Git在后台做什么,甚至不关心(或知道)它是分布式的。你的答案可能暗示了这些可能性,但试着瞄准那些希望在备份和安全的“服务器”上保留“主”存储库的初学者,并将他们的本地存储库仅视为“客户端”资源。

So:

安装/设置

如何安装Git如何设置Git?尝试涵盖Linux、Windows、Mac,思考“客户端/服务器”思维。在Windows上使用Msysgit安装GIT服务器如何创建新项目/存储库?如何将其配置为忽略不属于代码库的文件(.obj、.user等)?

使用代码

如何获取最新代码?如何检查代码?如何提交更改?如何查看未提交的内容或当前代码库的状态?如何销毁不需要的提交?如何比较文件的两个版本,或当前文件和以前的版本?如何查看文件修订的历史记录?如何处理二进制文件(例如,visio文档或编译器环境)?如何合并“同时”更改的文件?如何撤消(恢复或重置)提交?

标记、分支、发布、基线

如何“标记”、“标记”或“发布”特定文件集的特定修订集,以便以后随时可以提取该修订集?你如何获得特定的“释放”?你是怎么分支的?如何合并分支?如何解决冲突并完成合并?如何将一个分支的部分合并到另一个分支中?什么是重新定基?如何跟踪远程分支?如何在远程存储库上创建分支?如何删除远程存储库上的分支?Git工作流示例

另外

描述并链接到一个好的GUI、IDE插件等,使Git成为一个非命令行资源,但请列出它的局限性和优点。msysgit-跨平台,包含在Git中gitk-跨平台历史查看器,包含在Git中gitnub-Mac OS Xgitx-Mac OS X历史查看器smartgit-跨平台、商业、测试版用于Linux的tig控制台GUIqgit-用于Windows、Linux的GUIGitExtensions-Windows包,包括友好的GUI初学者还应该知道其他常见任务吗?Git Status告诉您刚才做了什么,您有什么分支,以及其他有用的信息如何将subversion存储库设置为源代码控制源代码,从而有效地工作?

其他Git初学者参考

Git指南Git手册Git魔法数字广播GitHub指南Git教程Scott Chacon的Progit-书Git-SVN速成课程Git自下而上Git就绪gitref.org网站Git可视化备忘单

深入Git

从概念上理解Git计算机科学家Git(和另一个版本)

我会不时地检查条目,并“整理”它们,使它们具有一致的外观/感觉,并且很容易扫描列表-请随意遵循简单的“标题-简要说明-说明列表-获取和额外信息”模板。我还将链接到上面项目符号列表中的条目,以便以后很容易找到它们。


当前回答

GIT工作流示例。

Git非常灵活,可以很好地适应任何工作流,但不强制执行特定的工作流可能会产生负面影响,使您很难理解除了线性“备份”工作流之外,您可以使用Git做什么,以及分支有多有用。

这篇博文很好地解释了一个非常简单但有效的工作流程,使用git很容易设置。

从博客文章中引用:我们认为origin/master是HEAD源代码始终反映生产就绪状态的主要分支:

工作流已经变得非常流行,可以制作一个实现此工作流的项目:gitflow

很好地说明了一个简单的工作流程,您可以在开发过程中进行所有更改,并且只有在代码处于生产状态时才将其推送给master:

现在让我们假设您想开发一个新功能,或者重构一个模块。您可以创建一个新的分支,我们可以称之为“功能”分支,这需要一些时间,可能会破坏一些代码。一旦您的特性“足够稳定”,并希望将其“更接近”生产,您就将特性分支合并到开发中。当所有的bug在合并后都被清理出来,并且你的代码通过了所有的测试,你就可以将你的更改推到master中。

在所有这些过程中,您会发现一个可怕的安全漏洞,必须立即修复。您可以有一个名为修补程序的分支,它使更改比正常的“开发”分支更快地返回到生产中。

在这里,您可以看到这个特性/修补程序/开发/生产工作流的样子(在博客文章中有很好的解释,我重复一遍,博客文章比我更详细、更好地解释了整个过程)。

其他回答

吉蒂语:http://macendeavor.com/gity

如何安装Git

在Windows上:

安装msysgit

有几个下载:

Git:除非您特别需要以下其他选项之一,否则请使用此选项。PortableGit:如果您想在PC上运行Git而不在PC上安装(例如从USB驱动器运行Git),请使用此选项msysGit:如果你想开发Git本身,可以使用这个。如果您只想将Git用于源代码,但不想编辑Git的源代码,则不需要这样做。

这还安装了一个Cygwin bash shell,因此您可以在更好的shell中使用git(而不是cmd.exe),还包括gitgui(可以通过gitgui命令或“开始”>“所有程序”>“git”菜单访问)

Mac OS X

使用gitosx安装程序,也可以从源代码安装

通过包管理器

使用本地包管理器安装git。例如,在Debian(或Ubuntu)上:

apt-get install git-core

或者在Mac OS X上,通过MacPorts:

sudo port install git-core+bash_completion+doc

…或fink:

fink install git

…或Homebrew:

brew install git

在基于Red Hat的发行版上,如Fedora:

yum install git

在Cygwin中,Git包可以在“devel”部分找到

源代码(Mac OS X/Linux/BSD/等)

在Mac OS X中,如果您安装了开发工具,您可以非常容易地从源代码编译Git。以.tar.bz或.tar.gz格式从以下位置下载最新版本的Git:http://git-scm.com/,并提取它(在Finder中双击)

在Linux/BSD/等上。应该是一样的。例如,在Debian(和Ubuntu)中,您需要通过apt安装构建基本包。

然后在终端中,cd到您提取文件的位置(运行cd~/Downloads/git*/应该有效),然后运行。。

./configure && make && sudo make install

这将在默认位置安装Git(/usr/local-因此Git将位于/usr/local/bin/Git中)

它将提示您输入密码(用于sudo),这样它就可以写入/usr/local/目录,而该目录只能由“root”用户访问,因此需要sudo!

如果您希望将其安装在单独的位置(这样Git的文件不会与其他工具混合),请在configure命令中使用--prefix:

./configure --prefix=/usr/local/gitpath
make
sudo make install

这会将git二进制文件安装到/usr/local/bin/gitpath/bin/git中,因此您不必每次都键入该文件,您应该通过在~/.profile中添加以下行将其添加到$PATH中:

export PATH="${PATH}:/usr/local/bin/gitpath/bin/"

如果您没有sudo访问权限,可以使用--prefix=/Users/myusername/bin并安装到主目录中。记得将~/bin/添加到$PATH

脚本x-git-update-to-latest-version自动完成了很多工作:

此脚本更新git repo的本地克隆(localy at ~/work/track/git),然后配置、安装(位于/usr/local/git git-descripte)并更新/usr/local/gt符号链接。这样,我的PATH中就可以有/usr/local/git/bin,而且我总是使用最新版本。此脚本的最新版本还安装了手册页。您需要调整MANPATH以包含/usr/local/git/share/man目录。

Git Magic是你所需要的一切。保证,否则你的钱会回来!

好吧,尽管你要求我们不要“简单地”链接到其他资源,但当已经存在一个社区生长(和不断增长)的非常好的资源时,这是非常愚蠢的:Git社区书。说真的,一个问题中的20多个问题绝对不会简明扼要。Git社区书有HTML和PDF两种格式,可以用清晰、格式良好、经过同行评审的答案回答您的许多问题,并且格式可以让您直接解决手头的问题。

唉,如果我的帖子真的让你不安,我会删除它。说吧。

还有一项我认为应该在这个列表中,可能对初学者非常有用:

不要惊慌

如果我做了一些承诺,然后做了一些可怕的事情,比如重新启动,而现在一些东西甚至所有东西都好像丢失了呢?(Rebase似乎是第一次吸引大多数人的方法,所以我专注于此。虽然git Rebase--abort有很大帮助,但有时你会发现,在交互式Rebase过程中,你把编辑搞砸了,比如,让Rebase完成,现在你想把你的旧东西拿回来。还有一些事情,比如过滤器分支…)

git的一个关键原则是它永远不会删除您提交的任何内容。(“什么,从来没有?”“不,从来没有!”。可能需要仔细挖掘才能找到以前的工作,但如果你早些时候成功地提交了一些git,那么,例如,即使是你的一系列因悲剧性的重新启动错误而被破坏的提交仍然存在,通常至少一个月(从技术上讲,直到“重新启动”到期)。

重要的是要记住,每个分支名称都标记或指向“提交ID”。这些是像7cc5272这样有趣的数字。您所做的许多事情,如向分支添加新的提交,都会使分支名称指向一个新的、不同的commit-ID。每个提交ID都有一个指向以前提交ID的链接,这实际上构成了一个充满提交的“分支”。

rebase条目谈到“重写历史”,像gitfilter branch这样的命令也会“重写历史,”但它们不是通过销毁以前的历史,而是通过添加新的历史来实现。一旦新的历史记录就位,git将“四处移动标签”,使其看起来历史已经改变。如果你在修复讨厌的bug分支上,并执行git重基并设法破坏东西,那么修复讨厌的错误标签现在指的是残骸,但原始版本仍然存在。特别是Rebase创建了一个临时(非移动,非分支)标签,拼写为ORIG_HEAD,可以让您找到它们。filter branch命令还保存所有原始名称。在某些情况下,可能没有明显的名称,但始终可以找到提交。如果有必要的话,找一个“git guru”,并解释你做了什么导致了残骸。

(命令git reflog show也可以帮助查找提交ID。)

如果您发现了您认为的部分或全部以前的工作,请尝试:

git log <commit-ID>   # ORIG_HEAD after a bad rebase, for instance
git show <commit-ID>  # or some long SHA1 value you can still see in a window

如果它看起来正确或有用,请为其命名:

git branch recover-my-stuff ORIG_HEAD

一切又回来了!事实上,现在你的糟糕的重新基础和你的原始工作都在你的git repo中“永远”(或者至少,直到你删除分支名称并让几个月过去,然后它们被垃圾收集)。您可以为任意多个恢复的提交添加任意多个名称。(分支名称实际上是免费的,除了弄乱了git分支输出之外,当然,它们还可以防止提交被垃圾收集。如果您喜欢,也可以在特定的提交ID上添加标记。)