高性能Scala
编辑推荐
适读人群 :本书适合已经具有Scala编程基础、能够较好地使用Scala风格代码实现业务功能的程序员,作为在性能优化方面的深造阅读资料。 《高性能Scala》将为你武装创建高性能Scala应用所需的知识,从如何定义性能这样的基础知识开始,探索了Scala语言特性及函数式编程技术,同时在所有主题上都密切关注着性能。 我们虚构了一家名为MV的交易公司,你将作为一个新加入这家公司中的软件工程师开始工作。随着不断学习降低延迟提高吞吐量的新技术和新方法,你将会把它们应用到解决MV交易公司的业务问题上。学习完本书之后,你将得到充分的知识储备,能使用函数式编程范式来解决真实世界中的问题,并能编写可以用于生产环境的高性能Scala软件。 √ 通过开发JMH基准测试,以及使用Flight Recorder做profiling去分析JVM应用的性能。 √ 发掘出Scala语言特性的使用场景及性能折衷的情况,了解急切集合及惰性集合。 √ 研究流式处理管道,探索使用事件溯源模式来提升性能。 √ 深入异步编程,使用Scala的Future和Scalaz的Task来榨取多核系统的性能。 √ 利用最终一致性的优势,结合无冲突复制的数据结构(CRDTs)来设计无须同步的分布式系统。 √ 理解队列对系统性能的影响,应用Free monad模式来构建具有高等级吞吐量的健壮的系统。
内容简介
Scala是一种表达能力非常强的语言,能够用非常简洁的代码表达丰富的业务含义。为了在生产上充分发挥Scala的能力,除了掌握其简洁的语法外,理解Scala在性能上的特点和优化点也是非常重要的事。本书通过解析一个金融领域高频交易的实际例子,引领读者掌握如何对Scala程序(以及一般JVM程序)进行基准测试和性能分析,从而找出瓶颈。随后作者介绍了Scala语言、Scala标准库(尤其是集合库)以及Scalaz库里解决相应瓶颈的各种技巧。并行计算和分布式架构作为性能调优的重要手段,更是本书的重中之重,作者对Scala的并行计算和分布式架构中存在的问题都进行了充分的讨论和讲解,非常值得学习。本书适合已经具有Scala编程基础、能够较好地使用Scala风格代码实现业务功能的程序员,作为在性能优化方面的深造阅读资料。
作者简介
杨云,网名大魔头,ThoughtWoks资深咨询师,Scala多年实践者及布道者。发表有多篇Scala相关博客及文章,译有多部Scala技术专著。博客:http://blog.damotou.info。 Vincent Theron是一个拥有 9年工作经验的专业软件工程师。他在 6年前发现了 Scala并将之应用于构建高伸缩性、高可靠的应用。他在多个行业设计软件来解决商业上的问题,包括在线博彩、金融交易,以及昀近的广告行业。在巴黎东部 Marne-la-Vallée,Vincent获得了计算机科学及软件工程硕士学位。他和妻子、孩子以及两只毛茸茸的猫一起在波士顿区域生活。 感谢在 Packt出版社的每一个人,是你们的努力工作才能让这本书面世。感谢柴塔尼亚-耐尔,带着这个出书项目找到我。感谢 Nikhil Borkar,一路上给我提供指引。感谢 Michael Diamant,我的合作作者,我的同事,同时也是朋友,感谢你给这本书带来的知识以及充满灵感的每一天。感谢我的父母,感谢你们的爱和支持,以及你们给我买的*一台电脑。昀后,感谢我的妻子,Julie,感谢你一直的鼓励,感谢你给了我一个这么绝妙的儿子。 Michael Diamant是一个专业的软件工程师,热衷于函数式编程。他在 2009年开始自己的事业,专注于 Java和面向对象的编程范式。在 2011年学习 Scala之后,他专注于使用 Scala和函数式编程范式来构建金融交易和广告领域的软件系统。迈克尔毕业于伍斯特理工学院,居住在波士顿区域。 我能在这本书里面分享的知识来源于他人在我一生中给予的支持和教导。我想要特别感谢我的同事文森特,感谢你推动我付出这些努力,感谢所有在一起的时间,让我们可以发展这些书中的想法。我所有的现在和之前的同事都帮助我提高了工程技术,没有你们慷慨地分享你们的所学,我将不可能编写这本书。除了 Vincent,我还想特别提及一些我觉得尤其想感谢的同事:Dave Stevens、Gary Malouf、Eugene Kolnick和 Johnny Everson。感谢我的父母和兄弟,你们支持我,将我培养成现在的我。我尤其想深深地感谢我的女友 Anna在整个写书过程中给予我的支持。昀后,同样的感谢送给 Packt出版社,在你们的帮助下我们写了我们的*一本书。 关于审阅者 Nermin ?rifovi?是一个从 2009年开始就热衷 Scala的人,他从 2011年开始在专业领域应用 Scala。在大部分工作生涯中,他专注于使用 JVM技术构建后端平台。昀近,作为 Pingup的研发总监,他正在一个本地化服务预订系统上领导开发工作。 Nermin是一个哈佛大学延伸教育学院的导师,他在那里与人合作教授 Scala并行编程的课程,他还在多个学术会议上发表了演讲。 作为一个 Scala社区的活跃会员,Nermin组织了波士顿区域的 Scala爱好者群,同时他也是中东 Scala座谈基金会一员。他是 Scala Puzzlers一书的合作作者,Scala解惑网站的合作创建者。 Nermin拥有康奈尔大学计算机科学硕士学位,他感兴趣的领域包括分布式系统及伴随着的并行,响应式和函数式编程。