Set up a database for ScalarDB/ScalarDL deployment on Azure
This guide explains how to set up a database for ScalarDB/ScalarDL deployment on Azure.
Azure Cosmos DB for NoSQL
Authentication method
When you use Cosmos DB for NoSQL, you must set COSMOS_DB_URI
and COSMOS_DB_KEY
in the ScalarDB/ScalarDL properties file as follows.
scalar.db.contact_points=<COSMOS_DB_URI>
scalar.db.password=<COSMOS_DB_KEY>
scalar.db.storage=cosmos
Please refer to the following document for more details on the properties for Cosmos DB for NoSQL.
Required configuration/steps
Create an Azure Cosmos DB account
You must create an Azure Cosmos DB account with the NoSQL (core) API. You must set the Capacity mode as Provisioned throughput when you create it. Please refer to the official document for more details.
Configure a default consistency configuration
You must set the Default consistency level as Strong. Please refer to the official document for more details.
Optional configurations/steps
Configure backup configurations (Recommended in the production environment)
You can configure Backup modes as Continuous backup mode for PITR. Please refer to the official document for more details.
It is recommended since the continuous backup mode automatically and continuously gets backups so that we can reduce downtime (pause duration) for backup operations. Please refer to the following document for more details on how to backup/restore the Scalar product data.
Configure monitoring (Recommended in the production environment)
You can configure the monitoring of Cosmos DB using its native feature. Please refer to the official document for more details.
It is recommended since the metrics and logs help you to investigate some issues in the production environment when they happen.
Enable service endpoint (Recommended in the production environment)
You can configure the Azure Cosmos DB account to allow access only from a specific subnet of a virtual network (VNet). Please refer to the official document for more details.
It is recommended since the private internal connections not via WAN can make a system more secure.
Configure the Request Units (Optional based on your environment)
You can configure the Request Units of Cosmos DB based on your requirements. Please refer to the official document for more details on the request units.
You can configure Request Units using ScalarDB/DL Schema Loader when you create a table. Please refer to the following document for more details on how to configure Request Units (RU) using ScalarDB/DL Schema Loader.
Azure Database for MySQL
Authentication method
When you use Azure Database for MySQL, you must set JDBC_URL
, USERNAME
, and PASSWORD
in the ScalarDB/ScalarDL properties file as follows.
scalar.db.contact_points=<JDBC_URL>
scalar.db.username=<USERNAME>
scalar.db.password=<PASSWORD>
scalar.db.storage=jdbc
Please refer to the following document for more details on the properties for Azure Database for MySQL (JDBC databases).
Required configuration/steps
Create a database server
You must create a database server. Please refer to the official document for more details.
You can choose Single Server or Flexible Server for your deployment. However, Flexible Server is recommended in Azure. This document assumes that you use Flexible Server. Please refer to the official documents for more details on the deployment models.
Optional configurations/steps
Configure backup configurations (Optional based on your environment)
Azure Database for MySQL gets a backup by default. You do not need to enable the backup feature manually.
If you want to change some backup configurations like the backup retention period, you can configure it. Please refer to the official document for more details.
Please refer to the following document for more details on how to backup/restore the Scalar product data.