Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

WordPress.com REST API > Comment: audit and improve performance for comment counts #40587

Open
jeherve opened this issue Dec 12, 2024 · 0 comments
Assignees
Labels
[Feature] WPCOM API [Focus] Performance [Plugin] Jetpack Issues about the Jetpack plugin. https://wordpress.org/plugins/jetpack/ [Pri] Normal [Type] Task

Comments

@jeherve
Copy link
Member

jeherve commented Dec 12, 2024

seeing a case of Jetpack high resource utilization and breaking of site due to repeat query for comment counts

SELECT comment_approved, COUNT(*) AS num_comments
	FROM wp_siteid_comments
	WHERE comment_type IN ( 'comment','pingback','trackback','' )
	GROUP BY comment_approved

-- p1732041372458899-slack-C01U2KGS2PQ

Reference:

// phpcs:disable WordPress.DB.PreparedSQL.InterpolatedNotPrepared -- `$where` is built with escaping just above.
$count = $wpdb->get_results(
"SELECT comment_approved, COUNT(*) AS num_comments
FROM $wpdb->comments
{$where}
GROUP BY comment_approved
"
);
// phpcs:enable WordPress.DB.PreparedSQL.InterpolatedNotPrepared

Those direct queries were introduced in #10786 to allow us to include specific comment types in the counts.

The performance of the endpoint needs to be addressed so that it doesn’t lead to excessive query times and db connections becoming unavailable.
-- pdWQjU-156-p2

Seems like the initial first step may be to add caching for wp_count_comments in WPCOM_JSON_API, as @fgiannar had suggested in Slack at the time. Core's wp_count_comments does come with caching, but in some scenarios we do direct queries in the WordPress.com API instead for the reasons mentioned above.

Maybe it would also be worth looking at using get_comments() instead of doing a direct database query, since the underlying WP_Comment_Query does come with caching as well. This is what we do in other endpoints:

@jeherve jeherve added [Feature] WPCOM API [Focus] Performance [Plugin] Jetpack Issues about the Jetpack plugin. https://wordpress.org/plugins/jetpack/ [Pri] Normal [Type] Task labels Dec 12, 2024
@fgiannar fgiannar self-assigned this Dec 17, 2024
@fgiannar fgiannar removed their assignment Jan 6, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
[Feature] WPCOM API [Focus] Performance [Plugin] Jetpack Issues about the Jetpack plugin. https://wordpress.org/plugins/jetpack/ [Pri] Normal [Type] Task
Projects
None yet
Development

No branches or pull requests

3 participants