Skip to main content

Production Monitoring

Opik has been designed from the ground up to support high volumes of traces making it the ideal tool for monitoring your production LLM applications.

You can use the Opik dashboard to review your feedback scores, trace count and tokens over time at both a daily and hourly granularity.

Opik monitoring dashboard

In addition to viewing scores over time, you can also view the average feedback scores for all the traces in your project from the traces table.

Logging feedback scores

To monitor the performance of your LLM application, you can log feedback scores using the Python SDK and through the UI.

Defining online evaluation metrics

You can define LLM as a Judge metrics in the Opik platform that will automatically score all, or a subset, of your production traces. You can find more information about how to define LLM as a Judge metrics in the Online evaluation section.

Once a rule is defined, Opik will score all the traces in the project and allow you to track these feedback scores over time.

tip

In addition to allowing you to define LLM as a Judge metrics, Opik will soon allow you to define Python metrics to give you even more control over the feedback scores.

Manually logging feedback scores alongside traces

Feedback scores can be logged while you are logging traces:

from opik import track, opik_context

@track
def llm_chain(input_text):
# LLM chain code
# ...

# Update the trace
opik_context.update_current_trace(
feedback_scores=[
{"name": "user_feedback", "value": 1.0, "reason": "The response was helpful and accurate."}
]
)

Updating traces with feedback scores

You can also update traces with feedback scores after they have been logged. For this we are first going to fetch all the traces using the search API and then update the feedback scores for the traces we want to annotate.

Fetching traces using the search API

You can use the Opik.search_traces method to fetch all the traces you want to annotate.

import opik

opik_client = opik.Opik()

traces = opik_client.search_traces(
project_name="Default Project"
)
tip

The search_traces method allows you to fetch traces based on any of trace attributes, you can learn more about the different search parameters in the search traces documentation.

Updating feedback scores

Once you have fetched the traces you want to annotate, you can update the feedback scores using the Opik.log_traces_feedback_scores method.

for trace in traces:
opik_client.log_traces_feedback_scores(
project_name="Default Project",
feedback_scores=[{"id": trace.id, "name": "user_feedback", "value": 1.0, "reason": "The response was helpful and accurate."}],
)

You will now be able to see the feedback scores in the Opik dashboard and track the changes over time.