diff --git a/externals/kyuubi-spark-sql-engine/src/main/scala/org/apache/kyuubi/engine/spark/events/SessionEvent.scala b/externals/kyuubi-spark-sql-engine/src/main/scala/org/apache/kyuubi/engine/spark/events/SessionEvent.scala index 2939adc7d..ce21c3936 100644 --- a/externals/kyuubi-spark-sql-engine/src/main/scala/org/apache/kyuubi/engine/spark/events/SessionEvent.scala +++ b/externals/kyuubi-spark-sql-engine/src/main/scala/org/apache/kyuubi/engine/spark/events/SessionEvent.scala @@ -22,7 +22,7 @@ import org.apache.spark.sql.types.StructType import org.apache.kyuubi.Utils import org.apache.kyuubi.engine.spark.KyuubiSparkUtil -import org.apache.kyuubi.session.Session +import org.apache.kyuubi.engine.spark.session.SparkSessionImpl /** * Event Tracking for user sessions @@ -31,6 +31,7 @@ import org.apache.kyuubi.session.Session * @param startTime Start time * @param endTime End time * @param ip Client IP address + * @param serverIp Kyuubi Server IP address * @param totalOperations how many queries and meta calls */ case class SessionEvent( @@ -38,6 +39,7 @@ case class SessionEvent( engineId: String, username: String, ip: String, + serverIp: String, startTime: Long, var endTime: Long = -1L, var totalOperations: Int = 0) extends KyuubiSparkEvent { @@ -56,12 +58,13 @@ case class SessionEvent( } object SessionEvent { - def apply(session: Session): SessionEvent = { + def apply(session: SparkSessionImpl): SessionEvent = { new SessionEvent( session.handle.identifier.toString, KyuubiSparkUtil.engineId, session.user, session.ipAddress, + session.serverIpAddress, session.createTime) } } diff --git a/externals/kyuubi-spark-sql-engine/src/main/scala/org/apache/kyuubi/engine/spark/session/SparkSQLSessionManager.scala b/externals/kyuubi-spark-sql-engine/src/main/scala/org/apache/kyuubi/engine/spark/session/SparkSQLSessionManager.scala index 693bbc60c..4a8769b9e 100644 --- a/externals/kyuubi-spark-sql-engine/src/main/scala/org/apache/kyuubi/engine/spark/session/SparkSQLSessionManager.scala +++ b/externals/kyuubi-spark-sql-engine/src/main/scala/org/apache/kyuubi/engine/spark/session/SparkSQLSessionManager.scala @@ -79,6 +79,7 @@ class SparkSQLSessionManager private (name: String, spark: SparkSession) protocol, user, password, + ipAddress, clientIp, conf, this, diff --git a/externals/kyuubi-spark-sql-engine/src/main/scala/org/apache/kyuubi/engine/spark/session/SparkSessionImpl.scala b/externals/kyuubi-spark-sql-engine/src/main/scala/org/apache/kyuubi/engine/spark/session/SparkSessionImpl.scala index 6cc7cd947..98ca7d190 100644 --- a/externals/kyuubi-spark-sql-engine/src/main/scala/org/apache/kyuubi/engine/spark/session/SparkSessionImpl.scala +++ b/externals/kyuubi-spark-sql-engine/src/main/scala/org/apache/kyuubi/engine/spark/session/SparkSessionImpl.scala @@ -30,6 +30,7 @@ class SparkSessionImpl( protocol: TProtocolVersion, user: String, password: String, + serverIpAddress: String, ipAddress: String, conf: Map[String, String], sessionManager: SessionManager, @@ -47,6 +48,8 @@ class SparkSessionImpl( private val sessionEvent = SessionEvent(this) + def serverIpAddress(): String = serverIpAddress + override def open(): Unit = { normalizedConf.foreach { case ("use:database", database) => spark.catalog.setCurrentDatabase(database) diff --git a/externals/kyuubi-spark-sql-engine/src/main/scala/org/apache/spark/ui/EnginePage.scala b/externals/kyuubi-spark-sql-engine/src/main/scala/org/apache/spark/ui/EnginePage.scala index 8f5b79a79..32c7d6b35 100644 --- a/externals/kyuubi-spark-sql-engine/src/main/scala/org/apache/spark/ui/EnginePage.scala +++ b/externals/kyuubi-spark-sql-engine/src/main/scala/org/apache/spark/ui/EnginePage.scala @@ -240,6 +240,7 @@ case class EnginePage(parent: EngineTab) extends WebUIPage("") { Seq( ("User", true, None), ("Client IP", true, None), + ("Server IP", true, None), ("Session ID", true, None), ("Start Time", true, None), ("Finish Time", true, None), @@ -264,6 +265,7 @@ case class EnginePage(parent: EngineTab) extends WebUIPage("") {