Re: [HACKERS] SendRowDescriptionMessage() is slow for queries with alot of columns
От | Andres Freund |
---|---|
Тема | Re: [HACKERS] SendRowDescriptionMessage() is slow for queries with alot of columns |
Дата | |
Msg-id | 20170927172019.gheidqy6xvlxb325@alap3.anarazel.de обсуждение исходный текст |
Ответ на | [HACKERS] SendRowDescriptionMessage() is slow for queries with a lot of columns (Andres Freund <andres@anarazel.de>) |
Ответы |
Re: [HACKERS] SendRowDescriptionMessage() is slow for queries with alot of columns
Re: [HACKERS] SendRowDescriptionMessage() is slow for queries with a lot of columns Re: [HACKERS] SendRowDescriptionMessage() is slow for queries with alot of columns |
Список | pgsql-hackers |
Hi, On 2017-09-13 23:34:18 -0700, Andres Freund wrote: > I'm not yet super sure about the implementation. For one, I'm not > sure this shouldn't instead be stringinfo.h functions, with very very > tiny pqformat.h wrappers. But conversely I think it'd make a lot of > sense for the pqformat integer functions to get rid of the > continually maintained trailing null-byte - I was hoping the compiler > could optimize that away, but alas, no luck. As soon as a single > integer is sent, you can't rely on 0 terminated strings anyway. I'd been wondering about missing CPU optimizations after the patch, and hunted it down. Turns out the problem is that htons/ntohs are, on pretty much all glibc versions, implemented using inline assembler. Which in turns allows the compiler very little freedom to perform optimizations, because it doesn't know what's actually happening. Attached is an extension of the already existing pg_bswap.h that a) adds 16 bit support b) moves everything to inline functions, removing multiple evaluation hazards that were present everywhere. c) adds pg_nto{s,l,ll} and pg_hton{s,l,ll} wrappers that only do work if necessary. This'll allow the later patches to allow the compiler to perform the relevant optimizations. It also allows to optimize e.g. pq_sendint64() to avoid having to do multiple byteswaps. Greetings, Andres Freund -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers
Вложения
В списке pgsql-hackers по дате отправления: