python_worker_logs
Returns a DataFrame of logs collected from Python workers.
Syntax
Python
spark.tvf.python_worker_logs()
Examples
Example 1: Collect and view Python worker logs
Python
from pyspark.sql import functions as sf
import logging
@sf.udf("string")
def my_udf(x):
logger = logging.getLogger("my_custom_logger")
logger.warning("This is a warning")
return str(x)
spark.conf.set("spark.sql.pyspark.worker.logging.enabled", "true")
spark.range(1).select(my_udf("id")).show()
Output
+----------+
|my_udf(id)|
+----------+
| 0|
+----------+
Example 2: View collected logs
Python
spark.tvf.python_worker_logs().select(
"level", "msg", "context", "logger"
).show(truncate=False)
Output
+-------+-----------------+---------------------+----------------+
|level |msg |context |logger |
+-------+-----------------+---------------------+----------------+
|WARNING|This is a warning|{func_name -> my_udf}|my_custom_logger|
+-------+-----------------+---------------------+----------------+