HiveBrain v1.2.0
Get Started
← Back to all entries
patternsqlMajor

CPU usage constantly high after upgrading from Postgres 9.5 to 9.6 to 10.6

Submitted by: @import:stackexchange-dba··
0
Viewed 0 times
afterpostgresupgradinghighusageconstantlycpufrom

Problem

I upgraded my RDS instance (db.t2.medium) from Postgres 9.5 to 9.6 couple of days back. Since the upgrade, the CPU usage was almost 100% all the time. This brought down my application. Presuming that the problem is with the 9.6 version, I did another upgrade to 10.6. It got better but still considerably higher than the CPU usage for the original 9.5 version.

I haven't changed the application code during the upgrade. How can I check the reason for the increased CPU usage and possibly fix it?

Solution

ANALYZE VERBOSE;


You need to run an ANALYZE query on the whole database using the above command.

The issue is that the query plans postgres has generated are optimised for the previous version of postgres, when you do an RDS update it does not implicity regenerate these plans, this needs to be done manually (I'm sure there's a reason why AWS doesn't do this manually but I've really no idea why).

In my case I saw roughly a week of extremely high CPU usage, just as in your case, then after running ANALYZE my cpu dropped back to it's previous baseline. As you can see in the image below the upgrade (in my case from 9.4 - 9.5) was run on 11/27, the analyze query was run on 12/02.

(The VERBOSE is not strictly necessary but it's useful to be able to watch the progress of the command)

Code Snippets

ANALYZE VERBOSE;

Context

StackExchange Database Administrators Q#228981, answer score: 42

Revisions (0)

No revisions yet.