BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

Alex Bordei关于扩展NoSQL数据库的建议

| 作者 Srini Penchikala 关注 36 他的粉丝 ,译者 李刚 关注 0 他的粉丝 发布于 2015年1月5日. 估计阅读时间: 3 分钟 | AICon 关注机器学习、计算机视觉、NLP、自动驾驶等20+AI热点技术和最新落地成功案例。

网络性能、虚拟化和测试是在处理NoSQL数据库性能和可扩展性问题时需要考虑的因素。Alex Bordei写了篇关于扩展NoSQL数据库的文章并给出了使用这些数据存储时提高性能的一些建议。他也是专注NoSQL数据库性能优化最佳实践的网站webcast的联合创办者。

Alex介绍了提高NoSQL数据库性能的五个方面。

扩展的线性:仅通过并行化来扩展分布式应用不一定能提高性能。并且当应用规模增加时,硬件价格会以指数方式增长。Alex建议找到水平扩展和垂直扩展之间的最佳平衡点,这样可以在硬件配置价格确定的前提下得到最佳性能。这个配置基于应用设计和为用例选择的NoSQL数据库方案的不同而不同。

测试:了解特定软件栈如何扩展的最佳方法就是测试。你可以在虚拟环境或者裸机云上测试应用,并且这两种方法都可以不用花很多钱或时间的情况下在多台机器上建立测试环境。

内存和CPU资源:内存和CPU细节对于NoSQL数据库的性能和可扩展性非常重要。对于不同规格细节的内存,访问速度变化很大(例如,从1333 MHz到 1866 MHz DIMMs )。对于像Redis或者Couchbase这样的数据库,内存访问速度是非常关键的因素。Alex建议不要假定RAM的速度,而是多关心内存规格的细节。在CPU方面,超线程和在不需要的情况下关闭虚拟化(Intel VT)可以提高性能。

网络性能:网络延迟和吞吐量影响总体配置的性能。对比裸机服务器,虚拟机提供比较低的网络联通性。因此,评估网络性能对于全面提高的数据库方案性能很重要。

NoSQL数据库的虚拟化:虚拟化对于单台机器做多用途提供了灵活性,并对非关键业务数据提供了相当的安全性。遗憾的是它也影响了内存访问速度,而这对于NoSQL数据库很关键。NoSQL和大数据供应商,像Datastax(对Cassandra数据库提供商业化支持)以及Splunk推荐使用裸机来装他们的软件产品。

Alex强调无论软件如何快和可扩展,硬件的每部分的质量都很重要。测试上投入的精力最终会节省你的时间。

查看英文原文:Alex Bordei on Scaling NoSQL Databases


感谢崔康对本文的审校。

给InfoQ中文站投稿或者参与内容翻译工作,请邮件至editors@cn.infoq.com。也欢迎大家通过新浪微博(@InfoQ)或者腾讯微博(@InfoQ)关注我们,并与我们的编辑和其他读者朋友交流。

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我
社区评论

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT