forked from quarkiverse/quarkus-azure-services
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Jianguo Ma <[email protected]>
- Loading branch information
Showing
2 changed files
with
224 additions
and
1 deletion.
There are no files selected for viewing
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,223 @@ | ||
# Azure Cosmos DB sample | ||
|
||
This is a sample about implementing REST endpoints using the Quarkus extension to read/write data stored in Azure Cosmos DB. | ||
|
||
## Prerequisites | ||
|
||
To successfully run this sample, you need: | ||
|
||
* JDK 17+ installed with JAVA_HOME configured appropriately | ||
* Apache Maven 3.8.6+ | ||
* Azure CLI and Azure subscription | ||
* Docker if you want to build the app as a native executable | ||
|
||
You also need to clone the repository and switch to the directory of the sample. | ||
|
||
``` | ||
git clone https://github.com/quarkiverse/quarkus-azure-services.git | ||
cd quarkus-azure-services/integration-tests/azure-cosmos | ||
``` | ||
|
||
### Use development iteration version | ||
|
||
By default, the sample depends on the development iteration version, which is `999-SNAPSHOT`. To install the development | ||
iteration version, you need to build it locally. | ||
|
||
``` | ||
mvn clean install -DskipTests --file ../../pom.xml | ||
``` | ||
|
||
### Use release version | ||
|
||
If you want to use the release version, you need to update the version of dependencies in the `pom.xml` file. | ||
|
||
First, you need to find out the latest release version of the Quarkus Azure services extensions | ||
from [releases](https://github.com/quarkiverse/quarkus-azure-services/releases), for example, `1.0.6`. | ||
|
||
Then, update the version of dependencies in the `pom.xml` file, for example: | ||
|
||
```xml | ||
<parent> | ||
<groupId>io.quarkiverse.azureservices</groupId> | ||
<artifactId>quarkus-azure-services-parent</artifactId> | ||
<version>1.0.6</version> | ||
<relativePath></relativePath> | ||
</parent> | ||
``` | ||
|
||
## Preparing the Azure services | ||
|
||
You need to create an Azure Cosmos DB account before running the sample application. | ||
|
||
### Logging into Azure | ||
|
||
Log into Azure and create a resource group for hosting the Azure Cosmos DB account to be created. | ||
|
||
``` | ||
az login | ||
RESOURCE_GROUP_NAME=<resource-group-name> | ||
az group create \ | ||
--name ${RESOURCE_GROUP_NAME} \ | ||
--location westus | ||
``` | ||
|
||
### Creating Azure Azure Cosmos DB account | ||
|
||
Run the following commands to create an Azure Cosmos DB account, and export its endpoint as an environment variable. | ||
|
||
``` | ||
COSMOSDB_ACCOUNT_NAME=<unique-cosmosdb-account-name> | ||
az cosmosdb create \ | ||
-n ${COSMOSDB_ACCOUNT_NAME} \ | ||
-g ${RESOURCE_GROUP_NAME} \ | ||
--default-consistency-level Session \ | ||
--locations regionName='West US' failoverPriority=0 isZoneRedundant=False | ||
export QUARKUS_AZURE_COSMOS_ENDPOINT=$(az cosmosdb show \ | ||
-n ${COSMOSDB_ACCOUNT_NAME} \ | ||
-g ${RESOURCE_GROUP_NAME} \ | ||
--query documentEndpoint -o tsv) | ||
echo "The value of 'quarkus.azure.cosmos.endpoint' is: ${QUARKUS_AZURE_COSMOS_ENDPOINT}" | ||
``` | ||
|
||
The value of environment variable `QUARKUS_AZURE_COSMOS_ENDPOINT` will be fed into config | ||
property `quarkus.azure.cosmos.endpoint` of `azure-cosmos` extension in order to set up the | ||
connection to the Azure Cosmos DB. | ||
|
||
Assign the `Cosmos DB Built-in Data Contributor` role to the signed-in user, so that the sample application can do data plane CRUD operations. | ||
|
||
``` | ||
az ad signed-in-user show --query id -o tsv \ | ||
| az cosmosdb sql role assignment create \ | ||
--account-name ${COSMOSDB_ACCOUNT_NAME} \ | ||
--resource-group ${RESOURCE_GROUP_NAME} \ | ||
--scope "/" \ | ||
--principal-id @- \ | ||
--role-definition-id 00000000-0000-0000-0000-000000000002 | ||
``` | ||
|
||
However, you cannot use any Azure Cosmos DB data plane SDK to authenticate management operations with a Microsoft Entra identity, so you need to create database and container manually. | ||
The following commands create a database `demodb` and a container `democontainer` using Azure CLI. | ||
|
||
``` | ||
az cosmosdb sql database create \ | ||
-a ${COSMOSDB_ACCOUNT_NAME} \ | ||
-g ${RESOURCE_GROUP_NAME} \ | ||
-n demodb | ||
az cosmosdb sql container create \ | ||
-a ${COSMOSDB_ACCOUNT_NAME} \ | ||
-g ${RESOURCE_GROUP_NAME} \ | ||
-d demodb \ | ||
-n democontainer \ | ||
-p "/id" | ||
``` | ||
|
||
## Running the sample | ||
|
||
You have different choices to run the sample. Make sure you have followed [Preparing the Azure services](#preparing-the-azure-services) to create the required Azure services. | ||
|
||
### Running the sample in development mode | ||
|
||
First, you can launch the sample in `dev` mode. | ||
|
||
``` | ||
mvn quarkus:dev | ||
``` | ||
|
||
### Running and test the sample in JVM mode | ||
|
||
You can also run the sample in JVM mode. | ||
|
||
``` | ||
# Build the package. | ||
mvn package | ||
# Run the generated jar file. | ||
java -jar ./target/quarkus-app/quarkus-run.jar | ||
``` | ||
|
||
### Running and test the sample as a native executable | ||
|
||
You can even run the sample as a native executable. Make sure you have installed Docker. | ||
|
||
``` | ||
# Build the native executable using the Docker. | ||
mvn package -Dnative -Dquarkus.native.container-build | ||
# Run the native executable. | ||
version=$(mvn help:evaluate -Dexpression=project.version -q -DforceStdout) | ||
./target/quarkus-azure-integration-test-cosmos-${version}-runner | ||
``` | ||
|
||
## Testing the sample | ||
|
||
Open a new terminal and run the following commands to test the sample: | ||
|
||
``` | ||
# Create an item {"id": "1", "name": "dog"} in Azure Cosmos DB database demodb and container democontainer. | ||
curl http://localhost:8080/quarkus-azure-cosmos/demodb/democontainer -X POST -d '{"id": "1", "name": "dog"}' -H "Content-Type: application/json" | ||
# Read the item from Azure Cosmos DB database demodb and container democontainer. You should see {"id":"1","name":"dog"} in the response. | ||
curl http://localhost:8080/quarkus-azure-cosmos/demodb/democontainer/1 -X GET | ||
# List items from Azure Cosmos DB database demodb and container democontainer. You should see [{"id":"1","name":"dog"}] in the response. | ||
curl http://localhost:8080/quarkus-azure-cosmos/demodb/democontainer -X GET | ||
# Update the item {"id": "1", "name": "dog"} to {"id": "1", "name": "cat"} in Azure Cosmos DB database demodb and container democontainer. | ||
curl http://localhost:8080/quarkus-azure-cosmos/demodb/democontainer -X POST -d '{"id": "1", "name": "cat"}' -H "Content-Type: application/json" | ||
# Read the updated item from Azure Cosmos DB database demodb and container democontainer. You should see {"id":"1","name":"cat"} in the response. | ||
curl http://localhost:8080/quarkus-azure-cosmos/demodb/democontainer/1 -X GET | ||
# List items again from Azure Cosmos DB database demodb and container democontainer. You should see [{"id":"1","name":"cat"}] in the response. | ||
curl http://localhost:8080/quarkus-azure-cosmos/demodb/democontainer -X GET | ||
# Delete the item from Azure Cosmos DB database demodb and container democontainer. | ||
curl http://localhost:8080/quarkus-azure-cosmos/demodb/democontainer/1 -X DELETE | ||
# Read the deleted item from Azure Cosmos DB database demodb and container democontainer. You should see HTTP status code 500 in the response. | ||
curl http://localhost:8080/quarkus-azure-cosmos/demodb/democontainer/1 -X DELETE -w "%{http_code}" -s -o /dev/null | ||
# List items again from Azure Cosmos DB database demodb and container democontainer. You should see [] in the response. | ||
curl http://localhost:8080/quarkus-azure-cosmos/demodb/democontainer -X GET | ||
# Create an item {"id": "1", "name": "dog"} in Azure Cosmos DB database demodb and container democontainer using the async API. | ||
curl http://localhost:8080/quarkus-azure-cosmos-async/demodb/democontainer -X POST -d '{"id": "1", "name": "dog"}' -H "Content-Type: application/json" | ||
# Read the item from Azure Cosmos DB database demodb and container democontainer using the async API. You should see {"id":"1","name":"dog"} in the response. | ||
curl http://localhost:8080/quarkus-azure-cosmos-async/demodb/democontainer/1 -X GET | ||
# List items from Azure Cosmos DB database demodb and container democontainer using the async API. You should see [{"id":"1","name":"dog"}] in the response. | ||
curl http://localhost:8080/quarkus-azure-cosmos-async/demodb/democontainer -X GET | ||
# Update the item {"id": "1", "name": "dog"} to {"id": "1", "name": "cat"} in Azure Cosmos DB database demodb and container democontainer using the async API. | ||
curl http://localhost:8080/quarkus-azure-cosmos-async/demodb/democontainer -X POST -d '{"id": "1", "name": "cat"}' -H "Content-Type: application/json" | ||
# Read the updated item from Azure Cosmos DB database demodb and container democontainer using the async API. You should see {"id":"1","name":"cat"} in the response. | ||
curl http://localhost:8080/quarkus-azure-cosmos-async/demodb/democontainer/1 -X GET | ||
# List items again from Azure Cosmos DB database demodb and container democontainer using the async API. You should see [{"id":"1","name":"cat"}] in the response. | ||
curl http://localhost:8080/quarkus-azure-cosmos-async/demodb/democontainer -X GET | ||
# Delete the item from Azure Cosmos DB database demodb and container democontainer using the async API. | ||
curl http://localhost:8080/quarkus-azure-cosmos-async/demodb/democontainer/1 -X DELETE | ||
# Read the deleted item from Azure Cosmos DB database demodb and container democontainer using the async API. You should see HTTP status code 500 in the response. | ||
curl http://localhost:8080/quarkus-azure-cosmos-async/demodb/democontainer/1 -X DELETE -w "%{http_code}" -s -o /dev/null | ||
# List items again from Azure Cosmos DB database demodb and container democontainer using the async API. You should see [] in the response. | ||
curl http://localhost:8080/quarkus-azure-cosmos-async/demodb/democontainer -X GET | ||
``` | ||
|
||
Press `Ctrl + C` to stop the sample once you complete the try and test. | ||
|
||
## Cleaning up Azure resources | ||
|
||
Run the following command to clean up the Azure resources if you created before: | ||
|
||
``` | ||
az group delete \ | ||
--name ${RESOURCE_GROUP_NAME} \ | ||
--yes --no-wait | ||
``` |
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