How to Kill a Process ID in PostgreSQL
Today, we’ll learn how to kill or stop a running query in the background while using the PostgreSQL database.
If the front-end ceases to work and the background process is still running, this may happen. In that scenario, you may want to kill the process.
Use the pg_cancel_backend
to Kill a Process ID in PostgreSQL
First of all, view all the running tasks using this command:
postgresqlCopyselect * from pg_stat_activity;
Now, if you want to drop a task from here, use the query:
postgresqlCopySELECT pg_cancel_backend(11080), pg_terminate_backend(11080) FROM pg_stat_activity WHERE state = 'active';
We used 11080 for the active
process and terminated it using this statement. It will return to idle
later on.
So, pg_cancel_backend
tends to be a little lenient in terminating a process as it requires some time. But in many cases, it may come back running; hence we use the pg_terminate_backend
to hard kill the process.
Do not call this the only active process in your system, as that may close off your current query. Hence, use these functions wisely and only when needed.
Instead of killing a process, you can always choose to terminate the current PostgreSQL session and restart it again.
Hello, I am Bilal, a research enthusiast who tends to break and make code from scratch. I dwell deep into the latest issues faced by the developer community and provide answers and different solutions. Apart from that, I am just another normal developer with a laptop, a mug of coffee, some biscuits and a thick spectacle!
GitHub