On 2015-01-14 09:22:45 -0600, Merlin Moncure wrote: > On Wed, Jan 14, 2015 at 9:11 AM, Andres Freund <and...@2ndquadrant.com> wrote: > > On 2015-01-14 10:05:01 -0500, Tom Lane wrote: > >> Merlin Moncure <mmonc...@gmail.com> writes: > >> > On Wed, Jan 14, 2015 at 8:41 AM, Tom Lane <t...@sss.pgh.pa.us> wrote: > >> >> What are the autovac processes doing (according to pg_stat_activity)? > >> > >> > pid,running,waiting,query > >> > 7105,00:28:40.789221,f,autovacuum: VACUUM ANALYZE pg_catalog.pg_class > > > > It'd be interesting to know whether that vacuum gets very frequent > > semaphore wakeups. Could you strace it for a second or three? > > for 30 seconds+ it just looks like this: > mmoncure@mernix2 ~ $ sudo strace -p 7105 > Process 7105 attached > semop(5701638, {{4, -1, 0}}, 1
Ok. So that explains why it's not interruptible. > all of other processes are yielding out of the spinlock, for example: > select(0, NULL, NULL, NULL, {0, 1408}) = 0 (Timeout) Note the above isn't the spinlock, it's the process's semaphore. It'll only get set if the refcount ever indicates that nobody but autovac is holding the lock. > > How did this perform < 9.4? > this is a new project. However, I can run it vs earlier version. > > Can you guess how many times these dynamic > > statements are planned? How many different relations are accessed in the > > dynamically planned queries? > > only once or twice, and only a couple of tables. Hm. Odd. The first -g profile seemed to indicate a hell of a lot time was spent in LWLockRelease() - indicating that there's actually progress. Later profiles/backtraces were less clear. If you gdb in, and type 'fin' a couple times, to wait till the function finishes, is there actually any progress? I'm wondering whether it's just many catalog accesses + contention, or some other problem. Alternatively set a breakpoint on ScanPgRelation() or so and see how often it's hit. > I can send the code off-list if you guys think it'd help. Might be interesting. Greetings, Andres Freund -- Andres Freund http://www.2ndQuadrant.com/ PostgreSQL Development, 24x7 Support, Training & Services -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers