{"id":660,"date":"2020-05-11T00:00:00","date_gmt":"2020-05-11T00:00:00","guid":{"rendered":""},"modified":"2025-06-29T23:28:47","modified_gmt":"2025-06-30T06:28:47","slug":"office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability","status":"publish","type":"post","link":"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/","title":{"rendered":"Office Licensing Service and Azure Cosmos DB part 2: Improved performance and availability"},"content":{"rendered":"\n<p class=\"wp-block-paragraph\"><i>This post is part 2 of a two-part series about how organizations use Azure Cosmos DB to meet real world needs, and the difference it\u2019s making to them. In <a href=\"https:\/\/azure.microsoft.com\/blog\/office-licensing-service-and-azure-cosmos-db-part-1-migrating-the-production-workload\" target=\"_blank\" rel=\"noopener\">part 1<\/a>, we explored the challenges that led the Microsoft Office Licensing Service team to move from Azure Table storage to Azure Cosmos DB, and how it migrated its production workload to the new service. In part 2, we examine the outcomes resulting from the team\u2019s efforts.<\/i><\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"strong-benefits-with-minimal-effort\">Strong benefits with minimal effort<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">The Microsoft Office Licensing Service (OLS) team\u2019s migration from Azure Table storage to <a href=\"https:\/\/azure.microsoft.com\/en-us\/services\/cosmos-db\/\" target=\"_blank\" rel=\"noopener\">Azure Cosmos DB<\/a> was simple and straightforward, enabling the team to meet all its needs with minimal effort.<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"an-easy-migration\">An easy migration<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">In moving to Azure Cosmos DB, thanks to its Table API, the OLS team was able to reuse most of its data access code, and the migration engine they wrote to avoid any downtime was fast and easy to build.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Danny Cheng, a software engineer at Microsoft, who leads the OLS development team explains:<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><em>\u201cThe migration engine was the only real \u2018new code\u2019 we had to write. And the code samples for all three parts are publicly available, so it\u2019s not like we had to start from scratch. All in all, the migration tooling we developed took three developers about four weeks each.\u201d<\/em><\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"virtually-unlimited-throughput\">Virtually unlimited throughput<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">Today, database throughput is no longer an issue for the OLS team. With Table storage, the team faced a throughput limit of 20,000 operations per second per storage account, which forced them to maintain each of their 18 tables in a different storage account to achieve maximum throughput. The team now maintains one Azure Cosmos DB account, which has no upper limit on throughput and can support more than 10 million operations per second per table\u2014all <a href=\"https:\/\/docs.microsoft.com\/en-us\/azure\/cosmos-db\/request-units\" target=\"_blank\" rel=\"noopener\">dedicated and backed by SLAs<\/a>.<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"guaranteed-high-availability\">Guaranteed high availability<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">Azure Cosmos DB gives the OLS team <a href=\"https:\/\/azure.microsoft.com\/en-us\/support\/legal\/sla\/cosmos-db\/v1_3\/\" target=\"_blank\" rel=\"noopener\">a 99.999 percent read availability SLA for all multi-region accounts<\/a>. This has led to a significant increase in storage quality-of-service (QoS), as illustrated in the following metrics captured using internally developed tooling.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><em>\u201cDuring peak traffic hours, Azure Cosmos DB delivers much better storage QoS than we were seeing with Table storage,\u201d says Cheng. \u201cToday we\u2019re seeing five nines, when in the past we were at about three nines.\u201d<\/em><\/p>\n\n\n\n<figure class=\"wp-block-image has-custom-border\"><img decoding=\"async\" src=\"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2020\/05\/18e09e81-d4de-4303-aefb-701694d996ed.webp\" alt=\"Graph of Azure Cosmos DB health vs Azure Table storage health.  \" style=\"border-radius:0px\" title=\"Graph of Azure Cosmos DB health vs Azure Table storage health.  \" \/><\/figure>\n\n\n\n<figure class=\"wp-block-image has-custom-border\"><img decoding=\"async\" src=\"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2020\/05\/2c066ba3-cace-4746-bba7-71f309990f71.webp\" alt=\"Average Azure Cosmos DB health vs Azure Table storage health. \" style=\"border-radius:0px\" title=\"Average Azure Cosmos DB health vs Azure Table storage health.\" \/><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"automatic-failover\">Automatic failover<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">The OLS team can now configure <a href=\"https:\/\/docs.microsoft.com\/en-us\/azure\/cosmos-db\/high-availability\" target=\"_blank\" rel=\"noopener\">automatic or manual failovers<\/a> to help protect against the unlikely event of a regional outage, with all SLAs maintained. The team can also prioritize failover order for its multi-region accounts and can manually trigger failover to test the end-to-end availability of OLS.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><em>\u201cWe\u2019ve configured automatic failover, but the service is so reliable that we haven\u2019t needed it yet,\u201d says Cheng.<\/em><\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"lower-latency\">Lower latency<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">Table storage provided the OLS team with no upper bounds on latency. In contrast, Azure Cosmos DB provides single-digit latency for reads and writes, backed with a guarantee of &lt;10 millisecond latency for reads and writes at the 99th percentile, at any scale, anywhere in the world. The following metrics illustrate the differences in latency that the OLS service is seeing between Table storage and Azure Cosmos DB. (DbTable is Azure Table storage and CosmosDbTable is the Azure Cosmos DB Table API.)<\/p>\n\n\n\n<figure class=\"wp-block-image has-custom-border\"><img decoding=\"async\" src=\"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2020\/05\/2e4a9658-d476-4845-aae6-ac59a0d7b2d8.webp\" alt=\"Difference in latency: Azure Cosmos DB versus Azure Table storage.\" style=\"border-radius:0px\" title=\"Difference in latency: Azure Cosmos DB versus Azure Table storage.\" \/><\/figure>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"turnkey-data-distribution\">Turnkey data distribution<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">With Table storage, options for global distribution were limited. What\u2019s more, the OLS team couldn\u2019t implement failover on its own. With Azure Cosmos DB, the team now enjoys distribution&nbsp; to any number of regions\u2014including <a href=\"https:\/\/docs.microsoft.com\/en-us\/azure\/cosmos-db\/how-to-multi-master\" target=\"_blank\" rel=\"noopener\">multi-master capabilities<\/a>, which when enabled will let any regions accept write operation.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><em>\u201cJust by clicking on the map, data can be automatically replicated to any Azure region in the world,\u201d says Cheng. \u201cThis feature is very convenient, and we plan to put it to use soon.\u201d<\/em><\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"other-technical-benefits\">Other technical benefits<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">In addition to the above, Azure Cosmos DB provides the OLS team with some additional advantages over Table storage:<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><b>Automatic indexing.<\/b> With Table storage, primary indexes are limited to PartitionKey and RowKey, and there are no secondary indexes. Azure Cosmos DB provides automatic and complete indexing on all properties by default, with no index management.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><b>Faster query times.<\/b> With Table storage, query execution uses the index for the primary key and scans otherwise. With Azure Cosmos DB, queries can take advantage of automatic indexing on all properties for faster query times.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><b>Consistency.<\/b> With Table storage, the OLS team was limited to strong consistency within the primary region and eventual consistency within the secondary region. With Azure Cosmos DB, they can choose from <a href=\"https:\/\/docs.microsoft.com\/en-us\/azure\/cosmos-db\/consistency-levels\" target=\"_blank\" rel=\"noopener\">well-defined consistency levels<\/a>, enabling them to optimize tradeoffs between read consistency and latency, availability, and throughput while they were designing the solution.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"get-started-with-azure-cosmos-db-today\">Get started with Azure Cosmos DB today<\/h2>\n\n\n\n<ul class=\"wp-block-list\">\n<li class=\"wp-block-list-item\">Visit <u><a href=\"https:\/\/azure.microsoft.com\/en-us\/services\/cosmos-db\/\" target=\"_blank\" rel=\"noopener\">Azure Cosmos DB<\/a><\/u>.<\/li>\n\n\n\n<li class=\"wp-block-list-item\">See <a href=\"https:\/\/docs.microsoft.com\/en-us\/azure\/cosmos-db\/table-introduction\" target=\"_blank\" rel=\"noopener\">Introduction to Azure Cosmos DB Table API<\/a>.<\/li>\n<\/ul>\n","protected":false},"excerpt":{"rendered":"<p>This post is part 2 of a two-part series about how organizations use Azure Cosmos DB to meet real world needs, and the difference it\u2019s making to them.<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"ms_queue_id":[],"ep_exclude_from_search":false,"_classifai_error":"","_classifai_text_to_speech_error":"","_alt_title":"","footnotes":"","msx_community_cta_settings":[]},"categories":[1473,1485],"tags":[48],"audience":[3057,3055,3056],"content-type":[1511],"product":[1538],"tech-community":[],"topic":[],"coauthors":[177],"class_list":["post-660","post","type-post","status-publish","format-standard","hentry","category-databases","category-internet-of-things","tag-big-data","audience-data-professionals","audience-developers","audience-it-implementors","content-type-best-practices","product-azure-cosmos-db","review-flag-1-1680286581-825","review-flag-2-1680286581-601","review-flag-anywh-1680286580-635","review-flag-new-1680286579-546","review-flag-percent"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.2 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Office Licensing Service and Azure Cosmos DB part 2: Improved performance and availability | Microsoft Azure Blog<\/title>\n<meta name=\"description\" content=\"This post is part 2 of a two-part series about how organizations use Azure Cosmos DB to meet real world needs, and the difference it\u2019s making to them.\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Office Licensing Service and Azure Cosmos DB part 2: Improved performance and availability | Microsoft Azure Blog\" \/>\n<meta property=\"og:description\" content=\"This post is part 2 of a two-part series about how organizations use Azure Cosmos DB to meet real world needs, and the difference it\u2019s making to them.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/\" \/>\n<meta property=\"og:site_name\" content=\"Microsoft Azure Blog\" \/>\n<meta property=\"article:publisher\" content=\"https:\/\/www.facebook.com\/microsoftazure\" \/>\n<meta property=\"article:published_time\" content=\"2020-05-11T00:00:00+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-06-30T06:28:47+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2020\/05\/18e09e81-d4de-4303-aefb-701694d996ed.webp\" \/>\n<meta name=\"author\" content=\"Parul Matah\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:creator\" content=\"@azure\" \/>\n<meta name=\"twitter:site\" content=\"@azure\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Parul Matah\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"4 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/\"},\"author\":[{\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/author\/parul-matah\/\",\"@type\":\"Person\",\"@name\":\"Parul Matah\"}],\"headline\":\"Office Licensing Service and Azure Cosmos DB part 2: Improved performance and availability\",\"datePublished\":\"2020-05-11T00:00:00+00:00\",\"dateModified\":\"2025-06-30T06:28:47+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/\"},\"wordCount\":798,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/#organization\"},\"image\":{\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2020\/05\/18e09e81-d4de-4303-aefb-701694d996ed.webp\",\"keywords\":[\"Big Data\"],\"articleSection\":[\"Databases\",\"Internet of things\"],\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/\",\"url\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/\",\"name\":\"Office Licensing Service and Azure Cosmos DB part 2: Improved performance and availability | Microsoft Azure Blog\",\"isPartOf\":{\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/#primaryimage\"},\"image\":{\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2020\/05\/18e09e81-d4de-4303-aefb-701694d996ed.webp\",\"datePublished\":\"2020-05-11T00:00:00+00:00\",\"dateModified\":\"2025-06-30T06:28:47+00:00\",\"description\":\"This post is part 2 of a two-part series about how organizations use Azure Cosmos DB to meet real world needs, and the difference it\u2019s making to them.\",\"breadcrumb\":{\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/#primaryimage\",\"url\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2020\/05\/18e09e81-d4de-4303-aefb-701694d996ed.webp\",\"contentUrl\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2020\/05\/18e09e81-d4de-4303-aefb-701694d996ed.webp\"},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Blog home\",\"item\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Databases\",\"item\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/category\/databases\/\"},{\"@type\":\"ListItem\",\"position\":3,\"name\":\"Office Licensing Service and Azure Cosmos DB part 2: Improved performance and availability\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/#website\",\"url\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/\",\"name\":\"Microsoft Azure Blog\",\"description\":\"Get the latest Azure news, updates, and announcements from the Azure blog. From product updates to hot topics, hear from the Azure experts.\",\"publisher\":{\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":\"Organization\",\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/#organization\",\"name\":\"Microsoft Azure Blog\",\"url\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/#\/schema\/logo\/image\/\",\"url\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2024\/06\/microsoft_logo.webp\",\"contentUrl\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2024\/06\/microsoft_logo.webp\",\"width\":512,\"height\":512,\"caption\":\"Microsoft Azure Blog\"},\"image\":{\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/#\/schema\/logo\/image\/\"},\"sameAs\":[\"https:\/\/www.facebook.com\/microsoftazure\",\"https:\/\/x.com\/azure\",\"https:\/\/www.instagram.com\/microsoftdeveloper\/\",\"https:\/\/www.linkedin.com\/company\/16188386\",\"https:\/\/www.youtube.com\/user\/windowsazure\"]},{\"@type\":\"Person\",\"@id\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/#\/schema\/person\/c702e5edd662b328b49b7e1180cab117\",\"name\":\"shakir\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/secure.gravatar.com\/avatar\/9342c7c05bb16548741bc5cd3a3e3b7ee0c8e746844ad2cc582db5beb5514c6f?s=96&d=mm&r=g7664e653ea371ce16eaf75e9fa8952c4\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/9342c7c05bb16548741bc5cd3a3e3b7ee0c8e746844ad2cc582db5beb5514c6f?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/9342c7c05bb16548741bc5cd3a3e3b7ee0c8e746844ad2cc582db5beb5514c6f?s=96&d=mm&r=g\",\"caption\":\"shakir\"},\"sameAs\":[\"https:\/\/azure.microsoft.com\"],\"url\":\"https:\/\/azure.microsoft.com\/en-us\/blog\/author\/shakir\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Office Licensing Service and Azure Cosmos DB part 2: Improved performance and availability | Microsoft Azure Blog","description":"This post is part 2 of a two-part series about how organizations use Azure Cosmos DB to meet real world needs, and the difference it\u2019s making to them.","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/","og_locale":"en_US","og_type":"article","og_title":"Office Licensing Service and Azure Cosmos DB part 2: Improved performance and availability | Microsoft Azure Blog","og_description":"This post is part 2 of a two-part series about how organizations use Azure Cosmos DB to meet real world needs, and the difference it\u2019s making to them.","og_url":"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/","og_site_name":"Microsoft Azure Blog","article_publisher":"https:\/\/www.facebook.com\/microsoftazure","article_published_time":"2020-05-11T00:00:00+00:00","article_modified_time":"2025-06-30T06:28:47+00:00","og_image":[{"url":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2020\/05\/18e09e81-d4de-4303-aefb-701694d996ed.webp","type":"","width":"","height":""}],"author":"Parul Matah","twitter_card":"summary_large_image","twitter_creator":"@azure","twitter_site":"@azure","twitter_misc":{"Written by":"Parul Matah","Est. reading time":"4 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/#article","isPartOf":{"@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/"},"author":[{"@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/author\/parul-matah\/","@type":"Person","@name":"Parul Matah"}],"headline":"Office Licensing Service and Azure Cosmos DB part 2: Improved performance and availability","datePublished":"2020-05-11T00:00:00+00:00","dateModified":"2025-06-30T06:28:47+00:00","mainEntityOfPage":{"@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/"},"wordCount":798,"commentCount":0,"publisher":{"@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/#organization"},"image":{"@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/#primaryimage"},"thumbnailUrl":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2020\/05\/18e09e81-d4de-4303-aefb-701694d996ed.webp","keywords":["Big Data"],"articleSection":["Databases","Internet of things"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/","url":"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/","name":"Office Licensing Service and Azure Cosmos DB part 2: Improved performance and availability | Microsoft Azure Blog","isPartOf":{"@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/#primaryimage"},"image":{"@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/#primaryimage"},"thumbnailUrl":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2020\/05\/18e09e81-d4de-4303-aefb-701694d996ed.webp","datePublished":"2020-05-11T00:00:00+00:00","dateModified":"2025-06-30T06:28:47+00:00","description":"This post is part 2 of a two-part series about how organizations use Azure Cosmos DB to meet real world needs, and the difference it\u2019s making to them.","breadcrumb":{"@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/#primaryimage","url":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2020\/05\/18e09e81-d4de-4303-aefb-701694d996ed.webp","contentUrl":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2020\/05\/18e09e81-d4de-4303-aefb-701694d996ed.webp"},{"@type":"BreadcrumbList","@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/office-licensing-service-and-azure-cosmos-db-part-2-improved-performance-and-availability\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Blog home","item":"https:\/\/azure.microsoft.com\/en-us\/blog\/"},{"@type":"ListItem","position":2,"name":"Databases","item":"https:\/\/azure.microsoft.com\/en-us\/blog\/category\/databases\/"},{"@type":"ListItem","position":3,"name":"Office Licensing Service and Azure Cosmos DB part 2: Improved performance and availability"}]},{"@type":"WebSite","@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/#website","url":"https:\/\/azure.microsoft.com\/en-us\/blog\/","name":"Microsoft Azure Blog","description":"Get the latest Azure news, updates, and announcements from the Azure blog. From product updates to hot topics, hear from the Azure experts.","publisher":{"@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/azure.microsoft.com\/en-us\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Organization","@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/#organization","name":"Microsoft Azure Blog","url":"https:\/\/azure.microsoft.com\/en-us\/blog\/","logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2024\/06\/microsoft_logo.webp","contentUrl":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-content\/uploads\/2024\/06\/microsoft_logo.webp","width":512,"height":512,"caption":"Microsoft Azure Blog"},"image":{"@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/#\/schema\/logo\/image\/"},"sameAs":["https:\/\/www.facebook.com\/microsoftazure","https:\/\/x.com\/azure","https:\/\/www.instagram.com\/microsoftdeveloper\/","https:\/\/www.linkedin.com\/company\/16188386","https:\/\/www.youtube.com\/user\/windowsazure"]},{"@type":"Person","@id":"https:\/\/azure.microsoft.com\/en-us\/blog\/#\/schema\/person\/c702e5edd662b328b49b7e1180cab117","name":"shakir","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/secure.gravatar.com\/avatar\/9342c7c05bb16548741bc5cd3a3e3b7ee0c8e746844ad2cc582db5beb5514c6f?s=96&d=mm&r=g7664e653ea371ce16eaf75e9fa8952c4","url":"https:\/\/secure.gravatar.com\/avatar\/9342c7c05bb16548741bc5cd3a3e3b7ee0c8e746844ad2cc582db5beb5514c6f?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/9342c7c05bb16548741bc5cd3a3e3b7ee0c8e746844ad2cc582db5beb5514c6f?s=96&d=mm&r=g","caption":"shakir"},"sameAs":["https:\/\/azure.microsoft.com"],"url":"https:\/\/azure.microsoft.com\/en-us\/blog\/author\/shakir\/"}]}},"msxcm_display_generated_audio":false,"msxcm_animated_featured_image":null,"distributor_meta":false,"distributor_terms":false,"distributor_media":false,"distributor_original_site_name":"Microsoft Azure Blog","distributor_original_site_url":"https:\/\/azure.microsoft.com\/en-us\/blog","push-errors":false,"_links":{"self":[{"href":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-json\/wp\/v2\/posts\/660","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-json\/wp\/v2\/comments?post=660"}],"version-history":[{"count":1,"href":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-json\/wp\/v2\/posts\/660\/revisions"}],"predecessor-version":[{"id":44408,"href":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-json\/wp\/v2\/posts\/660\/revisions\/44408"}],"wp:attachment":[{"href":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-json\/wp\/v2\/media?parent=660"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-json\/wp\/v2\/categories?post=660"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-json\/wp\/v2\/tags?post=660"},{"taxonomy":"audience","embeddable":true,"href":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-json\/wp\/v2\/audience?post=660"},{"taxonomy":"content-type","embeddable":true,"href":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-json\/wp\/v2\/content-type?post=660"},{"taxonomy":"product","embeddable":true,"href":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-json\/wp\/v2\/product?post=660"},{"taxonomy":"tech-community","embeddable":true,"href":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-json\/wp\/v2\/tech-community?post=660"},{"taxonomy":"topic","embeddable":true,"href":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-json\/wp\/v2\/topic?post=660"},{"taxonomy":"author","embeddable":true,"href":"https:\/\/azure.microsoft.com\/en-us\/blog\/wp-json\/wp\/v2\/coauthors?post=660"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}