Re: libpq compatibility policy across versions

From: Pavel Golub <pavel(at)microolap(dot)com>
To: Sebastien FLAESCH <sf(at)4js(dot)com>
Cc: pgsql-interfaces(at)postgresql(dot)org
Subject: Re: libpq compatibility policy across versions
Date: 2013-10-01 14:38:51
Message-ID: 807955869.20131001173851@gf.microolap.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-interfaces

Hello, Sebastien.

You wrote:

SF> Thank you Pavel,

SF> On 10/01/2013 02:28 PM, Pavel Golub wrote:
>> Yes, you should use the latest client library. It's compatible with
>> all prior versions.

SF> Just to be clear:

SF> We deliver our product without any PostgreSQL lib included.

Well, I prefer to deploy products with the latest lib included. Thus
I'm absolutely sure in the environment used.

SF> Our product installs beside an existing PostgreSQL install, typically
SF> on an application server, where both PostgreSQL client and server are
SF> installed in the same directory.

That's possible of course, but there are a lot of issues you may face
with IMHO

SF> Imagine for ex a machine with PostgreSQL 8.3 installed.

SF> I am asking how I must compile my source code and how to link, to build
SF> my binary, to be sure that it's compatible with PostgreSQL 8.3, and
SF> any in fact any existing PostgreSQL versions.

SF> Can I for ex, use the V 9.3 headers and library on my dev platform
SF> and then deliver this binary for any PostgreSQL version?

SF> In other words, is the PostgreSQL client C API backward compatible?

I'm not sure it is.

SF> Today the lib is stamped with 5 (libpq.so.5), will this never change
SF> in future versions?

SF> Is there a way to detect dynamically the version of the PostgreSQL server?

"SELECT version()" will do the trick using direct SQL.
http://www.postgresql.org/docs/9.3/static/functions-info.html

PQserverVersion - will help you if you need an integer representing the backend version.
http://www.postgresql.org/docs/9.3/static/libpq-status.html

SF> Thanks!
SF> Seb

SF> On 10/01/2013 02:28 PM, Pavel Golub wrote:
>> Hello, Sebastien.
>>
>> You wrote:
>>
>> SF> Hi all,
>>
>> SF> We have a libpq client application written in C.
>>
>> SF> We want to deliver the software so that can it be used with different
>> SF> PostgreSQL client versions, from 8.3 to 9.3 (and future versions).
>>
>> SF> So far, we build (compile and link) a binary with each major version
>> SF> of PostgreSQL (8.3, 8.4, 9.0, 9.1, 9.2, 9.3) - in fact we have shared
>> SF> libraries (database driver) for each PostgreSQL version.
>>
>> SF> Is this the proper way, or could we just compile/link with a given
>> SF> version (9.3) and assume that it's backward compatible with any
>> SF> prior version such as 8.3 ?
>>
>> Yes, you should use the latest client library. It's compatible with
>> all prior versions.
>>
>> SF> Assuming that we could dynamically load the libpq.so client, search
>> SF> for existing API symbols and only use them if present?
>>
>> SF> Is this risky? Do the C headers define C structures that are compatible
>> SF> between newer and older versions?
>>
>> SF> I would expect some note about libpq compatibility policy here:
>>
>> SF> http://www.postgresql.org/docs/9.3/static/libpq-build.html
>>
>> SF> I can see that the lib version number of libpq.so.x.y changes
>> SF> for each major version:
>>
>> SF> /opt3/dbs/pgs/9.2/lib/libpq.so -> libpq.so.5.5
>> SF> /opt3/dbs/pgs/9.2/lib/libpq.so.5 -> libpq.so.5.5
>> SF> /opt3/dbs/pgs/9.2/lib/libpq.so.5.5
>> SF> /opt3/dbs/pgs/9.3.0/lib/libpq.so -> libpq.so.5.6
>> SF> /opt3/dbs/pgs/9.3.0/lib/libpq.so.5 -> libpq.so.5.6
>> SF> /opt3/dbs/pgs/9.3.0/lib/libpq.so.5.6
>>
>> SF> The binaries are dependent from libpq.so.5:
>>
>> SF> $ ldd -r dbmpgs92x.so
>> SF> ...
>> SF> libpq.so.5 => /opt3/dbs/pgs/9.2.3/lib/libpq.so.5 (0xb77bb000)
>> SF> ...
>>
>> SF> What does this mean?
>>
>> SF> Theoritically, a binary linked in a 9.3 env can use le libpq.so version
>> SF> of a prior version down to 8.2 ... (8.1 has libpq.so.4)
>>
>> SF> The main question is about C header compatibility:
>>
>> SF> - Compile + link with PostgreSQL client version X.Y.?
>> SF> - What PostgreSQL client version can be used at runtime?
>>
>> SF> Thanks.
>> SF> Seb
>>
>>
>>
>>
>>

--
With best wishes,
Pavel mailto:pavel(at)gf(dot)microolap(dot)com

In response to

Responses

Browse pgsql-interfaces by date

  From Date Subject
Next Message Sebastien FLAESCH 2013-10-01 15:27:24 Re: libpq compatibility policy across versions
Previous Message Sebastien FLAESCH 2013-10-01 13:04:16 Re: libpq compatibility policy across versions