• Resolved nyhotdogman

    (@nyhotdogman)


    Hi Ollie, first of all – thanks a lot for addressing this super urgent issue. We have read this thread here: https://www.ads-software.com/support/topic/backend-edit-products-extremely-slow-80-seconds/ and then decided to install your new plugin. The tables were created in around 3 hours (we have around 400k orders in our database). We can see the action scheduler ran successfully. We can see order lookup appears to be faster BUT we still have HUGE slowness when opening an order (gateway timeouts). Are there any other suggestion on what we can do or why your fix is not working? We are on Woocommerce 8.9.3 and use WP Rocket.

    In a message in the above mentioned thread you commented:

    That regression disrupted stores with many orders. Root cause: A SQL query was added to fetch the distinct non-private meta_key values from wp_wc_orders_meta. The way it worked was very slow. (A full scan of the table is required to satisfy the offending query.)

    Changing it to use the same pattern as a similar query in core resolved the problem. Here’s the place in my plugin that patches the query. That change is in WooCommerce’s 9.0.0 code. (not 8.9.0)

    https://github.com/OllieJones/fast-woo-order-lookup/blob/3e9f25347cc96e43f166029e49e42e51816d5bb9/fast-woo-order-lookup.php#L345

    Are you sure this patch is still working with ver 8.9.3?

    Thanks a lot and have a nice day

    Sebastian

