- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我想在本地服务器上安装一个版本控制系统。
我一直在研究svn和git的优缺点,甚至是mercurial。
我们目前有大约30-35个不同的网站。我会创建一个包含所有文件夹的repo吗?还有哪一个会更好地处理所有这些作为个人网站项目?Git还是SVN?
我还将不得不在我们的linux服务器上安装它,并为开发人员创建开发沙盒。涉案人员还使用windows和mac。
我只是在寻找来自经验的建议,以及如何在服务器上本地安装它们的指导链接。
至于应用程序,我相信tourtiousgit/svn在windows上很好,tower和版本在mac上也很好。
最佳答案
让我们尝试一个平衡的比较,前提是在您的场景中,您可能不需要任何高级功能。
比较
保管部
文件系统上的布局:SVN需要两件事,一个工作目录和一个存储库,来处理您的数据。这不仅会造成不必要的元数据重复,而且会使事情变得稍微笨拙。git和mercurial都可以将完整的历史记录保存在工作目录中(每个工作目录都是完整的存储库)。如果您不打算在服务器上拥有已签出的文件副本,这一点就不太相关(但无论如何,它比这要复杂一些,所以请记住,可能还有其他情况下,整个要点都不适用)。
工作目录混乱:svn在存储库的每个subdir中添加.svn
子目录;git和mercurial只在顶层添加一个.git
/.hg
目录。
空间消耗:Git和Mercurial使用的存储机制往往比SVN的效率高得多。Git的缺点是存储库必须偶尔进行优化(如果没有非常大的文件,优化速度会相当快);我不知道这是否对Mercurial是必要的,但我怀疑不是。
结论:我推荐git或mercurial。
特征
因为您甚至不需要git/mercurial更好的合并功能,所以我不认为这是一个决定因素。如果您计划同时处理多组更改,则这不适用;在这种情况下,git/mercurial可能会使您的工作更轻松。
速度
众所周知,git和mercurial比svn快,特别是因为它们的设计允许在本地执行许多操作。
查看旧的东西:在svn中查看更改历史意味着svn必须连接到远程存储库并查看那里;在(例如)git中,历史通常在svn建立连接之前显示。
依赖于操作系统:Git的许多优化主要应用于Linux;比如说,在Windows上,您可能会遇到更糟糕的性能。我不知道,其他竞争者的情况可能也一样。
传输:git和mercurial在几乎任何场景中发送和接收新更改的速度都比svn快得多。
结论:如果你喜欢的东西快,git和mercurial比较好。在windows上,mercurial可能是一个更好的选择,但是如果您想确定,请咨询/执行实际的基准测试。
数字视频监控系统
Git和Mercurial允许开发人员继续处理他们的事情,并将他们组织成一组合理的提交,即使他们当前没有连接到您的网络。在svn中,提交只能在服务器上完成的同时进行,因此svn用户倾向于使用更单一(因此更难理解)的提交。另一方面,至少git甚至有一个工具可以使用二进制搜索快速找到引入bug的提交。再说一次,SVN可能会从底部出来。
复杂性
我是git的超级粉丝,我很容易同意git不是最方便用户的风投,至少如果你不了解它的设计的话。对于更高级的用例,我相信工具链可以弥补这一点;在您的例子中,您可能更喜欢Mercurial或SVN,除非您希望将来在更复杂的项目中使用相同的VCS。
工具、接口
我不太了解水星,所以我不太熟悉它的界面。事实上,我也没有为git使用任何华丽的shmancy接口,但我相信对于所有竞争者来说,有很多工具允许基本使用,比如说,不喜欢命令行的人。不过,我强烈建议您在对团队进行任何特定测试之前,先进行一系列小测试。
你的问题
对于不同的系统,存储库的结构往往不同。在svn中,在同一个存储库中有一大堆项目是可以的;git和mercurial强烈希望每个项目有一个存储库。对于共享代码,git至少有三个工具(其中两个是第三方)用于使用外部存储库,mercurial可能也有一些东西。我知道SVN也有类似的东西。
如果您将它们作为单独的存储库进行管理,我可能会推荐git或mercurial,因为正如前面所说的,它们每个存储库的开销往往较少。
如果使用任何更大的linux发行版,在服务器上安装git/mercurial/svn可能很容易;几乎可以肯定的是,有现成的软件包。如果您预期必须使用不同的每个用户访问控制来管理多个存储库,那么git有一个很好的管理系统gitolite。如果没有类似的事情,管理几个存储库可能会有点麻烦。
关于svn - 本地服务器的SVN,GIT或Mercurial,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5793734/
在做了一些重构之后,在 Eclipse 中,Subversion 在提交时开始提示。我不知道如何解决它。我已经设法删除(并提交了删除 GPFragmentRef.java 。 >niclas@nl:~
我想找出我与前一段时间合并的内容(我只是忘记了),而我的印象是“ svn propget svn:mergeinfo”将打印此类信息。 我正在与进行合并的计算机不同的计算机上运行此计算机。 有任何想法
我要求我的一个开发人员为每个开发人员提供一个不同的主干副本,以便在/branches 中工作(以他们自己的名义)。 该开发人员在颠覆方面没有经验(我也没有),所以我试图通过将主干复制到每个分支文件夹并
我已经使用 git-svn 从工作中克隆了一个 SVN 存储库。在初始克隆期间,我提供了一个 SVN 作者文件。当我进行初始克隆时,git 将 authorsfile 设置为绝对路径。但是,我在工作机
我试图了解常规 svn://和 svn+ssh://访问在颠覆存储库安全性方面的差异。 我已经在自定义端口和 IP 地址中设置了我的 subversion 存储库,并在防火墙上打开了相同的端口,并将存
好吧,我知道这是一个贫民窟设置,但至于为什么,它只是“那些东西”中的另一个。 这是设置。 在 subversion 中,我在一个 repo 中有两个项目: svn/path/projectA svn/
我们目前遇到包含空白的目录问题,这些目录是 svn auth 文件中规则的一部分。所以我们想要基于路径的授权,并且有一个包含以下内容的文件: [/] * = rw [/junk of me] * =
我目前在一台服务器上使用一个 svn 存储库,但为了使其更安全。我在另一台服务器上设置了另一个 svn 存储库,如何使用主服务器上 svn 中的信息镜像辅助服务器上的 svn? 最佳答案 您可以使用
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 4 年前。 Improve this qu
最近我对本地 svn 配置文件进行了一系列更改。我主要纠正了大约 15 种不同文件类型的 svn:mime-type 属性。现在我需要根据这个新配置重置所有以前 checkin 的文件。 SVN 似乎
我最近获得了一个新职位,发现他们没有版本控制。 我将大部分时间花在 Visual Studio 上,过去我使用过(由以前的公司预装)AnkhSVN 和 Visual SVN,他们都使用 Visual
有没有办法恢复svn repo的结帐? 我不小心检查了用户文件夹中的大量代码库,手动删除所有内容真的很痛苦,有没有办法删除工作副本? 有没有类似 svn autoclean ? 最佳答案 SVN 并不
我们想将我们的代码从本地 SVN 服务器移动到托管解决方案,我们应该如何将代码复制并重新导入到托管 SVN 服务器。主要问题是我们不想在重新导入时指向旧的 svn 数据文件。 最佳答案 我认为 svn
我创建了一个分支,然后对需要合并到分支中的主干进行了更改。 TortoiseSVN 有一个非常方便的合并分支->主干实用程序,但是要这样做,我是否必须手动合并特定的修订范围? 最佳答案 使用 SVN
是否有一种简单的方法可以将目录从一个存储库复制到另一个存储库并复制所有历史记录? 最佳答案 最简单的方法是使用: svnadmin dump path/to/repos > repos.out 这将为
我在 Linux 机器上有 3 个 svn 存储库 Main Project -trunk -branches -tags Project A -trunk -branches
我需要使用 SVN 的一些功能,如分支、历史记录、还原、修订我的本地代码副本,但我只想在某个时候提交到服务器存储库,当我完成本地开发时。有可能吗?谢谢。 最佳答案 这就是 Subversion 的模型
我已经用 svn merge -r COMMITTED:PREV 恢复了我最后一次意外的 SVN 提交。 看起来文件现在没问题了,但我仍然在 svn 日志中看到那个意外提交. 还好吗?我可以从历史记录
我正在寻找一种自动将工作副本中的所有未版本控制文件“svn add”到我的 SVN 存储库的好方法。 我有一个实时服务器,可以创建一些应该受源代码控制的文件。我想要一个简短的脚本,我可以运行它来自动添
我有一个 SVN 项目的只读访问权限。我检查了该项目,现在我想处理本地副本(并希望一路对其进行版本控制,但我不能在同一个 SVN 中,因为我没有访问权限,而是我刚刚创建了一个分支)所以,我创建了一个新
我是一名优秀的程序员,十分优秀!