-
Notifications
You must be signed in to change notification settings - Fork 246
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Refactor sample_cosmos.azure-spring-data-cosmos (#187)
- Loading branch information
Showing
36 changed files
with
733 additions
and
115 deletions.
There are no files selected for viewing
180 changes: 129 additions & 51 deletions
180
cosmos/azure-spring-data-cosmos/cosmos-multi-database-multi-account/README.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,86 +1,164 @@ | ||
# Azure Spring Boot Sample Cosmos Multi Database Multi Account for Java | ||
|
||
## Key concepts | ||
## Getting started | ||
This guide demonstrates how to use Azure Cosmos DB via `azure-spring-data-cosmos` to store data in and retrieve data from your Azure Cosmos DB. | ||
|
||
## What You Will Build | ||
You will build an application to write data to and query data from Azure Cosmos DB via `azure-spring-data-cosmos`. | ||
|
||
## What You Need | ||
|
||
### Configure Cosmos Database | ||
1. Log into <https://portal.azure.com>. | ||
- [An Azure subscription](https://azure.microsoft.com/free/) | ||
- [Terraform](https://www.terraform.io/) | ||
- [Azure CLI](https://docs.microsoft.com/cli/azure/install-azure-cli) | ||
- [JDK8](https://www.oracle.com/java/technologies/downloads/) or later | ||
- Maven | ||
- You can also import the code straight into your IDE: | ||
- [IntelliJ IDEA](https://www.jetbrains.com/idea/download) | ||
|
||
1. Click `Create a resource`. | ||
## Provision Azure Resources Required to Run This Sample | ||
|
||
1. Input `Azure Cosmos DB`. | ||
### Authenticate Using the Azure CLI | ||
Terraform must authenticate to Azure to create infrastructure. | ||
|
||
1. Click `Azure Cosmos DB` | ||
data:image/s3,"s3://crabby-images/0712e/0712e1a268c540715438b5948d21f8b752e93368" alt="Find Cosmos Resource 01" | ||
In your terminal, use the Azure CLI tool to setup your account permissions locally. | ||
|
||
data:image/s3,"s3://crabby-images/de26a/de26a71cd56c94d7a2df79349ac8557308a4db45" alt="Find Cosmos Resource 02" | ||
```shell | ||
az login | ||
``` | ||
|
||
Your browser window will open and you will be prompted to enter your Azure login credentials. After successful authentication, your terminal will display your subscription information. You do not need to save this output as it is saved in your system for Terraform to use. | ||
|
||
```shell | ||
You have logged in. Now let us find all the subscriptions to which you have access... | ||
|
||
[ | ||
{ | ||
"cloudName": "AzureCloud", | ||
"homeTenantId": "home-Tenant-Id", | ||
"id": "subscription-id", | ||
"isDefault": true, | ||
"managedByTenants": [], | ||
"name": "Subscription-Name", | ||
"state": "Enabled", | ||
"tenantId": "0envbwi39-TenantId", | ||
"user": { | ||
"name": "your-username@domain.com", | ||
"type": "user" | ||
} | ||
} | ||
] | ||
``` | ||
|
||
If you have more than one subscription, specify the subscription-id you want to use with command below: | ||
```shell | ||
az account set --subscription <your-subscription-id> | ||
``` | ||
|
||
### Provision the Resources | ||
|
||
After login Azure CLI with your account, now you can use the terraform script to create Azure Resources. | ||
|
||
#### Run with Bash | ||
|
||
```shell | ||
# In the root directory of the sample | ||
# Initialize your Terraform configuration | ||
terraform -chdir=./terraform init | ||
|
||
# Apply your Terraform Configuration | ||
terraform -chdir=./terraform apply -auto-approve | ||
|
||
``` | ||
|
||
#### Run with Powershell | ||
|
||
```shell | ||
# In the root directory of the sample | ||
# Initialize your Terraform configuration | ||
terraform -chdir=terraform init | ||
|
||
1. Click **Create**. | ||
# Apply your Terraform Configuration | ||
terraform -chdir=terraform apply -auto-approve | ||
|
||
data:image/s3,"s3://crabby-images/b9872/b98720b19750f5c78d9d4750ed50de10fadb99c7" alt="Create new Cosmos" | ||
``` | ||
|
||
1. On the **Create key vault** page, input `Subscription`, `Resource group`, `Account Name`, then click `Review + Create`. | ||
It may take a few minutes to run the script. After successful running, you will see prompt information like below: | ||
|
||
data:image/s3,"s3://crabby-images/5d1d1/5d1d186c62a85b46bd451259064f29ba3f42ca13" alt="Specify the options" | ||
```shell | ||
|
||
data:image/s3,"s3://crabby-images/8bb88/8bb88ef01501433815e54b61adc54360def27e04" alt="Create Cosmos resource" | ||
random_password.mysql_login_password: Creating... | ||
azurecaf_name.mysql_login_name: Creating... | ||
azurecaf_name.cosmos_01: Creating... | ||
azurecaf_name.mysql: Creating... | ||
azurecaf_name.cosmos_02: Creating... | ||
azurecaf_name.resource_group: Creating... | ||
... | ||
azurerm_cosmosdb_account.application_01: Creating... | ||
azurerm_cosmosdb_account.application_02: Creating... | ||
... | ||
azurerm_cosmosdb_sql_database.db_01: Creating... | ||
... | ||
... | ||
Apply complete! Resources: 14 added, 0 changed, 0 destroyed. | ||
|
||
``` | ||
|
||
1. When complete, click `Go to resource`. | ||
You can go to [Azure portal](https://ms.portal.azure.com/) in your web browser to check the resources you created. | ||
|
||
data:image/s3,"s3://crabby-images/dd865/dd865cdbcdebfbfc34a95228140a9a5f46c9f8ed" alt="Go to resource" | ||
### Export Output to Your Local Environment | ||
Running the command below to export environment values: | ||
|
||
1. Click **Keys** in the left navigation pane, copy your **URI**, the **PRIMARY KEY** and **SECONDARY KEY**; | ||
#### Run with Bash | ||
|
||
data:image/s3,"s3://crabby-images/bd309/bd309496acbc1dc4876c421e693ecdb84d86367b" alt="Get Connect Info" | ||
```shell | ||
source ./terraform/setup_env.sh | ||
``` | ||
|
||
1. Replace the content in `application.properties` with the obtained information. | ||
#### Run with Powershell | ||
|
||
1. We need to create another cosmos DB as the secondary like the steps above. | ||
```shell | ||
. terraform\setup_env.ps1 | ||
``` | ||
|
||
1. Add MYSQL connection attributes in `application.properties`. | ||
## Run Locally | ||
|
||
## Key concepts | ||
## Examples | ||
### Configure application.yml | ||
```yaml | ||
# primary account cosmos config | ||
azure.cosmos.primary.uri=your-primary-cosmosDb-uri | ||
azure.cosmos.primary.key=your-primary-cosmosDb-key | ||
azure.cosmos.primary.secondary-key=your-primary-cosmosDb-secondary-key | ||
azure.cosmos.primary.database=your-primary-cosmosDb-dbName | ||
azure.cosmos.primary.populate-query-metrics=if-populate-query-metrics | ||
In your terminal, run `mvn clean spring-boot:run`. | ||
|
||
# secondary account cosmos config | ||
azure.cosmos.secondary.uri=your-secondary-cosmosDb-uri | ||
azure.cosmos.secondary.key=your-secondary-cosmosDb-key | ||
azure.cosmos.secondary.secondary-key=your-secondary-cosmosDb-secondary-key | ||
azure.cosmos.secondary.database=your-secondary-cosmosDb-dbName | ||
azure.cosmos.secondary.populate-query-metrics=if-populate-query-metrics | ||
|
||
#mysql connection attributes | ||
spring.jpa.hibernate.ddl-auto=update | ||
spring.datasource.url=jdbc:mysql://${MYSQL_HOST:localhost}:3306/db_example | ||
spring.datasource.username=your-mysql-username | ||
spring.datasource.password=your-mysql-password | ||
```shell | ||
mvn clean spring-boot:run | ||
``` | ||
|
||
### Run with Maven | ||
## Verify This Sample | ||
|
||
Verify in your app’s logs that similar messages were posted: | ||
```shell | ||
cd azure-spring-boot-samples/cosmos/azure-spring-data-cosmos/cosmos-multi-database-multi-account | ||
mvn spring-boot:run | ||
... | ||
Data added successfully ......... | ||
... | ||
Get secondaryCosmosUser 1024: 1024@geek.com 1k Mars ......... | ||
``` | ||
|
||
Verify Result: | ||
The corresponding data is added to the mysql database and cosmos database | ||
The corresponding data is added to the mysql database and cosmos database | ||
data:image/s3,"s3://crabby-images/48582/48582bcd2abf10dcc5083b8f0b7898cce479ce62" alt="Result in MYSQL" | ||
data:image/s3,"s3://crabby-images/0f6e2/0f6e24207c47bd10f414a1ba9a2298eb6b065987" alt="Result in Primary Cosmos Database" | ||
data:image/s3,"s3://crabby-images/41b80/41b80f3d8882ded4bb689f8f9e96f00d4af4a8c7" alt="Result in Secondary Cosmos Database" | ||
|
||
## Troubleshooting | ||
## Next steps | ||
## Contributing | ||
|
||
<!-- LINKS --> | ||
## Clean Up Resources | ||
After running the sample, if you don't want to run the sample, remember to destroy the Azure resources you created to avoid unnecessary billing. | ||
|
||
The terraform destroy command terminates resources managed by your Terraform project. | ||
To destroy the resources you created. | ||
|
||
#### Run with Bash | ||
|
||
```shell | ||
terraform -chdir=./terraform destroy -auto-approve | ||
``` | ||
|
||
#### Run with Powershell | ||
|
||
```shell | ||
terraform -chdir=terraform destroy -auto-approve | ||
``` |
Binary file removed
BIN
-102 KB
...-cosmos/cosmos-multi-database-multi-account/resource/create-cosmos-resource.png
Binary file not shown.
Binary file removed
BIN
-126 KB
...data-cosmos/cosmos-multi-database-multi-account/resource/creating-cosmos-01.png
Binary file not shown.
Binary file removed
BIN
-123 KB
...data-cosmos/cosmos-multi-database-multi-account/resource/creating-cosmos-02.png
Binary file not shown.
Binary file removed
BIN
-168 KB
...data-cosmos/cosmos-multi-database-multi-account/resource/creating-cosmos-03.png
Binary file not shown.
Binary file removed
BIN
-141 KB
...g-data-cosmos/cosmos-multi-database-multi-account/resource/get-connect-info.png
Binary file not shown.
Binary file removed
BIN
-125 KB
...ing-data-cosmos/cosmos-multi-database-multi-account/resource/go-to-resource.png
Binary file not shown.
Binary file modified
BIN
+0 Bytes
(100%)
...mos-multi-database-multi-account/resource/result-in-primary-cosmos-database.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified
BIN
+0 Bytes
(100%)
...s-multi-database-multi-account/resource/result-in-secondary-cosmos-database.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file removed
BIN
-119 KB
...ata-cosmos/cosmos-multi-database-multi-account/resource/specify-the-options.png
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
18 changes: 0 additions & 18 deletions
18
...data-cosmos/cosmos-multi-database-multi-account/src/main/resources/application.properties
This file was deleted.
Oops, something went wrong.
22 changes: 22 additions & 0 deletions
22
...pring-data-cosmos/cosmos-multi-database-multi-account/src/main/resources/application.yaml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
azure: | ||
cosmos: | ||
primary: | ||
uri: ${AZURE_COSMOS_URI_1} | ||
key: ${AZURE_COSMOS_KEY_1} | ||
secondary-key: ${AZURE_COSMOS_SECONDARY_KEY_1} | ||
database: ${AZURE_COSMOS_DATABASE_1} | ||
populate-query-metrics: if-populate-query-metrics | ||
secondary: | ||
uri: ${AZURE_COSMOS_URI_2} | ||
key: ${AZURE_COSMOS_KEY_2} | ||
secondary-key: ${AZURE_COSMOS_SECONDARY_KEY_2} | ||
database: ${AZURE_COSMOS_DATABASE_2} | ||
populate-query-metrics: if-populate-query-metrics | ||
spring: | ||
datasource: | ||
username: ${AZURE_MYSQL_USERNAME}@${AZURE_MYSQL_HOST} | ||
password: ${AZURE_MYSQL_PASSWORD} | ||
url: jdbc:mysql://${AZURE_MYSQL_HOST}.mysql.database.azure.com:3306/db_example | ||
jpa: | ||
hibernate: | ||
ddl-auto: update |
Oops, something went wrong.