Viewing 12 replies - 1 through 12 (of 12 total)
  • Plugin Author OllieJones

    (@olliejones)

    Thanks for the feedback about this. I will take a look and let you know.

    Your 503 timeout surely implicates an absurdly slow query.

    Plugin Author OllieJones

    (@olliejones)

    Hi, you are absolutely right that a change in WooCommerce 8.9.3 made my monkeypatch of the slow query stop working correctly. They changed the slow query, but alas, did not make it any faster. https://github.com/OllieJones/fast-woo-order-lookup/issues/11

    This is fixed in version 0.4.1 of the plugin. Thanks again for your feedback. As always, please let me know if you still have trouble.

    Thread Starter nyhotdogman

    (@nyhotdogman)

    @olliejones thanks a lot for your quick reply and the fix! I appreciate it a lot! Unfortunately it did not solve the slowness in the order page loading, still 30+ sec. We have NewRelic setup, I attached you a few details from one of the transactions, maybe it helps:

    1. Database queries: https://drive.google.com/open?id=1LOU8MofC11LNby3NulUleE48rwNe9D81&usp=drive_fs

    2) MySQL wp_wc_orders_meta select / 32.37 s

    MySQL wp_wc_orders_meta select

    backtrace

    in mysqli_query called at /var/www/html/wp-includes/class-wpdb.php (2349), in wpdb::_do_query called at /var/www/html/wp-includes/class-wpdb.php (2263), in wpdb::query called at /var/www/html/wp-includes/class-wpdb.php (3107), in wpdb::get_col called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/DataStores/CustomMetaDataStore.php (265), in Automattic\WooCommerce\Internal\DataStores\CustomMetaDataStore::get_meta_keys called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/Admin/Orders/MetaBoxes/CustomMetaBox.php (126), in Automattic\WooCommerce\Internal\Admin\Orders\MetaBoxes\CustomMetaBox::order_meta_keys_autofill called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/Admin/Orders/MetaBoxes/CustomMetaBox.php (146), in Automattic\WooCommerce\Internal\Admin\Orders\MetaBoxes\CustomMetaBox::render_meta_form called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/Admin/Orders/MetaBoxes/CustomMetaBox.php (75), in Automattic\WooCommerce\Internal\Admin\Orders\MetaBoxes\CustomMetaBox::render_custom_meta_form called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/Admin/Orders/MetaBoxes/CustomMetaBox.php (60), in Automattic\WooCommerce\Internal\Admin\Orders\MetaBoxes\CustomMetaBox::output called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/Admin/Orders/Edit.php (372), in Automattic\WooCommerce\Internal\Admin\Orders\Edit::render_custom_meta_box called at /var/www/html/wp-admin/includes/template.php (1456), in do_meta_boxes called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/Admin/Orders/Edit.php (496), in Automattic\WooCommerce\Internal\Admin\Orders\Edit::render_meta_boxes called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/Admin/Orders/Edit.php (405), in Automattic\WooCommerce\Internal\Admin\Orders\Edit::display called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/Admin/Orders/PageController.php (293), in Automattic\WooCommerce\Internal\Admin\Orders\PageController::output called at /var/www/html/wp-includes/class-wp-hook.php (324), in WP_Hook::apply_filters called at /var/www/html/wp-includes/class-wp-hook.php (348), in WP_Hook::do_action called at /var/www/html/wp-includes/plugin.php (517), in do_action called at /var/www/html/wp-admin/admin.php (259)

    duration
    32373

    name
    Datastore/statement/MySQL/wp_wc_orders_meta/select

    port_path_or_id
    unknown

    sql_obfuscated
    SELECT DISTINCT meta_key FROM wp_wc_orders_meta WHERE meta_key != ? AND meta_key NOT LIKE ? ORDER BY meta_key ASC LIMIT ?

    timestamp
    1621

    I can also supply you any other information if you are interested. Once again, thanks a lot!

    Thread Starter nyhotdogman

    (@nyhotdogman)

    @olliejones I think I may have accidentally marked the issue as resolved, I adjusted it again now. I also saw woo 9.0 was released, but I do not see a fix for our issue in the change, despite woo support having accounced it in the other thread you commented on: https://github.com/woocommerce/woocommerce/blob/trunk/changelog.txt

    Thanks again ?? Sebastian

    Plugin Author OllieJones

    (@olliejones)

    I have to say, your problem is a bit puzzling. As far as I can see, WooCommerce 9.0.0 has fixed the problem, following exactly the traceback you sent me from New Relic. They’ve replaced the offending query with this one.

    SELECT DISTINCT meta_key 
    FROM wp_wc_orders_meta
    WHERE meta_key !=''
    AND meta_key NOT BETWEEN '_' AND '_z' /* they added this */
    AND meta_key NOT LIKE '\\_%'
    ORDER BY meta_key ASC
    LIMIT 30

    That is also what my patch did for earlier versions. In my setups this query doesn’t have the crippling performance problem of the stuff they rolled out in earlier versions.

    I could troubleshoot this further if you would send me the output of these wp-cli commands

    wp db query "SELECT VERSION()"
    wp db query "EXPLAIN SELECT DISTINCT meta_key FROM wp_wc_orders_meta WHERE meta_key !='' AND meta_key NOT BETWEEN '_' AND '_z' AND meta_key NOT LIKE '\\_%' ORDER BY meta_key ASC LIMIT 30"
    wp db query "EXPLAIN SELECT DISTINCT meta_key FROM wp_wc_orders_meta WHERE meta_key !='' AND meta_key NOT LIKE '\\_%' ORDER BY meta_key ASC LIMIT 30"

    Thanks for your patience.

    Thread Starter nyhotdogman

    (@nyhotdogman)

    Hi @olliejones thanks for your reply and sorry for my late reponse – I wanted to wait until we update to woocommerce 9.0.2, which we did now. So I can see the order edit page load decreased quite a bit – but it is still at around 17 seconds.

    1. See the trace:
    MySQL wp_wc_orders_meta selectPerformanceAttributes

    backtrace

    in mysqli_query called at /var/www/html/wp-includes/class-wpdb.php (2349), in wpdb::_do_query called at /var/www/html/wp-includes/class-wpdb.php (2263), in wpdb::query called at /var/www/html/wp-includes/class-wpdb.php (3107), in wpdb::get_col called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/DataStores/CustomMetaDataStore.php (265), in Automattic\WooCommerce\Internal\DataStores...

    duration
    15871

    name
    Datastore/statement/MySQL/wp_wc_orders_meta/select

    sql_obfuscated
    SELECT DISTINCT meta_key FROM wp_wc_orders_meta WHERE meta_key !=? AND meta_key NOT BETWEEN ? AND ? AND meta_key NOT LIKE ? ORDER BY meta_key ASC LIMIT ?

    timestamp
    4537

    2. Database query:

    Total duration: 15871.00 ms | Call count: 1 | Database instance: ip-###-##-##-## Query

    SELECT DISTINCT meta_key FROM wp_wc_orders_meta WHERE meta_key !=? AND meta_key NOT BETWEEN ? AND ? AND meta_key NOT LIKE ? ORDER BY meta_key ASC LIMIT ?Stack trace

                                                                                       in mysqli_query called at /var/www/html/wp-includes/class-wpdb.php (2349)

                                                                                    in wpdb::_do_query called at /var/www/html/wp-includes/class-wpdb.php (2263)

                                                                                        in wpdb::query called at /var/www/html/wp-includes/class-wpdb.php (3107)

                                  in wpdb::get_col called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/DataStores/CustomMetaDataStore.php (265)

    …ores\CustomMetaDataStore::get_meta_keys called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/Admin/Orders/MetaBoxes/CustomMetaBox.php (126)

    …CustomMetaBox::order_meta_keys_autofill called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/Admin/Orders/MetaBoxes/CustomMetaBox.php (146)

    …taBoxes\CustomMetaBox::render_meta_form called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/Admin/Orders/MetaBoxes/CustomMetaBox.php (75)

    …\CustomMetaBox::render_custom_meta_form called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/Admin/Orders/MetaBoxes/CustomMetaBox.php (60)

    …erce\Internal\Admin\Orders\MetaBoxes\CustomMetaBox::output called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/Admin/Orders/Edit.php (372)

                      in Automattic\WooCommerce\Internal\Admin\Orders\Edit::render_custom_meta_box called at /var/www/html/wp-admin/includes/template.php (1456)

                                               in do_meta_boxes called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/Admin/Orders/Edit.php (496)

    …\WooCommerce\Internal\Admin\Orders\Edit::render_meta_boxes called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/Admin/Orders/Edit.php (405)

    …\WooCommerce\Internal\Admin\Orders\Edit::display called at /var/www/html/wp-content/plugins/woocommerce/src/Internal/Admin/Orders/PageController.php (293)

                             in Automattic\WooCommerce\Internal\Admin\Orders\PageController::output called at /var/www/html/wp-includes/class-wp-hook.php (324)

                                                                          in WP_Hook::apply_filters called at /var/www/html/wp-includes/class-wp-hook.php (348)

                                                                                     in WP_Hook::do_action called at /var/www/html/wp-includes/plugin.php (517)

                                                                                                  in do_action called at /var/www/html/wp-admin/admin.php (259)

    3. Are you still interested in the output of the wp-cli commands you sent me? If yes, i will have my server admin send them to me shortly.

    I should add we still have your faster order lookup plugin enabled ?? Thanks again and have a great day

    Sebastian

    • This reply was modified 4 months, 4 weeks ago by nyhotdogman.
    • This reply was modified 4 months, 4 weeks ago by nyhotdogman.
    Plugin Author OllieJones

    (@olliejones)

    <rant>I’m starting to think the high in high-performance order storage is something to do with wakky weed, not with query efficiency. I wish we had a really big reference WooCommerce database available to the world for testing.<rant>

    @nyhotdogman: Are you willing to work with me to anonymize and redact a copy of your system so it can be used that way?

    This absurdly inefficient query populates the meta_name dropdown list in the order edit screen. That’s it.

    Let me investigate some more. In the meantime you can use better keys on that table. See this: https://www.plumislandmedia.net/wordpress/performance/woocommerce-key-improvement/#wp_wc_orders_meta

    Or if you don’t want to redo all the keys on that table you can simply say this to wp-cli. It will add a key that works on this query.

    wp db query "ALTER TABLE wp_wc_orders_meta ADD KEY  slow_ordermeta_workaround(meta_key)"
    Plugin Author OllieJones

    (@olliejones)

    I built a gigantic fake table and tested the query in 9.0.0. Sure enough, it runs in O(n) time with the database keys delivered with WooCommerce.

    I investigated caching the resultset of the slow query in a transient, then delivering the cached data in response to the postmeta_form_keys filter. However, the wp_wc_orders_meta table update code doesn’t have appropriate hooks built in to allow the cache to be either updated or invalidated if something stores a new meta_key value in that table.

    So, I think the best solution to the problem is to add the non-prefixed database key on the meta_key column to the table. My test shows the offending query runs in O(log(n)) time with that index, which is what we want.

    I’ll work on adding this table to our Index WP MySQL For Speed plugin.

    Thanks for your patience as I continue to sort this out.

    • This reply was modified 4 months, 3 weeks ago by OllieJones.
    Thread Starter nyhotdogman

    (@nyhotdogman)

    Unbelievable. Thanks a lot @olliejones for investigating this! Let me know if there is anything I can test for you. My server admin himself actually added indexes to our order tables a while ago (I think back using wooc 7 – we had huge slowness, after his indexes suddenly checkout times for clients went from 15 seconds to 4 seconds). I will then need to double check with him so using your Index WP MySQL For Speed?plugin does not cause a conflict. But I will test as soon as you have an update. Thanks again!

    Thread Starter nyhotdogman

    (@nyhotdogman)

    @olliejones just checking in to see if you possibly had time to investigate this further? I also sent you an email (to the address I found on plumislandmedia). Thanks in advance!

    Plugin Author OllieJones

    (@olliejones)

    The latest version of this plugin, https://www.ads-software.com/plugins/fast-woo-order-lookup/, contains a cache to handle the offending query. That should help you with the performance problem.

    Thread Starter nyhotdogman

    (@nyhotdogman)

    @olliejones wow, like magic! Order loading went from 15-20 seconds to under 4 seconds. Thanks a lot!

Viewing 12 replies - 1 through 12 (of 12 total)
  • You must be logged in to reply to this topic.