Perforce值得吗? - java

Improve this question

我的一位同事对PerForce的可能性感到非常兴奋(我们基本上需要有能力在逻辑上对补丁和更改进行分组,并且获得SCM的本地支持会非常好)。我们目前使用CVS,并且对所有可能性开放。我们只有很少的开发人员使用纯Eclipse并使用ant脚本运行构建。

在跳入水中之前,我想听听其他人,他们出于技术原因可以说“好主意”或“坏主意”。我也想听听这对您的日常工作有多大干扰。

编辑2011:仅作记录。我们迁移到git-决定性的因素是我们使用Eclipse,而eclipse.org则是git,因此最终可以期望非常好的IDE集成。我们还有些早-直到今年夏天Eclipse 3.7。今天,git在Eclipse中可以很好地工作。

EDIT 2015:事实证明,由于github和通用的IDE支持以及与Maven的结合,最终git成为了无可争议的赢家,最终使Java项目与IDE无关。

参考方案

2011年11月更新:

出于多种原因(去中心化,私有提交,分支,合并等),使用gitt作为forcefully advocated的Tilo显然是更好的选择。
我完全了解集中式和分散式VCS之间的差异,如“Describe your workflow of using version control (VCS or DVCS)”中所述。

但是,在大型企业中使用并不容易
我知道。我在一个大型企业中介绍了Git:
我在“ Can we finally move to DVCS in Corporate Software? Is SVN still a 'must have' for development? ”中介绍了一般原因(尽管仍然说DVCS是非常有效的选择)

但是我确实在“ Distributed Version Control Systems and the Enterprise - a Good mix? ”中详细介绍了在企业中安装Git的主要痛点。
实际上,我已经在最新的CodeKen 2011 (replacing the ex-DevDays 2011)中介绍了这些痛点。
该演示文稿称为“Introducing DVCS in a big corporation”,其推文口才雄辩:

  • Grundlefleck:我的摘要:不能简单地混入企业
  • ben_sim:@VonC_重新定义了#codeken2011的痛苦:重新编译git及其所有依赖项,以便可以在企业的生产服务器上使用它。
  • DVCS的诀窍是:您仍然需要一个“服务器”,这是所有开发人员获得其仓库的“加福”版本的集中位置。
    在一家大公司中,那些相互关联的服务器是相互关联的……已经有很多其他服务正在运行,这意味着您不能仅在其上添加Git(在该服务器上没有正确的库)。
    另外,您将需要自己的ssh和httpd,以便用户将其推入/拉出该服务器。

    实际上,我已经在GitHub project compileEverything中自动完成了Git及其所有依赖项/相关服务的安装过程。

    所以,是的,使用Git。
    在客户端PC上,您可以在几分钟内安装并开始使用它!
    但是在大型企业的服务器上?这不是那么容易。

    记得2009年:

  • Windows上可能支持Git,但仍在进行中,
  • Git本身不包括“smart http”,这意味着ssh / clone和push操作具有身份验证的唯一协议是ssh:说服用户生成和管理公钥/私钥是……至少可以说是有问题的。
    即使请求效率很低,也可以使用Https进行拉取和克隆。为了进行推送...安装涉及WebDAV,非常复杂。 Smart Http改变了这一切。
  • 授权层很笨重(gitosis),而gitolite才刚刚开始。
    在大型企业中,您需要一个授权层。
    并非任何用户都可以访问任何存储库,其中一些所述存储库是非常机密的。
  • 最初的答案,可以追溯到2009年:

    在公司内部,在封闭的集中式环境中,Perforce当然是一个不错的选择。
    它确实可以快速签出您的工作区,并很好地管理变更集。
    它支持“默认情况下锁定”,有助于查看谁在同一文件上工作。

    但是,您必须始终与P4服务器同步,并且应该具有适当的基础架构来支持它,包括备份和DRP方案:如果没有服务器,并且继续工作,例如删除文件,不会在后续更新中恢复。

    我从使用它的团队中听到的主要抱怨(因为我只对该工具执行了一些管理任务)是“Inter-File Branching”的概念,起初有点令人困惑,但非常有用。

    根据Perforce with your IDE (here eclipse)和编辑器的集成级别,主要的侵入方面是确保工作空间保持同步。

    其他有趣的链接供您阅读:

  • What are the advantages to Perforce?
  • What are the benefits of using Perforce instead of Subversion?
  • Eclipse WTP部署的构建路径依赖项 - java

    我有一个依赖于其他项目(项目属性/ Java Build Path /项目)的Eclipse项目,而这些其他项目导出它们自己的库(项目属性/ Java Build Path / Order和Export)。有没有办法让Eclipse WTP和/或JBoss工具在部署中包括从属项目的导出文件?我可以通过Deployment Assembly单独添加jar,但是…

    Java:线程池如何将线程映射到可运行对象 - java

    试图绕过Java并发问题,并且很难理解线程池,线程以及它们正在执行的可运行“任务”之间的关系。如果我创建一个有10个线程的线程池,那么我是否必须将相同的任务传递给池中的每个线程,或者池化的线程实际上只是与任务无关的“工人无人机”可用于执行任何任务?无论哪种方式,Executor / ExecutorService如何将正确的任务分配给正确的线程? 参考方案 …

    JAVA:字节码和二进制有什么区别? - java

    java字节代码(已编译的语言,也称为目标代码)与机器代码(当前计算机的本机代码)之间有什么区别?我读过一些书,他们将字节码称为二进制指令,但我不知道为什么。 参考方案 字节码是独立于平台的,在Windows中运行的编译器编译的字节码仍将在linux / unix / mac中运行。机器代码是特定于平台的,如果在Windows x86中编译,则它将仅在Win…

    java:继承 - java

    有哪些替代继承的方法? java大神给出的解决方案 有效的Java:偏重于继承而不是继承。 (这实际上也来自“四人帮”)。他提出的理由是,如果扩展类未明确设计为继承,则继承会引起很多不正常的副作用。例如,对super.someMethod()的任何调用都可以引导您通过未知代码的意外路径。取而代之的是,持有对本来应该扩展的类的引用,然后委托给它。这是与Eric…

    Java:BigInteger,如何通过OutputStream编写它 - java

    我想将BigInteger写入文件。做这个的最好方式是什么。当然,我想从输入流中读取(使用程序,而不是人工)。我必须使用ObjectOutputStream还是有更好的方法?目的是使用尽可能少的字节。谢谢马丁 参考方案 Java序列化(ObjectOutputStream / ObjectInputStream)是将对象序列化为八位字节序列的一种通用方法。但…