[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Missing the information I need","missingTheInformationINeed","thumb-down"],["Too complicated / too many steps","tooComplicatedTooManySteps","thumb-down"],["Out of date","outOfDate","thumb-down"],["Samples / code issue","samplesCodeIssue","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-08-28 UTC."],[],[],null,["# Package com.google.cloud.pubsublite.spark.internal (1.0.0)\n\nVersion latestkeyboard_arrow_down\n\n- [1.0.0 (latest)](/java/docs/reference/pubsublite-spark-sql-streaming/latest/com.google.cloud.pubsublite.spark.internal)\n- [0.4.5](/java/docs/reference/pubsublite-spark-sql-streaming/0.4.5/com.google.cloud.pubsublite.spark.internal)\n- [0.3.4](/java/docs/reference/pubsublite-spark-sql-streaming/0.3.4/com.google.cloud.pubsublite.spark.internal) \n\nClasses\n-------\n\n### [CachedPartitionCountReader](/java/docs/reference/pubsublite-spark-sql-streaming/latest/com.google.cloud.pubsublite.spark.internal.CachedPartitionCountReader)\n\n### [CachedPublishers](/java/docs/reference/pubsublite-spark-sql-streaming/latest/com.google.cloud.pubsublite.spark.internal.CachedPublishers)\n\nCached Publishers to reuse publisher of same settings in the same task.\n\n### [CachedSubscriberClients](/java/docs/reference/pubsublite-spark-sql-streaming/latest/com.google.cloud.pubsublite.spark.internal.CachedSubscriberClients)\n\nSingleton class that caches subscriber service clients to be re-used by the same task.\n\n### [LimitingHeadOffsetReader](/java/docs/reference/pubsublite-spark-sql-streaming/latest/com.google.cloud.pubsublite.spark.internal.LimitingHeadOffsetReader)\n\nRate limited HeadOffsetReader, utilizing a LoadingCache that refreshes all partitions head\noffsets for the topic at most once per minute.\n\n### [MultiPartitionCommitterImpl](/java/docs/reference/pubsublite-spark-sql-streaming/latest/com.google.cloud.pubsublite.spark.internal.MultiPartitionCommitterImpl)\n\nA [MultiPartitionCommitter](/java/docs/reference/pubsublite-spark-sql-streaming/latest/com.google.cloud.pubsublite.spark.internal.MultiPartitionCommitter) that lazily adjusts for partition changes when [MultiPartitionCommitter#commit(PslSourceOffset)](/java/docs/reference/pubsublite-spark-sql-streaming/latest/com.google.cloud.pubsublite.spark.internal.MultiPartitionCommitter#com_google_cloud_pubsublite_spark_internal_MultiPartitionCommitter_commit_com_google_cloud_pubsublite_spark_PslSourceOffset_) is called.\n\n### [PslCredentialsProvider](/java/docs/reference/pubsublite-spark-sql-streaming/latest/com.google.cloud.pubsublite.spark.internal.PslCredentialsProvider)\n\nInterfaces\n----------\n\n### [MultiPartitionCommitter](/java/docs/reference/pubsublite-spark-sql-streaming/latest/com.google.cloud.pubsublite.spark.internal.MultiPartitionCommitter)\n\n### [MultiPartitionCommitter.CommitterFactory](/java/docs/reference/pubsublite-spark-sql-streaming/latest/com.google.cloud.pubsublite.spark.internal.MultiPartitionCommitter.CommitterFactory)\n\n### [PartitionCountReader](/java/docs/reference/pubsublite-spark-sql-streaming/latest/com.google.cloud.pubsublite.spark.internal.PartitionCountReader)\n\n### [PartitionSubscriberFactory](/java/docs/reference/pubsublite-spark-sql-streaming/latest/com.google.cloud.pubsublite.spark.internal.PartitionSubscriberFactory)\n\n### [PerTopicHeadOffsetReader](/java/docs/reference/pubsublite-spark-sql-streaming/latest/com.google.cloud.pubsublite.spark.internal.PerTopicHeadOffsetReader)\n\n### [PublisherFactory](/java/docs/reference/pubsublite-spark-sql-streaming/latest/com.google.cloud.pubsublite.spark.internal.PublisherFactory)"]]