Docs

Session options

Clerk provides session management options for fine-tuning user visits to your application, including options for session lifetime, multi-session handling, and session token customization.

Session lifetime

Depending on the business domain of an application, there might be different requirements for how long users should remain signed in. Criteria to base this decision upon typically revolve around user activity on the application and how long it has been since the user first signed in.

Ultimately, picking the ideal session lifetime is a trade-off between security and user experience. Longer sessions are generally better for UX but worse for security; and vice-versa.

Fortunately, with Clerk you have to ability to fully control the lifetime of your users' sessions. There are two settings for doing so and you can set them via your instance settings in the Clerk Dashboard: Inactivity timeout and Maximum lifetime.

Note

Note that either one or both must be enabled at all times. For security reasons, you are not allowed to disable both settings.

Inactivity timeout

Inactivity timeout is the duration after which a session will expire and the user will have to sign in again, if they haven't been active on your site.

A user is considered inactive when the application is closed, or when the app stops refreshing the token.

By default, the inactivity timeout is set to 7 days. You can set a custom inactivity timeout by following these steps:

  1. Navigate to the Clerk Dashboard and select your application.
  2. In the navigation sidebar, select Sessions.
  3. Toggle on Inactivity timeout.
  4. Set your desired duration.

Maximum lifetime

The duration after which a session will expire and the user will have to sign in again, regardless of their activity on your site.

By default, this setting is enabled with a default value of 7 days for all newly created instances. To find this setting and change the value:

  1. Navigate to the the Clerk Dashboard and select your application.
  2. In the navigation sidebar, select Sessions.
  3. Toggle on Maximum lifetime.
  4. Set your desired duration.

Note

Safari will clear Clerk's session cookie every 7 days as an effect of their CNAME cloaking ITP policy. This will cause users to be signed out weekly, even if session lifetime is set to a longer duration. The only current workaround to this issue is to proxy FAPI.

Multi-session applications

A multi-session application is an application that allows multiple accounts to be signed in from the same browser at the same time. The user can switch from one account to another seamlessly. Each account is independent from the rest and has access to different resources.

To enable multi-session in your application, you need to configure it in the Clerk Dashboard.

  1. Navigate to the Clerk Dashboard and select your application.
  2. In the navigation sidebar, select Sessions.
  3. Toggle on Multi-session handling.
  4. Select Save changes.

There are two main ways to add the multi-session feature to your application:

Customize session token

Session tokens are JWTs that contain a set of default claims required by Clerk. You can customize these tokens by providing additional claims of your own.

To learn how to customize session tokens, check out our Customize your session token guide.

Feedback

What did you think of this content?

Last updated on