写点什么

Terracotta 近况:转向开源,接受度,Hibernate 支持

  • 2007-10-26
  • 本文字数:2263 字

    阅读完需:约 7 分钟

Terracotta 提供一种 JVM 集群方案,可让单节点、多线程的应用变成分布式、多节点的应用,而无需修改一行代码。InfoQ 之前报道过,得到 VC 支持的 Terracotta 在 2006 年底转向开源,从那以来已经有了很大的进展。最近的新进展包括 2.4 版支持 Websphere 和 Hibernate,以及 Terracotta 获得了大量用户的接受,如 PartyGaming(PartyPoker.com 的制造者)。InfoQ 就开源转变以及 Hibernate/Websphere 支持访问了 Ari Zilka。

据 Ari 说,这一年中成长速度大大加快,夏天的时候论坛贴子数量翻了一番,网站每周的访问量达到几千,超过 100 个客户部署了他们的产品。“与开源产品和框架如 Jetty、Geronimo、Spring 和 Tomcat 集成用的 Terracotta 集成模块起到了加速的作用”。至于转向开源对公司的成长有何影响: > 我们相信开源是重要的催化剂,有两个原因。首先,它降低了用户接受的成本,也降低了我们公司的销售成本。顾客现在自己完成整个概念验证过程,看过 Terracotta 在他们的应用中的使用效果,然后找我们谈企业购买的事情。这非常有助于我们保持较低的开销。这对顾客也很好,因为他们只需要投入一点时间就可以得出价值命题的结论。第二,开源是一个强烈的信号——开放源码是表明自身可靠程度的强列信号,表明你知道自己的产品是优秀的,并且可以经受住详尽的技术检查。我们相信在引入像 Terracotta 这样一种全新概念的时候,开源的影响会特别有价值。

从由 VC 支持的商业收入模型转向开源模型:

我们和顾客双方的交易成本都降低很多,这也加速了顾客的接受过程,对我们和用户社区都是巨大的利益。不过实际上转变过程并没有人们想象的那么戏剧性。公司的核心工作是制造出能增值的产品,然后想法把产品换成金钱。赚钱这个基本任务并没有改变,更不会消失。开源有利于产生好的产品,但决不是不花钱的。最大的变化是你的首要对手变成了自己,你必须找到方法去支持你的社区同时又赚到钱。我们同样认为这对顾客是很好的事情,因为 Terracotta 不能只提供支持,还被驱使着去发现更多创造性的价值增长点。在未来的几个月中,社区就会明白我们的意思。

Terracotta 最近公布了一些值得注意的新客户,包括在线赌博公司 PartyGaming、实时 RIA 框架 Kaazing,以及开源 CMS 开发商 Liferay。PartyGaming 经营 PartyPoker.com、PartyCasino.com、PartyBets.com 和 PartyBingo.com。他们的 Terracotta 部署包括几百台游戏服务器组成的集群。PartyGaming 的 CEO 说,“Terracotta 有能力组建数百台服务器的集群,同时网络使用率比其他方式低很多,由此带来的高性能是 PartyGaming 最主要的考虑。”

在今年夏天,Terracotta 2.4 加入了对 WebSphere 和 Hibernate 的支持。Ari 介绍说,Hibernate 支持包括了两种方式:

  • 用集群化的 EHCache 在 Hibernate 底下完成二级缓存的工作。如果现有的应用只打算用集群化数据库缓存的方式降低数据库负载,就采用这种方案。
  • 在集群和 Hibernate Session 之间无缝地断开连接以及重新连接 POJO,以此来实现 Hibernate 的 POJO 缓存。我们的 POJO 集群化成了 Hibernate 的代理……这很适合新的应用(或者改造现有应用),因为 POJO 集群化通过细致的字段级更新,能达到更高的性能。

Terracotta 的字段级更新检测 / 缓存,比 Hibernate 的机制有何优点:

在 POJO 集群化的方式中,发送的数据比较少,调用 Hibernate 和数据库的频率也比较低,因此伸缩性好一点。它也好过散落在代码中的 Hibernate 的 load() 和 store() 调用……对于二级缓存,如果你在程序的其他部分为 Session 和 POJO 使用了 Terracotta,使用 Terracotta + EHCache 的主要好处是获得单一的集群化提供者。否则 Hibernate 二级缓存基本上是对数据库行的定制序列化,一个字段对应到缓存里就成了一整行——所有缓存提供者都是这样的(顺便一提,这个例子说明了在缺少 DSO 的情况下,人们——在这里是 Gavin King——被迫做什么样的变通)。

Terracotta 2.4 还支持 java.util.concurrent 中的再入(re-entrant)读写锁:

在 2.4 之前,Terracotta 在集群中的锁机制,比线程在单个 JVM 中所能支持的锁机制更加智能。由于 JVM 的锁语义是悲观和排他的,因此当把协调关系放到 Terracotta 中实现,我们就能够在集群中提供更多的支持。如果开发者想让线程池的范围从单机扩展到集群,抑或只想实现有些线程读有些线程读写的业务逻辑,再入(re-entrant)读写锁将会以纯粹 POJO 的风格,提升集群中每个 JVM 的速度。concurrentHashMap 与 hashmap 的对比就是一个例子。java.util.concurrent 中的集合的并发性是通过再入读写锁实现的,现在已经得到 Terracotta 2.4 的原生支持。性能又提高了!

