Skip to content

This project demonstrates how to use a Java sample application to perform CRUD management operations for the Microsoft.NetApp resource provider.

License

Notifications You must be signed in to change notification settings

hildurhodd/netappfiles-java-sdk-sample

 
 

Repository files navigation

page_type languages products description
sample
java
azure
azure-netapp-files
This project demonstrates how to use a to perform management CRUD operations for Microsoft.NetApp resource provider using Java SDK.

Azure NetApp Files SDK for Java

This project demonstrates how to use a Java sample application to perform CRUD management operations for the Microsoft.NetApp resource provider.

In this sample application we perform the following operations:

  • Creations
    • NetApp accounts
    • Capacity pools
    • Volumes
    • Snapshots
    • Volume from snapshot
  • Updates
    • Change a capacity pool size from 4 TB to 10 TB
    • Change a volume size from 100 GB to 1 TB
    • Add a new NFS export policy to an existing volume
  • Deletions
    • Snapshots
    • Volumes (including those created from snapshots)
    • Capacity pool
    • NetApp accounts

Note: The cleanup execution is commented out by default. If you want to run this end-to-end with the cleanup, simply uncomment the related lines in main.java

Most of these operations are based on an asynchronous programming model to demonstrate how to asynchronously manage Azure NetApp Files resources with Java. The exceptions are volume creation and deletion operations that are executed sequentially at the Resource Provider level; therefore, these operations are executed sequentially.

If you don't already have a Microsoft Azure subscription, you can get a FREE trial account here.

Prerequisites

  1. This project is built upon Maven, which must be installed in order to run the sample. Instructions on installing Maven can be found on their website here
  2. Azure subscription
  3. Subscription needs to be whitelisted for Azure NetApp Files. For more information, see Submit a waitlist request for accessing the service.
  4. Resource Group created
  5. Virtual Network with a delegated subnet to Microsoft.Netapp/volumes resource. For more information, see Guidelines for Azure NetApp Files network planning.
  6. For this sample console application to work, authentication is needed. We will use Service Principal based authentication
    1. Within an Azure Cloud Shell session, make sure you're logged in at the subscription where you want to be associated with the service principal by default:

      az account show

      If this is not the correct subscription, use:

      az account set -s <subscription name or id>  
    2. Create a service principal using Azure CLI:

      az ad sp create-for-rbac --sdk-auth

      Note: This command will automatically assign RBAC contributor role to the service principal at subscription level. You can narrow down the scope to the specific resource group where your tests will create the resources.

    3. Set the following environment variables from the output of the creation:

      Powershell

      $env:AZURE_SUBSCRIPTION_ID = <subscriptionId>
      $env:AZURE_CLIENT_ID = <clientId>
      $env:AZURE_CLIENT_SECRET = <clientSecret>
      $env:AZURE_TENANT_ID = <tenantId>

      Bash

      export AZURE_SUBSCRIPTION_ID=<subscriptionId>
      export AZURE_CLIENT_ID=<clientId>
      export AZURE_CLIENT_SECRET=<clientSecret>
      export AZURE_TENANT_ID=<tenantId>

What does netappfiles-java-sdk-sample do?

Currently, Azure NetApp Files SDK exposes control plane management operations--CRUD operations--for its resources like NetApp accounts, capacity pools, volumes, and snapshots. We start this execution by reading a configuration file (appsettings.json). This file has two sections: the 'general' section has information about the subscription and resource group to be used. The other section, 'accounts', is the place that defines the accounts, capacity pools, and volumes. This process will create a configuration object that is used extensively throughout the code to reference the resources to be created, updated, and deleted.

Note: See Resource limits for Azure NetApp Files to understand Azure NetApp Files limits.

The SDK will then move forward to the authentication process, generating a ServiceClientCredentials (service principal) that is accepted by the AzureNetAppFilesManagementClient to create the management client, which is used to make the CRUD requests and is also used extensively throughout the code.

Then the sample will start the CRUD operations by creating the accounts, capacity pools, and volumes, in this exact sequence (see Azure NetApp Files storage hierarchy). Afterwards, a snapshot is created and following that, a new volume is created from that snapshot. After all resources have been created, the sample will perform an update to a capacity pool by increasing its size and, then it will perform updates to a volume by changing its size quota and adding an extra export policy. Finally, the cleanup process starts and removes all resources deployed by this application (provided that the appropriate code in main.java has been uncommented).

Note: This sample does not have a specific retrieve section, because we perform gets and lists operations in several places throughout the code.

How the project is structured

The following table describes all files within this solution:

Folder FileName Description
Root _sample_appsettings.json This is the sample appsettings.json file. To use it, make a copy and rename to 'appsettings.json'. Sizes are all defined in bytes. By default the appsettings.json is included in the .gitignore file to avoid unwanted extra information being committed to a public Git repo
Root\^ main.java Reads configuration, authenticates, executes all operations
Root\^ Creation.java Class that contains all resource creation loops, following the hierarchy logic in order to successfully deploy Azure NetApp Files resources
Root\^ Updates.java Class that is used to update capacity pool and volume sizes, and to add a new export policy to a Volume as well
Root\^ Snapshots.java Class used for snapshot operations such as creating a new snapshot and creating a new volume from a snapshot
Root\^ Cleanup.java Class that performs cleanup of all artifacts that were created during this sample application. Its call is commented out by default in main.java
Root\^\common CommonSdk.java Class dedicated to common operations related to Azure NetApp Files SDK
Root\^\common ProjectConfiguration.java Class used to create the configuration object based on appsettings.json file contents
Root\^\common ResourceUriUtils.java Class that exposes a few methods that help parsing Uri's, building new Uri's, or getting a resource name from a Uri, etc
Root\^\common ServiceCredentialsAuth.java A small support class for extracting and creating credentials from a File
Root\^\common Utils.java Class that exposes methods that help with getting the configuration object, byte conversion, etc
Root\^\model * Various .java files that define objects received from the configuration file and are used throughout the code

\^ == src/main/java/sdk/sample

How to run the console application

  1. Clone the SDK sample locally
    git clone https://github.com/Azure-Samples/netappfiles-java-sdk-sample
  2. Change folder to .\netappfiles-java-sdk-sample
  3. Make a copy of _sample_appsettings.json file, rename it to appsettings.json and modify its contents accordingly (at minimum all values between <> must be replaced with real values).
  4. Make sure you have the azureauth.json and its environment variable with the path to it defined (as previously described)
  5. Compile the console application
    mvn clean compile
  6. Run the console application
    mvn exec:java -Dexec.mainClass="sdk.sample.main"

Sample output e2e execution

References

About

This project demonstrates how to use a Java sample application to perform CRUD management operations for the Microsoft.NetApp resource provider.

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 100.0%