org.apache.spark.dataflint.saas.SparkRunSerializer.scala Maven / Gradle / Ivy
package org.apache.spark.dataflint.saas
import org.apache.spark.JobExecutionStatus
import org.apache.spark.rdd.DeterministicLevel
import org.apache.spark.status.api.v1.StageStatus
import org.json4s.jackson.{JsonMethods, Serialization}
import org.json4s.{Formats, NoTypeHints}
import java.io.{File, PrintWriter}
object SparkRunSerializer {
implicit val formats: Formats = Serialization.formats(NoTypeHints) + new JavaEnumNameSerializer[JobExecutionStatus]() + new JavaEnumNameSerializer[StageStatus]() + new EnumSerializer(DeterministicLevel) + new ExecutorsMetricsSerializer()
def serialize(data: SparkRunStore): String = {
Serialization.write(data)
}
def deserialize(json: String): SparkRunStore = {
JsonMethods.parse(json).extract[SparkRunStore]
}
def serializeAndSave(data: SparkRunStore, filePath: String): Unit = {
val jsonData = serialize(data)
val writer = new PrintWriter(new File(filePath))
try {
writer.write(jsonData)
} finally {
writer.close()
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy