Streamlit in Snowflake 日志记录和跟踪¶
您可以在 Streamlit 应用程序代码执行时捕获日志消息并跟踪事件,然后使用 SQL 分析结果(例如分析错误)。有关更多信息,请参阅 日志记录、跟踪和指标。
设置事件表¶
要记录并跟踪 Streamlit 应用程序代码,需要创建事件表,将事件表与账户关联,并设置日志和跟踪事件级别。例如:
-- Create an event table if it doesn't already exist
CREATE EVENT TABLE SAMPLEDATABASE.LOGGING_AND_TRACING.SAMPLE_EVENTS;
-- Associate the event table with the account
ALTER ACCOUNT SET EVENT_TABLE = SAMPLEDATABASE.LOGGING_AND_TRACING.SAMPLE_EVENTS;
-- Set the log level for the database containing your app
ALTER DATABASE STREAMLIT_TEST SET LOG_LEVEL = INFO;
-- Set the trace level for the database containing your app
ALTER DATABASE SAMPLEDATABASE SET TRACE_LEVEL = ON_EVENT;
有关更多信息,请参阅 事件表概述。
示例:从 Streamlit 应用程序记录日志¶
import logging
import streamlit as st
logger = logging.getLogger("simple_logger")
# Write directly to the app
st.title("Simple Logging Example")
# Get the current credentials
session = st.connection('snowflake').session()
def get_log_messages_query() -> str:
"""
Get data from the `EVENT TABLE` where the logs were created by this app.
"""
return """
SELECT
TIMESTAMP,
RECORD:"severity_text"::VARCHAR AS SEVERITY,
RESOURCE_ATTRIBUTES:"db.user"::VARCHAR AS USER,
VALUE::VARCHAR AS VALUE
FROM
SAMPLE_EVENTS
WHERE
SCOPE:"name" = 'simple_logger'
ORDER BY
TIMESTAMP DESC;
"""
button = st.button("Log a message")
if button:
try:
logger.info("Logging an info message through Stremlit App.")
st.success('Logged a message')
except Exception as e:
logger.error("Logging an error message through Stremlit App: %s",e)
st.error('Logged an error')
sql = get_log_messages_query()
df = session.sql(sql).to_pandas()
with st.expander("**Show All Messages**"):
st.dataframe(df, use_container_width=True)
示例:从 Streamlit 应用发出跟踪¶
备注
以下示例需要安装 snowflake-telemetry-python
包。有关更多信息,请参阅 添加对遥测包的支持。
import streamlit as st
import time
import random
from snowflake import telemetry
def sleep_function() -> int:
"""
Function that sleeps for a random period of time, between one and ten seconds.
"""
random_time = random.randint(1, 10)
time.sleep(random_time)
return random_time
def get_trace_messages_query() -> str:
"""
Get data from the `EVENT TABLE` where the logs were created by this app.
"""
return """
SELECT
TIMESTAMP,
RESOURCE_ATTRIBUTES :"db.user" :: VARCHAR AS USER,
RECORD_TYPE,
RECORD_ATTRIBUTES
FROM
SAMPLE_EVENTS
WHERE
RECORD :"name" :: VARCHAR = 'tracing_some_data'
OR RECORD_ATTRIBUTES :"loggin_demo.tracing" :: VARCHAR = 'begin_span'
ORDER BY
TIMESTAMP DESC;
"""
def trace_message() -> None:
"""
Add a new trace message into the event table.
"""
execution_time = sleep_function()
telemetry.set_span_attribute("loggin_demo.tracing", "begin_span")
telemetry.add_event(
"tracing_some_data",
{"function_name": "sleep_function", "execution_time": execution_time},
)
# Write directly to the app
st.title("Simple Tracing Example")
# Get the current credentials
session = st.connection('snowflake').session()
button = st.button("Add trace event")
if button:
with st.spinner("Executing function..."):
trace_message()
st.toast("Succesfully log a trace message!", icon="✅")
sql = get_trace_messages_query()
df = session.sql(sql).to_pandas()
with st.expander("**Show All Trace Messages**"):
st.dataframe(df, use_container_width=True)