com.azure.cosmos.spark.udf.CosmosAsyncClientCache.scala Maven / Gradle / Ivy
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package com.azure.cosmos.spark.udf
import com.azure.cosmos.spark.{CosmosClientCache, CosmosClientConfiguration, CosmosConfig, CosmosReadConfig}
import org.apache.spark.sql.SparkSession
/**
* Helper API to retrieve the CosmosAsyncClient instance used by the connector internally
*/
object CosmosAsyncClientCache {
/**
* This API can be used by Spark apps to retrieve the same CosmosAsyncClient instance that
* the Cosmos DB Spark connector is using internally as well. It can help avoiding the need
* to instantiate one additional CosmosAsyncClient in the app for the same configuration
* the Spark connector internally also uses.
* NOTE: The returned client is from the shaded package - so `azure_cosmos_spark.com.azure.CosmosAsyncClient`
* @param userProvidedConfig the configuration dictionary also used in Spark APIs to authenticate
* @return the shaded CosmosAsyncClient that is also used internally by the Spark connector
*/
def getCosmosClientFromCache(userProvidedConfig: Map[String, String]): CosmosAsyncClientCacheItem = {
val effectiveUserConfig = CosmosConfig.getEffectiveConfig(None, None, userProvidedConfig)
val readConfig = CosmosReadConfig.parseCosmosReadConfig(effectiveUserConfig)
val useEventualConsistency = readConfig.forceEventualConsistency
val sparkEnvironmentInfo = CosmosClientConfiguration.getSparkEnvironmentInfo(SparkSession.getActiveSession)
new CosmosAsyncClientCacheItem(effectiveUserConfig, useEventualConsistency, sparkEnvironmentInfo)
}
/**
* This API can be used by Spark apps to retrieve a function that allows getting the
* same CosmosAsyncClient instance that the Cosmos DB Spark connector is using internally as well.
* To use the client on an executor, please ensure that the function is only invoked on the
* executor.
* NOTE: The returned client is from the shaded package - so `azure_cosmos_spark.com.azure.CosmosAsyncClient`
*
* @param userProvidedConfig the configuration dictionary also used in Spark APIs to authenticate
* @return the function returning the shaded CosmosAsyncClient that is also used internally by the Spark connector
*/
def getCosmosClientFuncFromCache(userProvidedConfig: Map[String, String]): () => CosmosAsyncClientCacheItem = {
val effectiveUserConfig = CosmosConfig.getEffectiveConfig(None, None, userProvidedConfig)
val readConfig = CosmosReadConfig.parseCosmosReadConfig(effectiveUserConfig)
val useEventualConsistency = readConfig.forceEventualConsistency
val sparkEnvironmentInfo = CosmosClientConfiguration.getSparkEnvironmentInfo(SparkSession.getActiveSession)
// delay getting the client from cache here to allow this to be executed on executors
// as well - not just on the driver
() =>
new CosmosAsyncClientCacheItem(effectiveUserConfig, useEventualConsistency, sparkEnvironmentInfo)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy