Opened 10 years ago
Last modified 7 years ago
#2731 new enhancement
refactor the menu_order tool ("Recalculate the position of each reply")
Reported by: | tharsheblows | Owned by: | |
---|---|---|---|
Milestone: | 2.7 | Priority: | normal |
Severity: | normal | Version: | |
Component: | Tools | Keywords: | dev-feedback early |
Cc: | jjjay@… |
Description
This refers to #2654 and is about refactoring the menu_order tool here: https://bbpress.trac.wordpress.org/browser/branches/2.5/includes/admin/tools.php#L1144
I was working on this this morning and really just need a place to keep my results and (ideally) get feedback or told that I'm doing it all wrong which, honestly, would be super helpful as well.
Currently I have the following times from my last run:
-- the query with LIMIT 500 replies average time: 0.1032 s
-- bbp_update_reply_position( $reply->ID ) average time for each call: 0.01375 s <-- this of course varies with the number of replies to the topic, the std deviation is 0.004111s so quite large and I'm only doing a sample, not sure if I'm catching the really long topics
I am doing a max of 2500 replies (500 at a time) in total right now so the page doesn't time out, otherwise it does -- I haven't fine tuned this though, so I'm not exactly sure at what point it would. Definitely 10,000 replies is too much and 5,000 too, I think.
My first inclination would be to do this in chunks and have the page reload between each chunk, putting the offset in a POST variable and looking for it on the tool page load. Is there a better way? It should also be the case that if you choose to use that tool, that it's the *only* tool you can use but that's straightforward jQuery stuff.
It should be done so that the vast majority of the sites don't get the chunked version, I think that'd be around 1000 replies / around 15 seconds for me. I have no idea how different servers vary or if that's reasonable.
I also had a slightly different way of doing this and will see if I can get the update time down a little.
Attachments (9)
Change History (26)
This ticket was mentioned in Slack in #bbpress by tharsheblows. View the logs.
10 years ago
This ticket was mentioned in Slack in #bbpress by netweb. View the logs.
9 years ago
#4
@
9 years ago
- Milestone changed from Awaiting Review to 2.7
Let's move this to 2.7 and rework the repair tools and borrow from bbPress's import/converter panel to handle these tasks and loop through manageable size chunks.
#5
@
9 years ago
This is what I've been doing. It seems to work although not been tested thoroughly and will time out as discussed. I've just gone ahead and left in all the little timing things because I think they're interesting.
This ticket was mentioned in Slack in #bbpress by tharsheblows. View the logs.
9 years ago
This ticket was mentioned in Slack in #bbpress by tharsheblows. View the logs.
9 years ago
#9
@
9 years ago
It can only handle about 500 at a time but I just noticed it was ordering by ID rather than post_date in bbp_get_child_ids and that was causing issues. It needs to order by post_date but that's not an index. I'm not great at this sort of thing but could you change the query slightly and use FORCE INDEX type_status_date? It's WHERE post_type=reply AND status=publish ORDER BY post_date? Would that help? Does it matter? I have a feeling some of the larger sites who have never fixed this will have topics with thousands of replies and this will get all of them. What do you think?
Also this is just where I am. I think it's working now though, it'd be great if someone could give it a go -- please imagine it much much prettier with no alerts and lovely notices and the like. This is just for functionality.
#10
@
9 years ago
The patch 2731-tests.diff is a first pass at verifying bbp_admin_repair_reply_menu_order()
repairs reply order correctly.
Note: It doesn't account for the proposed changes in 2731.3.diff
#11
@
9 years ago
Thoughts on bbp_get_child_ids:
- it's stupid to change bbp_get_child_ids to use post_date for everything, it'd make more to pass something through to change the ORDER BY. That way almost everything could stay the same.
- Also really bad idea for index. It'll be fine, it'll be fine.
- The flush cache is in the for testing. Take it out.
- how long will a super long topic take? 10k replies.
Thoughts on the tool
- one way to mitigate a long bbp_get_child_ids query is to have the function cycle by time. Is this is bad idea?
- where do the responses and cancel button go? I was just going to put it in the td
- it needs a cancel button, an actual button or link
- the cancel button needs to call a kill process. It need to do something that will kill the tool. So maybe a value in wp_options or the cache (is this reliable?) or something that the tool checks each time it runs.
I'm sure there's some oh don't do that it's a really bad idea stuff above, when you notice it, please tell me.
#12
@
9 years ago
- only do published replies in bbp_get_child_ids when updating menu_order (it's currently doing spam / pending and trash too)
Also
- on pending (not published) -> publish and spam (hmmm) -> publish, re-do menu order at least for the posts after the changed post. Probably for trash too just in case. You'd have to do it the other way too, publish -> pending etc etc
#13
@
9 years ago
Working (but not styled) version of js. The checkbox is disabled, only the run link can be used at the moment. If there is a php only version, then people will need to be strongly encouraged to use the js version as it'll be better. (Do we absolutely need a php-only version?)
PLEASE NOTE: the iterations are alerts. You can kill the process by clicking the "kill process" link but still, the alerts are annoying. I just haven't styled the notifications yet which will *not* be alerts but something much nicer. :)
#14
@
9 years ago
fixes edge case in bbp_get_reply_positions_published for posts with non-unique post_date (phpunit tests should now work correctly with this)
also lower limit required when using bbp_db()
#15
@
9 years ago
with a non-js fallback and the checkbox usable (only for testing, this tool is much much better run with js)
#17
@
7 years ago
- Keywords early added
Along with this, is the idea of removing the menu_order
usage entirely (again) and simply counting on the ID
or post_date
columns to determine the order organically.
menu_order
was used to help get accurate pagination counts for private/hidden statuses, but it may not be necessary anymore since recent advancements went into performance improvements in our queries.
This is worth looking early in 2.7, IMO.
It would help to know the wp_posts table has about 65k entries for the above numbers, wouldn't it.
Here is the current code for reference: