User Sessions

This article covers frequently asked questions about the User Sessions chart and sessions in the event streams. Please also refer to Track sessions for how Amplitude defines and calculates sessions.

Why is my User Sessions chart empty?

The User Sessions chart requires valid session IDs for events. A valid session ID is one that has a value other than -1. You can determine if the events in your project have session IDs by checking any user's event streams. 

Why are there so many zero-length sessions in my User Sessions chart?

There are two likely causes when you see a large number of users in the “0 sec” session data point in the User Session chart.

Potential cause #1: Out-of-session events

Amplitude considers events sent using the HTTP API is calculated based on the formula:

max(client_event_time) - session_id

If you want these events to be considered part of a session, the session ID should be a timestamp reflecting the beginning of the session in epoch time.

Potential cause #2: You're tracking the Start Session event, but no other events

If your project permits sending start or end session events (which you can enable using Android SDK or iOS SDK), anytime your app launches in the foreground, it will send a Start Session to Amplitude. If Amplitude receives no other events to log after this, it sets the session length to zero.

Amplitude's Microscope feature lets you examine a given user’s activity, so you can quickly determine whether either of these potential causes is the issue.

When is the Amplitude Start Session event triggered?

This happens when the app enters the foreground, or when the SDK is initialized in the foreground.

Why are there empty sessions with no active events in the user event streams? When using mobile SDKs with start or end session events enabled, you may see sessions that include only the Start Session and End Session events. There are a few reasons why this occurs: 

  • The user enters and leaves the app without triggering custom events
  • The user triggers events that are blocked or deleted in your tracking plan, and which are therefore not ingested into Amplitude
  • Certain activities in the app (like backend notifications or identify calls) may bring the app to the foreground without triggering an actual event

Why do some mobile sessions contain a gap of over five minutes, or why do some sessions last an unusually long time?

Some common reasons are: 

  • The default session timeout window has changed (set to 5 minutes for mobile SDKs by default)
  • Activities in the app (like backend notifications or identify calls) may bring the app to the foreground between two actual sessions, leading to unexpectedly long sessions

Does the change of custom session apply retroactively?

Yes. Once you change the custom session definition, all sessions, including those logged before the change, will be grouped based on the new definition. 

Does the definition of custom session affect the raw data?

It does not affect the raw data, and you can revert it to the default session definition at any time.

Does a server-side integration between Amplitude and Segment provide a Session ID automatically? Please see the FAQ article on Segment / Amplitude integration to learn more.

Was this page helpful?

Thanks for your feedback!

July 4th, 2024

Need help? Contact Support

Visit Amplitude.com

Have a look at the Amplitude Blog

Learn more at Amplitude Academy

© 2024 Amplitude, Inc. All rights reserved. Amplitude is a registered trademark of Amplitude, Inc.