From 3c1a0dd140b32f3383660d866d6e5aa1594c03eb Mon Sep 17 00:00:00 2001 From: sunxiaojian Date: Wed, 15 Jan 2025 20:04:35 +0800 Subject: [PATCH] unified cache --- spark-connector/spark-common/build.gradle.kts | 18 ++++++++++++++++++ .../catalog/GravitinoCatalogManager.java | 11 +++++------ spark-connector/v3.3/spark/build.gradle.kts | 2 +- spark-connector/v3.4/spark/build.gradle.kts | 2 +- spark-connector/v3.5/spark/build.gradle.kts | 2 +- 5 files changed, 26 insertions(+), 9 deletions(-) diff --git a/spark-connector/spark-common/build.gradle.kts b/spark-connector/spark-common/build.gradle.kts index 06e0077d21e..a42efba52fb 100644 --- a/spark-connector/spark-common/build.gradle.kts +++ b/spark-connector/spark-common/build.gradle.kts @@ -16,6 +16,8 @@ * specific language governing permissions and limitations * under the License. */ +import com.github.jengelman.gradle.plugins.shadow.tasks.ShadowJar + plugins { `maven-publish` id("java") @@ -40,6 +42,7 @@ val scalaCollectionCompatVersion: String = libs.versions.scala.collection.compat dependencies { implementation(project(":catalogs:catalog-common")) implementation(libs.guava) + implementation(libs.caffeine) compileOnly(project(":clients:client-java-runtime", configuration = "shadow")) compileOnly("org.apache.iceberg:iceberg-spark-runtime-${sparkMajorVersion}_$scalaVersion:$icebergVersion") @@ -171,3 +174,18 @@ configurations { artifacts { add("testArtifacts", testJar) } + +tasks.withType(ShadowJar::class.java) { + isZip64 = true + configurations = listOf(project.configurations.runtimeClasspath.get()) + archiveClassifier.set("") + + // Relocate dependencies to avoid conflicts + relocate("com.google", "org.apache.gravitino.shaded.com.google") + relocate("com.github.benmanes.caffeine", "org.apache.gravitino.shaded.com.github.benmanes.caffeine") +} + +tasks.jar { + dependsOn(tasks.named("shadowJar")) + archiveClassifier.set("empty") +} diff --git a/spark-connector/spark-common/src/main/java/org/apache/gravitino/spark/connector/catalog/GravitinoCatalogManager.java b/spark-connector/spark-common/src/main/java/org/apache/gravitino/spark/connector/catalog/GravitinoCatalogManager.java index f04193f33a3..a484972656a 100644 --- a/spark-connector/spark-common/src/main/java/org/apache/gravitino/spark/connector/catalog/GravitinoCatalogManager.java +++ b/spark-connector/spark-common/src/main/java/org/apache/gravitino/spark/connector/catalog/GravitinoCatalogManager.java @@ -18,13 +18,12 @@ */ package org.apache.gravitino.spark.connector.catalog; +import com.github.benmanes.caffeine.cache.Cache; +import com.github.benmanes.caffeine.cache.Caffeine; import com.google.common.base.Preconditions; import com.google.common.base.Supplier; -import com.google.common.cache.Cache; -import com.google.common.cache.CacheBuilder; import java.util.Arrays; import java.util.Map; -import java.util.concurrent.ExecutionException; import org.apache.gravitino.Catalog; import org.apache.gravitino.client.GravitinoClient; import org.slf4j.Logger; @@ -42,7 +41,7 @@ public class GravitinoCatalogManager { private GravitinoCatalogManager(Supplier clientBuilder) { this.gravitinoClient = clientBuilder.get(); // Will not evict catalog by default - this.gravitinoCatalogs = CacheBuilder.newBuilder().build(); + this.gravitinoCatalogs = Caffeine.newBuilder().build(); } public static GravitinoCatalogManager create(Supplier clientBuilder) { @@ -69,8 +68,8 @@ public void close() { public Catalog getGravitinoCatalogInfo(String name) { try { - return gravitinoCatalogs.get(name, () -> loadCatalog(name)); - } catch (ExecutionException e) { + return gravitinoCatalogs.get(name, catalogName -> loadCatalog(catalogName)); + } catch (Exception e) { LOG.error(String.format("Load catalog %s failed", name), e); throw new RuntimeException(e); } diff --git a/spark-connector/v3.3/spark/build.gradle.kts b/spark-connector/v3.3/spark/build.gradle.kts index 66c65f863b9..a1cae53e917 100644 --- a/spark-connector/v3.3/spark/build.gradle.kts +++ b/spark-connector/v3.3/spark/build.gradle.kts @@ -38,7 +38,7 @@ val scalaCollectionCompatVersion: String = libs.versions.scala.collection.compat val artifactName = "${rootProject.name}-spark-${sparkMajorVersion}_$scalaVersion" dependencies { - implementation(project(":spark-connector:spark-common")) + implementation(project(":spark-connector:spark-common", configuration = "shadow")) compileOnly("org.apache.kyuubi:kyuubi-spark-connector-hive_$scalaVersion:$kyuubiVersion") compileOnly("org.apache.spark:spark-catalyst_$scalaVersion:$sparkVersion") { exclude("com.fasterxml.jackson") diff --git a/spark-connector/v3.4/spark/build.gradle.kts b/spark-connector/v3.4/spark/build.gradle.kts index aa4134a3c71..18c103619f1 100644 --- a/spark-connector/v3.4/spark/build.gradle.kts +++ b/spark-connector/v3.4/spark/build.gradle.kts @@ -38,7 +38,7 @@ val scalaCollectionCompatVersion: String = libs.versions.scala.collection.compat val artifactName = "${rootProject.name}-spark-${sparkMajorVersion}_$scalaVersion" dependencies { - implementation(project(":spark-connector:spark-common")) + implementation(project(":spark-connector:spark-common", configuration = "shadow")) compileOnly("org.apache.kyuubi:kyuubi-spark-connector-hive_$scalaVersion:$kyuubiVersion") compileOnly("org.apache.spark:spark-catalyst_$scalaVersion:$sparkVersion") { exclude("com.fasterxml.jackson") diff --git a/spark-connector/v3.5/spark/build.gradle.kts b/spark-connector/v3.5/spark/build.gradle.kts index 15aa018081d..9e26dd21451 100644 --- a/spark-connector/v3.5/spark/build.gradle.kts +++ b/spark-connector/v3.5/spark/build.gradle.kts @@ -39,7 +39,7 @@ val artifactName = "${rootProject.name}-spark-${sparkMajorVersion}_$scalaVersion dependencies { implementation(project(":spark-connector:spark-3.4")) - implementation(project(":spark-connector:spark-common")) + implementation(project(":spark-connector:spark-common", configuration = "shadow")) compileOnly("org.apache.kyuubi:kyuubi-spark-connector-hive_$scalaVersion:$kyuubiVersion") compileOnly("org.apache.spark:spark-catalyst_$scalaVersion:$sparkVersion") { exclude("com.fasterxml.jackson")