PostHog Integration
- HobbyPublic Beta
- ProPublic Beta
- TeamPublic Beta
- Self HostedNot Available
PostHog (opens in a new tab) is a popular choice for OSS product analytics. While Langfuse offers analytics out of the box, many of our users have asked for a way to integrate their LLM related metrics that they capture with Langfuse into their PostHog dashboards.
We've built an integration to make it easy to answer questions like:
- "Are my most active users also the ones who are most engaged with my LLM content?"
- "Does interacting with the LLM feature relate to higher retention rates?"
- "How does the LLM feature impact my conversion rates?"
- "Does the user feedback that I capture in Langfuse correlate with the user behavior that I see in PostHog?"
Get started
Enable the integration
Configure this integration in your Langfuse project settings. You will need to provide your PostHog Hostname and API key.
Build a dashboard in PostHog
Once integrated, you can build a dashboard in PostHog to visualize your Langfuse metrics (see reference below). Use the AI Metrics template to get started with a pre-built dashboard that includes the most common metrics from Langfuse.
Example PostHog Dashboard
Integration details
On a daily schedule Langfuse batches aggregated events and metrics to your PostHog instance.
Metadata matching
Matching of metadata helps to join the data from Langfuse with the data from PostHog:
Langfuse | PostHog | Notes |
---|---|---|
user_id | $distinct_id | |
trace.timestamp , generation.started_at , score.timestamp | timestamp | |
trace.metadata.$posthog_session_id | $session_id | Optional, you need to add the PostHog session id to your Langfuse traces. |
User properties
We send the following user properties via '$set'
:
langfuse_user_url
: Deeplink to the user profile in Langfuse.
Events
The integration sends the following events to PostHog.
Is there any additional information that would be helpful? You can request more events or properties here.
Event: langfuse trace
timestamp
: The time the event occurred.langfuse_trace_name
: The name of the trace.langfuse_url
: The URL of the trace.langfuse_id
: The unique identification of the trace.langfuse_cost_usd
: The total cost associated with the trace.langfuse_count_observations
: The number of observations in the trace.langfuse_session_id
: The session ID related to the event.langfuse_project_id
: An ID associated with the project related to the event.langfuse_user_id
: User ID related to the event. If it's null, it's marked as langfuse_unknown_user.langfuse_latency
: The latency of the event.langfuse_release
: Information relating to the event release.langfuse_version
: The version of the event.langfuse_tags
: Any tags associated with the event.langfuse_integration_version
: The integration version of LangFuse.
Event: langfuse generation
timestamp
: The start time of the generation.langfuse_generation_name
: The name of the generation.langfuse_trace_name
: Name of the trace related to the generation.langfuse_url
: The URL of the generation on the host platform.langfuse_id
: Unique identifier of the generation.langfuse_cost_usd
: Computed total cost of the generation.langfuse_input_units
: Number of tokens utilized in prompting the generation.langfuse_output_units
: Number of tokens produced by the generation.langfuse_total_units
: Total number of tokens consumed in the generation process.langfuse_unit
: The units used for the generation (likely tokens).langfuse_session_id
: The session ID associated with the trace of the generation.langfuse_project_id
: The project identification where the generation happened.langfuse_user_id
: The user ID that started the trace linked to the generation. In case it's unavailable, it defaults tolangfuse_unknown_user
.langfuse_latency
: The observed latency of the generation.langfuse_time_to_first_token
: The time taken to generate the first token when streaming.langfuse_release
: Release information of the trace attached with the generation.langfuse_version
: The versioning info about the generation.langfuse_model
: The model used during this generation's process.langfuse_level
: The level associated with the generation.langfuse_tags
: Any tags attached to the trace of the generation.langfuse_integration_version
: The integration version with LangFuse.
Event langfuse score
timestamp
: The time when the score event occurred.langfuse_score_name
: The name associated with the score.langfuse_score_value
: The value of the score.langfuse_score_comment
: Any comments attached with the score.langfuse_trace_name
: The name of the trace associated with the score.langfuse_id
: The unique identification of the score.langfuse_session_id
: The session identification related to the score's trace.langfuse_project_id
: The project identification linked with the score's trace.langfuse_user_id
: The user ID that triggered the trace tied with the score. If not available, defaults tolangfuse_unknown_user
.langfuse_release
: The release information of the trace associated with the score.langfuse_tags
: Any tags related to the trace of the score.langfuse_integration_version
: The integration version with LangFuse.
Troubleshooting
Missing data in PostHog? Please check that you have correctly entered the PostHog hostname and API key in your Langfuse project settings. Also, if you use the PostHog free-tier, please make sure that you have not exceeded the event limits as PostHog drops events when the limit is reached. Reach out to us if you encounter any other issues with the integration.