PostgreSQL, and ODBC statement handles

From: Reza Taheri <rtaheri(at)vmware(dot)com>
To: "pgsql-interfaces(at)postgresql(dot)org" <pgsql-interfaces(at)postgresql(dot)org>
Subject: PostgreSQL, and ODBC statement handles
Date: 2017-05-03 23:41:33
Message-ID: CY4PR05MB2791D721221B213FFDF133AFDE160@CY4PR05MB2791.namprd05.prod.outlook.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-interfaces

I am running a benchmark (TPCx-V) with a single process on the client system handing all the load. Each connection to the server is in a separate thread with its own connection to PGSQL, and its own connection handle and statement handle. I am facing a contention problem with ODBC on the client side. strace and perf top show we are serializing over what appears to be accesses to the ODBC statement handle. Contention goes away if I use multiple processes instead of multiple threads within a process.

I suppose I don't understand the concept of "handles" well, but I am surprised that all the threads get the same connection handle number and the same statement handle number. Does that mean some data structure is shared between the different threads? Is there a way to force different statement handles (or handle numbers???) for different threads within one process? I have asked this question on the ODBC mailing list, and they suggested it could be something in the postgresql driver. I can provide detailed performance data, but maybe someone can help me figure out what might be a very basic configuration or parameter setting problem. I am running the following RPMs on RHEL 7.1:
postgresql93-9.3.5-2PGDG.rhel7.x86_64
postgresql93-odbc-09.03.0300-1PGDG.rhel7.x86_64
unixODBC-2.3.1-10.el7.x86_64

Thanks,
Reza

Responses

Browse pgsql-interfaces by date

  From Date Subject
Next Message Tom Lane 2017-05-04 04:12:49 Re: PostgreSQL, and ODBC statement handles
Previous Message Greg Sabino Mullane 2017-04-26 02:17:47 DBD::Pg version 3.6.0 released