Skip to main content

Provide a deterministic session garbage collection instead of the default random one

Project description

Beta License: AGPL-3 OCA/server-tools Translate me on Weblate Try me on Runboat

Whenever a new request is processed by Odoo, this statement is evaluated: random.random() < 0.001 [1]

1 time out of 1000 in average, it will return True and trigger the Garbage Collection of sessions: sessions that have not been active for more than 1 week will be deleted [2]

This random approach can become a problem in some contexts.

On a highly visited Odoo website, many sessions will be created. Going through all of them will take some time, especially on a slow/loaded FS. The Garbage Collection happening randomly, your users will report you cases of Odoo being randomly slow on random actions. They won’t be able to reproduce these cases and you won’t be able to trace them in your odoo logs neither, because calls’ response time doesn’t include the time Odoo spent on the Garbage Collection.

Moreover, on a heavily loaded server, better be in a position to control when does the Garbage Collection happen. One might want to run it once per night only for example.

That’s why we created this module:

  • to disable the default random Garbage Collection

  • to enable administrators to replace it by a deterministic approach:

    • either by using the included Scheduled Action;

    • or by calling the added public method ir.autovacuum:gc_sessions() remotely

Table of contents

Installation

You need to load this module server-wide:

  • By starting Odoo with --load=web,base_deterministic_session_gc

  • Or by updating its configuration file:

[options]
(...)
server_wide_modules = web,base_deterministic_session_gc

You also need to install it in your database if you want to use the provided deterministic approach.

Configuration

You can change the session expiry delay in the Odoo configuration file:

[options]
(...)
; 1 day = 60*60*24 seconds
session_expiry_delay = 86400

Default value is 7 days.

Bug Tracker

Bugs are tracked on GitHub Issues. In case of trouble, please check there if your issue has already been reported. If you spotted it first, help us to smash it by providing a detailed and welcomed feedback.

Do not contact contributors directly about support or help with technical issues.

Credits

Authors

  • Trobz

Contributors

Maintainers

This module is maintained by the OCA.

Odoo Community Association

OCA, or the Odoo Community Association, is a nonprofit organization whose mission is to support the collaborative development of Odoo features and promote its widespread use.

This module is part of the OCA/server-tools project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

File details

Details for the file odoo12_addon_base_deterministic_session_gc-12.0.1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for odoo12_addon_base_deterministic_session_gc-12.0.1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a4147f8880ea1ce82a8cac67fe4592de3a15bfadf25a98bb1f425c70c6051050
MD5 77acb6431aa7745d7bcb13a804c886f1
BLAKE2b-256 cc87f2b8e6c544f8706a7880c6d615218e5b3c52b353cd1119e250485a2aa6eb

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page