[ODBC] PostgreSQL, and ODBC statement handles - Mailing list pgsql-odbc

From Reza Taheri
Subject [ODBC] PostgreSQL, and ODBC statement handles
Date
Msg-id AEDF45A5-DED8-4799-942B-57475EF72C17@vmware.com
Whole thread Raw
Responses Re: [ODBC] PostgreSQL, and ODBC statement handles  ("Inoue, Hiroshi" <h-inoue@dream.email.ne.jp>)
List pgsql-odbc

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 handlepgsq. 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

pgsql-odbc by date:

Previous
From: "Tsunakawa, Takayuki"
Date:
Subject: [ODBC] [bug fix] Handling the case where character conversion fails
Next
From: "Inoue, Hiroshi"
Date:
Subject: Re: [ODBC] PostgreSQL, and ODBC statement handles