如何让你的内存中的 NoSQL 数据存储适合企业级应用
对于关注用户体验的每一个Web或移动应用而言,基于内存的NoSQL数据存储系统(例如开源的 Redis和Memcached)正在成为事实标准。由
对于关注用户体验的每一个Web或移动应用而言,基于内存的NoSQL数据存储系统(例如开源的 Redis和Memcached)正在成为事实标准。由于性能、可扩展性和可用性面临的诸多挑战,很多大企业已经在试图采用这些数据库系统。
非常幸运的是,现代编程语言(例如Ruby、Node.js、Python等)和开发平台(例如Rails、Sinatra、Django等)已经内置了很多工具和开发库(libraries)。这些工具和开发库能够有效利用内存数据库的高性能和各种操作命令,能够实现当前流行的多种应用项目。
这些开源的示例项目包括作业管理、论坛、实时分析、Twitter克隆、地理位置搜索以及高级缓存等等。
数据库系统的可用性(availability)、可扩展性(scalability)和性能(performance)对于这些项目的成功至关重要。
本文粗略的介绍如何构建企业真正可用的基于内存的NoSQL数据库,包括一些技巧和建议;这些技巧和建议能够解决云端NoSQL数据库管理面临的七大挑战。
1. 可用性无论你做什么,对于你的应用来说数据必须是时刻可用的。这对于内存数据库尤为重要;因为,如果没有得当的措施,当下面的情形发生时你的数据将会部分或全部丢失:
对于情形1和情形2有两种方式来解决;情形3将在稍后讨论。
一旦程序写的频率增加,你会发现应用服务器写入速度远大于复制的速度,尤其是在主节点和复制节 点存在网络拥堵的情形下。一旦这种情况发生,如果数据集大到一定程度,复制节点很有可能永不再 与主节点同步。
1.确保主存储节点一旦失败就立马切换到备用复制节点。这一般基于成熟健壮的看门狗技术 (watchdog),看门狗持续的监控节点,一旦失败就切换到健康的复制节点。
2.对于你的应用程序而言切换过程要尽量透明;最理想的情况是不需要更改任何配置。更高级的解决方案是仅仅修改DNS中存储节点的IP地址,确保修复过程在几秒钟之内完成。
3.自动切换应当基于Quorum并且是完全一致(fully consistent)或最终一致(eventually consistent)的。讨论下面继续:
网络分裂(network splits)在云中频繁发生,对地球上的分布式存储系统而言也是最复杂的问题。一旦发生分裂,应用程序可能只会发现内存数据库的部分节点;同时,每个内存NoSQL数据库节点也很有可能只能发现一部分的其他节点。
为什么说这是一个非常严重的问题呢?如果你的数据库包含一些隐蔽的设计缺陷,当网络分裂发生时,应用程序很可能会写入错误的节点。这意味着,当情况恢复时,应用程序发起的写入就会丢失。这对基于内存的NoSQL数据库来说这是一个非常有意义的话题,因为基于内存的NoSQL数据库每秒的写操作远大于其他的NoSQL数据库系统。
一个设计得当的基于内存的NoSQL是什么样子的呢?很不幸,你只能从下面两个非常糟糕的候选中选择一个:
注意——在今天的市场上并不存在最终一致(eventually consistent)的基于内存的NoSQL数据库,所以只有选项1是可以实际应用的方案。
3. 数据持久化尽管基于内存的NoSQL解决方案提供多种复制选择,你仍需要着重考虑数据持久化和备份,原因如下:
现在你已经确信数据持久化是必要的,在大多数云环境中你应当使用附属在云主机上的存储设备(像AWS的EBS、Azure的Cloud Derive等)。如果你将数据保存在本地硬盘,,当遇到节点故障时你就会丢失数据。
一旦数据得到持久化保存,你最大的挑战将变成:在将改变实时写入到持久化存储的同时保证内存NoSQL数据库的速度。
4. 稳定的性能基于内存的NoSQL数据库(例如Redis和Memcached)的设计目标是:在毫秒延迟内,每秒钟能够处理超过10万个请求。但是,这个数字在云环境下是很难达到的,除非你遵循以下的原则:
5. 网速大多数云主机都配置了一块1Gbps网卡。在基于内存的NoSQL数据库中,该网卡需要完成以下操作:
这很容易成为运行的瓶颈,因此,这里提供一些解决该问题的建议:
6. 可扩展性对于简单的KV(key/value)缓存(例如Memcached或者Redis的简单应用),扩展很少被认为是一个很严重的问题;因为在大多数情况下,这只需要在在服务器列表中增加或删除节点并修改哈希方法。但是,实际经历过该问题的人就会意识到这是一个非常令人痛苦的问题。对于该话题我们有一些建议:
当进行某些复杂操作时,例如 Redis的 UNION 和 INTERSECT 操作,扩展就成为一个真正的问题。这些操作与SQL中的JOIN命令完全一样。在multi-shard架构下,如果不增加一定的的延迟和复杂性这些操作就完全不能实现。应用级别的分片(Sharding)能够解决一定的问题,因为它允许在分片(shard)模式下运行一些复杂的命令。但这需要非常复杂的设计,并且与内存NoSQL数据库的配置密切相关(例如分片的应用必须明确知道每一个主键保存的节点);当遇到扩展时(例如re-sharding)还需要巨大的代码修改和额外开销。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