Ari 仿照 Network Attached Storage 的说法(或 Azul 所说的 Network Attached Processing),把 Terracotta 定位成“Network Attached Memory”。Ari 说:

这是有意的。NAS 的意图是简化文件 I/O 的编程,以及支持透明地注入高可用性(HA),还有运行时可伸缩的存储能力。Terracotta 设计时就考虑了全面的 HA(n+m 冗余度——你可以有任意多的备份,不停机的持续升级,等等)。其重要性在于,虽然应用各有不同,HA 和伸缩性必须以一致的方式来达成,这样 IT 部门才能为业务部门提供低成本的稳固的应用。换言之,HA/ 伸缩性是一种全局的需要,而 Terracotta 就正好是设计来为 Hotspot 和 IBM JRE 提供这样的能力。

Terracotta 的更多信息可以查阅 InfoQ 以往的新闻报道和技术文章: http://infoq.com/terracotta

查看英文原文: Catching up with Terracotta: Transition to Open Source, Adoption, Hibernate Support

2007-10-26 11:134428
用户头像

发布了 225 篇内容, 共 65.4 次阅读, 收获喜欢 50 次。

关注

评论

发布
暂无评论
发现更多内容

Data For AI:2025年数据集成技术趋势预测

白鲸开源

数据同步 数据集成 数据管道

聆听三位开发者的故事:从破到立,00 后开发者的 Web3 创业“变形计”

TinTinLand

某讯面试中常见的Java集合面试题

王中阳Go

Java 集合 面试问题 后端】

某讯面试中常见的Java多线程面试题

王中阳Go

Java 多线程 面试问题 后端】

Proxifier for Mac(全局代理客户端)

Mac相关知识分享

Starknet Bounty 活动倒计时 48H!赶快报名,加入开发实战之旅

TinTinLand

AICon演讲实录 | 谢皓:AI Agent 在边缘云的探索与实践

火山引擎边缘云

边缘计算 智能硬件 AI 大底座 Agents 边缘智能

怎么制作情绪板?10个情绪板案例盘点!

职场工具箱

设计 设计师 在线白板 办公软件 可视化展示

Lightroom Classic 2021 for mac(LRC 2021大师版)

Mac相关知识分享

实力!云起无垠入选中国信通院《数字安全护航技术能力全景图》

云起无垠

微软开源超强小模型 Phi-4,超 GPT-4o、可商用;HeyGen 集成 Sora 推全新数字人技术

声网

2024数据库编程大赛冠军挑战赛,5位选手用DuckDB和Doris挑战成功

NineData

sql Doris NineData 云数据库技术 数据库编程大赛

预测市场平台 Aegis:Al Agent + Web3,为预测市场提供新的动力

股市老人

AI 代理碎片化格局下,哪些具体赛道及项目值得关注

TechubNews

去中心化金融 #人工智能

讯飞星火办公智能体,杜绝职场人的“年会不消停”

脑极体

AI

NineData云原生智能数据管理平台新功能发布|2024年12月版

NineData

oracle DevOps Package 存储过程 NineData

TON 生态增长实战四城巡回压轴站—— 深圳站即将启动

TinTinLand

《CPython Internals》阅读笔记:p61-p75

codists

CPython Internals

📢 2025 First LOOK! CnosDB 新版本 2.4.3.1 发布 📢

CnosDB

AI rust 物联网 时序数据库 CnosDB

TypeScript与JavaScript的区别

秃头小帅oi

探寻工业智慧化新引擎:还得看JNPF呀!!

快乐非自愿限量之名

低代码 物联网

还不会 Cert Manager 自动签发证书?一文掌握

北京好雨科技有限公司

Kubernetes rainbond 云原生‘’ 企业号 2025年1月PK榜

AIGC 新浪潮|Story CN meetups 将于 1 月 10-14 日举办!

TinTinLand

微服务架构中的服务注册与发现有哪些?Zookeeper、Eureka、Nacos、Consul 都有什么区别,实现原理是什么?

码哥字节

微服务 注册中心

Mythical Games: 通过 Polkadot 革新游戏与数字资产所有权

One Block Community

联发科技携手Cocos:推动端侧生成式 AI,为游戏开发注入新动力

科技范儿

官宣!通义灵码 AI 程序员全面上线

阿里云云效

阿里云 云原生 通义灵码

2025,谁会成为 AI Agent 的新入口?|播客《编码人声》

声网

成为敏捷引领者,Scrum中文网PSM课程助你成就ScrumMaster之路

爱吃鱼的小雨

Scrum 敏捷开发 ScrumMaster认证 敏捷培训 PSM

App Uninstaller for Mac(mac软件卸载工具)中文版

Mac相关知识分享

Linux ssh 登录及免密登录

玄兴梦影

Linux 免密登录

Terracotta近况:转向开源,接受度,Hibernate支持_Java_Floyd Marinescu_InfoQ精选文章