Azure Cosmos Db 介绍及演示
Azure Cosmos DB 是 Microsoft 提供的全球分布式多模型數(shù)據(jù)庫服務(wù)。Cosmos DB是一種NoSql數(shù)據(jù)庫,但是它兼容多種API。它支持SQL, MongoDB、Cassandra或 Gremlin,你可以挑選自己喜歡的方式進(jìn)行存儲跟訪問。
主要優(yōu)勢
統(tǒng)包式全局分發(fā)
憑借 Cosmos DB,你可以在全球范圍內(nèi)生成具有高響應(yīng)性和高可用性的應(yīng)用程序。無論用戶身處何處,Cosmos DB 均可以透明方式復(fù)制數(shù)據(jù),因此用戶可以與離他們最近的數(shù)據(jù)副本進(jìn)行交互。憑借 Cosmos DB,還可以隨時(shí)向 Cosmos 帳戶添加或刪除任何 Azure 區(qū)域,只需單擊一個(gè)按鈕即可。Cosmos DB 將無縫地將數(shù)據(jù)復(fù)制到與 Cosmos 帳戶相關(guān)聯(lián)的所有區(qū)域,同時(shí),得益于該服務(wù)的多導(dǎo)功能,應(yīng)用程序?qū)⒗^續(xù)保持高可用性。有關(guān)詳細(xì)信息,請參閱全局分發(fā)一文。
AlwaysOn
憑借與 Azure 基礎(chǔ)結(jié)構(gòu)和透明多主數(shù)據(jù)庫復(fù)制的深度集成,Cosmos DB 可為讀寫操作提供 99.999% 的高可用性。Cosmos DB 還提供以編程方式(或通過門戶)調(diào)用 Cosmos 帳戶的區(qū)域性故障轉(zhuǎn)移的功能。此功能有助于確保應(yīng)用程序能夠在發(fā)生區(qū)域性災(zāi)難時(shí)進(jìn)行故障轉(zhuǎn)移。
吞吐量和存儲的彈性可伸縮性(全球范圍內(nèi))
Cosmos DB 采用透明的水平分區(qū)和多主數(shù)據(jù)庫復(fù)制設(shè)計(jì),在全球范圍內(nèi)為讀寫操作提供了前所未有的彈性可伸縮性。通過單個(gè) API 調(diào)用即可在全球范圍內(nèi)從數(shù)千個(gè)請求/秒擴(kuò)展到數(shù)億個(gè)請求/秒,并且只需為所需吞吐量(和存儲)付費(fèi)。此功能有助于處理工作負(fù)載中的意外峰值,而無需為意外峰值進(jìn)行過度預(yù)配。有關(guān)詳細(xì)信息,請參閱 Cosmos DB 中的分區(qū)、容器和數(shù)據(jù)庫上的預(yù)配吞吐量以及全局縮放預(yù)配的吞吐量。保證第 99 個(gè)百分位為低延遲(全球范圍內(nèi)) 使用 Cosmos DB,可以生成響應(yīng)迅速、具全球規(guī)模的應(yīng)用程序。憑借其新穎的多主數(shù)據(jù)庫復(fù)制協(xié)議、免閂鎖及優(yōu)化了寫入的數(shù)據(jù)庫引擎,,Cosmos DB 可保證全球任意位置第 99 個(gè)百分位的讀取(已編入索引)和寫入延遲均低于 10 毫秒。此功能可以為高響應(yīng)能力的應(yīng)用持續(xù)引入數(shù)據(jù),并提供快速查詢。
精確定義的多個(gè)一致性選擇
在 Cosmos DB 中構(gòu)建全球分布式應(yīng)用程序時(shí),不再需要在一致性、可用性、延遲和吞吐量之間進(jìn)行極端的權(quán)衡。Cosmos DB 的多主數(shù)據(jù)庫復(fù)制協(xié)議經(jīng)過精心設(shè)計(jì),為一個(gè)直觀的編程模型(其低延遲和高可用性適用于全球分布式應(yīng)用程序)提供五個(gè)明確定義的一致性選擇 - “強(qiáng)”、“有限過期”、“會話”、“一致前綴”和“最終” 。
無需架構(gòu)或索引管理
對于全球分布式應(yīng)用來說,讓數(shù)據(jù)庫架構(gòu)和索引與應(yīng)用程序架構(gòu)保持同步尤其不便。借助 Cosmos DB,則無需處理架構(gòu)或索引管理。數(shù)據(jù)庫引擎完全與架構(gòu)無關(guān)。由于不需要架構(gòu)和索引管理,因此遷移架構(gòu)時(shí)也不必?fù)?dān)心應(yīng)用程序停用時(shí)間。Cosmos DB 自動為所有數(shù)據(jù)編制索引,并可快速提供查詢服務(wù)。
以上內(nèi)容摘自Azure Cosmos文檔
創(chuàng)建Cosmos DB資源
在portal控制面板找到Cosmos點(diǎn)擊創(chuàng)建。
跟別的資源一樣填寫一個(gè)賬戶名,選擇一個(gè)離自己近的位置。API選擇MongoDB API。Apply Free Tier Discount選擇Apply。這樣就能開啟免費(fèi)額度了。
Cosmos DB的免費(fèi)額度為:5G存儲,400請求單位/秒。
復(fù)制Mongodb連接字符串
左側(cè)菜單選擇“連接字符串”,復(fù)制主連接字符串內(nèi)容,下面會用到。
使用Mongodb API操作數(shù)據(jù)庫
因?yàn)镃osmos支持mongodb協(xié)議,所以我們操作Cosmos的時(shí)候直接把Cosmos當(dāng)做mongodb來使用就可以。下面代碼演示了如何使用nodejs的mongodb驅(qū)動來操作Cosmos DB。
var MongoClient = require('mongodb').MongoClient; var assert = require('assert'); var ObjectId = require('mongodb').ObjectID; var endpoint = 'mongodb://'; var collectionName = "students"; //新增一個(gè)json文檔 var insert = function(db, callback) {db.collection(collectionName).insertOne( {"id": "S001","lastName": "zhou","birthday": "2019-09-09","sex": "m","classId": 0}, function(err, result) {assert.equal(err, null);console.log("Inserted a document into the students collection.");callback();});};//把collection里的數(shù)據(jù)都查出來var find = function(db, callback) {var cursor =db.collection(collectionName).find( );cursor.each(function(err, doc) {assert.equal(err, null);if (doc != null) {console.dir(doc);} else {callback();}});};//修改S001的lastNamevar update = function(db, callback) {var myquery = { "id": "S001" };var newvalues = { $set: {lastName: "li"} };db.collection(collectionName).updateOne(myquery,newvalues,function(err, results) {console.log(results);callback();});};//移除lastName為li的內(nèi)容var remove = function(db, callback) {db.collection(collectionName).deleteMany({ "lastName": "li" },function(err, results) {console.log(results);callback();});};MongoClient.connect(endpoint, function(err, client) {assert.equal(null, err);var db = client.db('school');insert(db, function() {console.log('insert success .');find(db, function() {console.log('find success .');update(db, function() {console.log('update success .');remove(db, function(){console.log('remove success .');})});})});});總結(jié)
Azure Cosmos DB是微軟基于Azure開發(fā)的一款NoSql數(shù)據(jù)庫,它支持多種數(shù)據(jù)庫API。比如按SQL方式查詢,按MongoDB方式讀寫等。如果你有海量文檔數(shù)據(jù)需要存儲及查詢,你可以把它存儲在Azure Cosmos DB上,由Azure來為你提供低延時(shí)、高吞吐量以及高達(dá)99.999%的SLA服務(wù),而你只需要挑選自己喜歡的方式來進(jìn)行它完成自己的業(yè)務(wù)。
關(guān)注公眾號玩轉(zhuǎn)技術(shù)
總結(jié)
以上是生活随笔為你收集整理的Azure Cosmos Db 介绍及演示的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Azure App Service 健康
- 下一篇: 大改革,GNOME 3.x将直接跳到GN