Thread: [PATCH] Using mimalloc to improve performance and reduce memory allocation lock contention

Hi,

We have a multi-threaded Windows application that was experiencing delays due to high lock contention in memory allocations from the PostgreSQL ODBC driver. We tried modifying the driver to use mimalloc, which is a memory allocator with better performance characteristics. After deploying this change, the delays due to lock contention disappeared. It has been running on thousands of our production deployments for 9 months without issue.

I've created this pull request so that others can benefit from this change by building the driver with the _MIMALLOC_ symbol defined and linking to the mimalloc library.

In my patch, the usage of mimalloc is off by default, so it should be safe to merge. But I'd like to get people's thoughts on whether it should be enabled by default so that people can benefit from this change without having to build the driver themselves.

Regards,
Adrian

iress.com
Adrian Grucza  
Technical Lead
Office: +61390185800
adrian.grucza@iress.com
www.iress.com
Level 16 385 Bourke St
 Melbourne, Victoria, 3000
The contents of this email originated from Iress. For this purpose Iress includes Iress Limited and/or any of its subsidiaries, holding companies and trading entities. ​If you have received this email in error please notify the sender immediately and delete this email. 
nosig


On Mon, 25 Mar 2024 at 01:42, Adrian Grucza <adrian.grucza@iress.com> wrote:
Hi,

We have a multi-threaded Windows application that was experiencing delays due to high lock contention in memory allocations from the PostgreSQL ODBC driver. We tried modifying the driver to use mimalloc, which is a memory allocator with better performance characteristics. After deploying this change, the delays due to lock contention disappeared. It has been running on thousands of our production deployments for 9 months without issue.

I've created this pull request so that others can benefit from this change by building the driver with the _MIMALLOC_ symbol defined and linking to the mimalloc library.

In my patch, the usage of mimalloc is off by default, so it should be safe to merge. But I'd like to get people's thoughts on whether it should be enabled by default so that people can benefit from this change without having to build the driver themselves.

Cool, 

Thanks, I will have a look

Dave