Capturing messages from unhandled exceptions¶
By default, when you’ve set up an event table, Snowflake automatically logs unhandled exceptions in procedure and UDF handlers in the event table. Capturing these messages does not require that you add handler code specific to logging or tracing. You can disable this feature so that unhandled exceptions aren’t automatically logged.
Important
Error messages can contain sensitive information. Consider disabling this feature if you don’t want potentially sensitive information captured in an event table. To learn more, see Protecting sensitive data.
Configuring logging and tracing to capture unhandled exceptions¶
Set log or trace level so that Snowflake captures entries for unhandled exceptions. You can have entries captured as log entries, trace event entries, or both.
To capture messages as log entries, set the log level to
ERROR
or more verbose.To capture messages as trace event entries, set the trace level to
ALWAYS
orON_EVENT
.
Data captured for unhandled exceptions¶
You can capture message data as a log entry, a trace event, or both. The captured data will differ between log and trace event entries.
Data captured in a log entry¶
By default, Snowflake records the following in the event table for unhandled exceptions in procedure and UDF handlers:
Column |
Data |
---|---|
A |
|
The following attributes are recorded for an unhandled exception.
|
|
The string |
Example¶
Code in the following example queries an event table for log data recorded for an unhandled exception from a UDF handler.
For more about querying an event table for log data, see Accessing logged message data.
SET event_table_name = 'my_db.public.my_event_table';
SELECT
RECORD['severity_text'] AS severity,
RECORD_ATTRIBUTES['exception.message'] AS error_message,
RECORD_ATTRIBUTES['exception.type'] AS exception_type,
RECORD_ATTRIBUTES['exception.stacktrace'] AS stacktrace
FROM
my_event_table
WHERE
RECORD_TYPE = 'LOG';
The following is possible output from the query.
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
| SEVERITY | ERROR_MESSAGE | EXCEPTION_TYPE | STACKTRACE |
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
| "FATAL" | "could not convert string to float: '$1,000,000.00'" | "ValueError" | "Traceback (most recent call last):\n File \"_udf_code.py\", line 6, in compute\nValueError: could not convert string to float: '$1,000,000.00'\n" |
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
Data captured in a trace event entry¶
By default, Snowflake records the following in the event table for unhandled exceptions in procedure and UDF handlers:
Column |
Data |
---|---|
A |
|
The following attributes are recorded for an unhandled exception.
|
Examples¶
Code in the following examples query an event table for trace event data recorded for an unhandled exception from a UDF handler.
For more about querying an event table for trace event data, see Accessing trace data.
Span example¶
SET event_table_name = 'my_db.public.my_event_table';
SELECT
RECORD['status']['code'] AS span_status
FROM
my_event_table
WHERE
record_type = 'SPAN';
The following is possible output from the query.
-----------------------
| SPAN_STATUS |
-----------------------
| "STATUS_CODE_ERROR" |
-----------------------
Span event example¶
SET event_table_name = 'my_db.public.my_event_table';
SELECT
RECORD['name'] AS event_name,
RECORD_ATTRIBUTES['exception.message'] AS error_message,
RECORD_ATTRIBUTES['exception.type'] AS exception_type,
RECORD_ATTRIBUTES['exception.stacktrace'] AS stacktrace
FROM
my_event_table
WHERE
RECORD_TYPE = 'SPAN_EVENT';
The following is possible output from the query.
-----------------------------------------------------------------------------------------------------------------------------------------
| EVENT_NAME | ERROR_MESSAGE | EXCEPTION_TYPE | STACKTRACE |
-----------------------------------------------------------------------------------------------------------------------------------------
| "exception" | "could not convert string to float: '$1,000,000.00'" | "ValueError" | " File \"_udf_code.py\", line 6, in compute\n" |
-----------------------------------------------------------------------------------------------------------------------------------------
Protecting sensitive data¶
Given that log and trace messages from unhandled exceptions can include sensitive data, consider doing the following to protect that data:
Take steps to protect sensitive data, such as by doing the following:
Improve your exception handling code to minimize the risk of unhandled exceptions.
Apply row access policies to your event table to restrict access to rows that contain personally identifiable information (PII).
Create a view on top of the event table and apply masking policies to it to mask or delete personally identifiable information (PII).
Turn off unhandled exception logging by setting the ENABLE_UNHANDLED_EXCEPTIONS_REPORTING parameter to
false
.