隨著網路的發展,大數據分析和即時資訊處理成為了企業的重要需求。為了滿足這樣的需求,傳統的關係型資料庫已經不再滿足業務和技術發展的需要。相反,使用NoSQL資料庫已經成為了一個重要的選擇。在這篇文章中,我們將討論SpringBoot與NoSQL資料庫的整合使用,以實現現代應用程式的開發和部署。什麼是NoSQL資料庫?NoSQL是notonlySQL

在現代的網路應用程式開發中,PHP和NoSQL資料庫已經成為了非常受歡迎的技術選擇。在過去,PHP曾被廣泛應用於開發動態網站和Web應用程序,而NoSQL資料庫則是最近才出現的全新的資料儲存技術,它提供了更靈活和可擴展的解決方案。在這篇文章中,我們將會探討PHP和NoSQL資料庫在實際應用上的情況。 PHP是一種伺服器端程式語言,最初

NoSQL(NotOnlySQL)資料庫是近年來快速發展的一類資料庫,與傳統關係型資料庫相比,具有更好的可擴展性和效能,並支援更多的資料類型和資料儲存方式。其中,MongoDB是一款使用文件資料庫模型的NoSQL資料庫,被廣泛應用於Web應用、行動應用、物聯網設備等領域。本文將介紹如何使用PHP編寫MongoDB資料庫的基本操作,並透過實例示範如何滿足

nosql與mysql的區別是:1、MySQL是一個基於表格設計的關係資料庫,而NoSQL本質上是非關聯式的基於文件的設計;2、MySQL的嚴格模式限制並不容易擴展,而NoSQL可以透過動態模式特性輕鬆擴充等等。

隨著網路的快速發展,數據量也不斷增加。因此,資料管理成為了一個非常重要的課題。 NoSQL(非關聯式資料庫)已成為處理大數據問題的熱門解決方案之一。而Redis又是一款十分流行的NoSQL資料管理軟體。本文將分析比較Redis和其他NoSQL資料庫之間的異同點,幫助理解它們的特徵和優缺點。一、Redis概述Redis是一個基於記憶體的儲存系統,允許使用者使

隨著網路的發展,資料量越來越大,要對這些資料進行有效的儲存和處理變得尤為重要。 NoSQL(NotOnlySQL)資料庫因其高效能、可擴展性和便利性而備受關注,相比傳統的關聯式資料庫,它們更加靈活,適用於各種不同的資料處理場景。 MongoDB是一款非常受歡迎的NoSQL資料庫,在Java開發中也常被使用。本文將介紹在JavaAPI開發中

Couchbase是一個受歡迎的快取技術,提供高效能、可擴展性和可靠性,是許多企業和組織的首選解決方案。本文將詳細介紹Couchbase快取技術的原理、優勢以及應用情境。 Couchbase快取的原理Couchbase快取技術基於分散的NoSQL資料庫,能夠支援多個節點的並發操作,同時實現了資料的高可用性和可擴展性。 Couchbase中的資料使用記憶體進行緩存,

在PHP中連接NoSQL資料庫:MongoDB:使用MongoDB\Client類別;Redis:使用Redis類別;Elasticsearch:使用Elasticsearch\ClientBuilder類別。使用Redis快取WordPress頁面:建立一個Redis用戶端;定義一個過濾函數來檢查快取中是否存在頁面;如果存在,則輸出快取頁面;否則,輸出原始頁面並將其快取起來;啟用快取過濾。
