From 30886f710ec4b78d941f5ec2f23d4321f3702e5b Mon Sep 17 00:00:00 2001 From: Timothy Lukian Date: Mon, 14 Jan 2019 16:32:33 -0800 Subject: [PATCH 1/7] Create slowwww-reordering.md Details about collection/entry reordering and Spock interactions/delays, and workarounds/solutions. --- content/collections/kb/slowwww-reordering.md | 31 ++++++++++++++++++++ 1 file changed, 31 insertions(+) create mode 100644 content/collections/kb/slowwww-reordering.md diff --git a/content/collections/kb/slowwww-reordering.md b/content/collections/kb/slowwww-reordering.md new file mode 100644 index 00000000..cd1e5156 --- /dev/null +++ b/content/collections/kb/slowwww-reordering.md @@ -0,0 +1,31 @@ +--- +title: Reordering items in a collection saves very slowly (with Spock installed) +kb_categories: + - Troubleshooting Common Scenarios +--- +If you've got a numerically-ordered collection, and you use the *'Reorder'* functionality in the Control Panel, **and** you've got Spock installed, and set to push its commits automagically, you may have also noticed that the wait between clicking *'Save Order'* and being returned to the collection's entry listing can take a pretty long time. + +Statamic collections are organized by filename — by date (in the case of date-based entries), or by number (in the case of numerically-ordered entries). Statamic's entry-reordering operates by altering/updating the filenames of the files included in the view being reordered. + +Presently, Statamic's *'Reorder'* functionality fires off an event for **each** file that gets touched by a *'Reorder'* — and even if the relative order of a given entry isn't changing, if it's in the view within which the *'Reorder'* is taking place, it's getting touched by the process. + +Spock, in-turn, attempts to commit and — here's where things can get slowed down — `git push` the touched entries, one-at-a-time, up to your repository. Since each push takes some time to complete (whether or not the push is successful — more on that shortly), the total amount of time the Control Panel hangs up between saving the re-order, and returning you to the listing, is the total amount of time that ALL of those Spock-initiated `git push` commands take to execute. At sometimes upwards of a second or two per affected entry, this can add up. + +An additional piece of the puzzle is that *some* of the commits/pushes will probably fail, since some of the files have been touched, *but not actually changed at all* — and GIT sends back a response that in-turn winds up getting logged to Statamic's log file(s). Which *may* add to the experienced delays. + +## What can you do? + +- **Disable Spock's Automatic `git push`** + If Spock isn't attempting to `git push` each commit it makes, in sequence, this problem seems to be eliminated — or at least the execution time required for all of the commits is far less than if each of them is also being pushed, in sequence, one at a time. With this solution/workaround, you'll need to remember to `git push` manually at the end of your content editing/managing session in order to propagate your automagically-Spock-committed changes back to your repo. + +- **Install and enable Redis queuing** + In Spock v2.2.0, the ability to have Spock queue its commands was added. You can take advantage of this to allow Spock to apply its Vulcan logic to your files in the background, while your Control Panel stays snappy for you (and the site's other users). You'll need to have Redis installed and configured on the server in question, and your Statamic `.env` file will need to be modified to identify Redis as the queue driver. Please see the [Spock docs](https://statamic.com/marketplace/addons/spock/docs#queueing-commands) for configuration information. + + Installing and configuring Redis on your server is going to differ depending on the server configuration. Here are some links to a few of the more common server/OS scenarios: + + [Installing Redis on OS X](https://medium.com/@petehouston/install-and-config-redis-on-mac-os-x-via-homebrew-eb8df9a4f298) + [Installing Redis on Ubuntu 14.04](https://hostpresto.com/community/tutorials/how-to-install-and-configure-redis-on-ubuntu-14-04/) + [Installing Redis on Ubuntu 16.04](https://www.digitalocean.com/community/tutorials/how-to-install-and-configure-redis-on-ubuntu-16-04) + + - **Wait for newer versions of Statamic that have *Advanced Alien Technology*™** + It seems that in the future (near or far currently unknown), the event(s) fired by Statamic when a collection is re-ordered/saved may be improved, in order to consolidate all of the changes made into a single even (thus causing Spock to only execute a single commit and/or push). Which should, in-turn, reduce the time spent by the system executing those processes, and make the re-order/save experience a lot snappier in this situation. From 5a3c2ae1bb2fb2373eb002ed0b3798d26544b33d Mon Sep 17 00:00:00 2001 From: Timothy Lukian Date: Mon, 14 Jan 2019 16:38:17 -0800 Subject: [PATCH 2/7] Update slowwww-reordering.md --- content/collections/kb/slowwww-reordering.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/content/collections/kb/slowwww-reordering.md b/content/collections/kb/slowwww-reordering.md index cd1e5156..029a0888 100644 --- a/content/collections/kb/slowwww-reordering.md +++ b/content/collections/kb/slowwww-reordering.md @@ -28,4 +28,4 @@ An additional piece of the puzzle is that *some* of the commits/pushes will prob [Installing Redis on Ubuntu 16.04](https://www.digitalocean.com/community/tutorials/how-to-install-and-configure-redis-on-ubuntu-16-04) - **Wait for newer versions of Statamic that have *Advanced Alien Technology*™** - It seems that in the future (near or far currently unknown), the event(s) fired by Statamic when a collection is re-ordered/saved may be improved, in order to consolidate all of the changes made into a single even (thus causing Spock to only execute a single commit and/or push). Which should, in-turn, reduce the time spent by the system executing those processes, and make the re-order/save experience a lot snappier in this situation. + It seems that in the future (near or far currently unknown), the event(s) fired by Statamic when a collection is re-ordered/saved may be improved, in order to consolidate all of the changes made into a single event (thus causing Spock to only execute a single commit and/or push). Which should, in-turn, reduce the time spent by the system executing those processes, and make the re-order/save experience a lot snappier in this situation. From 204a129774376ad009dd6bfba2be304e175ade2c Mon Sep 17 00:00:00 2001 From: Timothy Lukian Date: Mon, 14 Jan 2019 16:39:09 -0800 Subject: [PATCH 3/7] Update slowwww-reordering.md --- content/collections/kb/slowwww-reordering.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/content/collections/kb/slowwww-reordering.md b/content/collections/kb/slowwww-reordering.md index 029a0888..79e25f9e 100644 --- a/content/collections/kb/slowwww-reordering.md +++ b/content/collections/kb/slowwww-reordering.md @@ -24,7 +24,9 @@ An additional piece of the puzzle is that *some* of the commits/pushes will prob Installing and configuring Redis on your server is going to differ depending on the server configuration. Here are some links to a few of the more common server/OS scenarios: [Installing Redis on OS X](https://medium.com/@petehouston/install-and-config-redis-on-mac-os-x-via-homebrew-eb8df9a4f298) + [Installing Redis on Ubuntu 14.04](https://hostpresto.com/community/tutorials/how-to-install-and-configure-redis-on-ubuntu-14-04/) + [Installing Redis on Ubuntu 16.04](https://www.digitalocean.com/community/tutorials/how-to-install-and-configure-redis-on-ubuntu-16-04) - **Wait for newer versions of Statamic that have *Advanced Alien Technology*™** From e086935f8dbf0bba69985c6a59e1b1df5b1d0ce5 Mon Sep 17 00:00:00 2001 From: Timothy Lukian Date: Mon, 14 Jan 2019 16:51:08 -0800 Subject: [PATCH 4/7] Update slowwww-reordering.md --- content/collections/kb/slowwww-reordering.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/content/collections/kb/slowwww-reordering.md b/content/collections/kb/slowwww-reordering.md index 79e25f9e..0b59be88 100644 --- a/content/collections/kb/slowwww-reordering.md +++ b/content/collections/kb/slowwww-reordering.md @@ -28,6 +28,8 @@ An additional piece of the puzzle is that *some* of the commits/pushes will prob [Installing Redis on Ubuntu 14.04](https://hostpresto.com/community/tutorials/how-to-install-and-configure-redis-on-ubuntu-14-04/) [Installing Redis on Ubuntu 16.04](https://www.digitalocean.com/community/tutorials/how-to-install-and-configure-redis-on-ubuntu-16-04) + + *Note that you may ALSO need to sort out a way to run the queue listener `php please queue:listen`, in the background, as a daemon or somesuch thing (so quoth the coding gods), in order for Spock to continue properly enqueueing its commands, without needing to keep the queue listener open in a terminal window — again, details about how to achieve this will likely differ based on your server environment.* - **Wait for newer versions of Statamic that have *Advanced Alien Technology*™** It seems that in the future (near or far currently unknown), the event(s) fired by Statamic when a collection is re-ordered/saved may be improved, in order to consolidate all of the changes made into a single event (thus causing Spock to only execute a single commit and/or push). Which should, in-turn, reduce the time spent by the system executing those processes, and make the re-order/save experience a lot snappier in this situation. From ff1d70369db33a685fc9da2c85ea92d62f684f44 Mon Sep 17 00:00:00 2001 From: timichango Date: Mon, 14 Jan 2019 22:29:51 -0800 Subject: [PATCH 5/7] update to include some info about using Supervisor to run queue listener process --- content/collections/kb/slowwww-reordering.md | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/content/collections/kb/slowwww-reordering.md b/content/collections/kb/slowwww-reordering.md index 0b59be88..94295d24 100644 --- a/content/collections/kb/slowwww-reordering.md +++ b/content/collections/kb/slowwww-reordering.md @@ -29,7 +29,13 @@ An additional piece of the puzzle is that *some* of the commits/pushes will prob [Installing Redis on Ubuntu 16.04](https://www.digitalocean.com/community/tutorials/how-to-install-and-configure-redis-on-ubuntu-16-04) - *Note that you may ALSO need to sort out a way to run the queue listener `php please queue:listen`, in the background, as a daemon or somesuch thing (so quoth the coding gods), in order for Spock to continue properly enqueueing its commands, without needing to keep the queue listener open in a terminal window — again, details about how to achieve this will likely differ based on your server environment.* + **Note that you may ALSO need to sort out a way to run the queue listener `php please queue:listen`, in the background, as a daemon or somesuch thing (so quoth the coding gods), in order for Spock to continue properly enqueueing its commands, without needing to keep the queue listener open in a terminal window — again, details about how to achieve this will likely differ based on your server environment.** + + One way to do this (if your environment supports it) is to install and configure [Supervisor](http://supervisord.org/) on your server to run the `php please queue:listen` process for you — and keep it running/relaunch it if the process gets terminated, server gets rebooted, etcetera. From the *Supervisor* website: + + Supervisor is a client/server system that allows its users to monitor and control a number of processes on UNIX-like operating systems [...] it is meant to be used to control processes related to a project or a customer, and is meant to start like any other program at boot time. + + The [program:x](http://supervisord.org/configuration.html#program-x-section-values) section in the documentation is of particular relevance in setting *Supervisor* up to run `php please queue:listen` for you in a daemonized capacity. - **Wait for newer versions of Statamic that have *Advanced Alien Technology*™** It seems that in the future (near or far currently unknown), the event(s) fired by Statamic when a collection is re-ordered/saved may be improved, in order to consolidate all of the changes made into a single event (thus causing Spock to only execute a single commit and/or push). Which should, in-turn, reduce the time spent by the system executing those processes, and make the re-order/save experience a lot snappier in this situation. From 4dd51bc8d873e34e493c0f2774a9e7f6b43ccff6 Mon Sep 17 00:00:00 2001 From: timichango Date: Mon, 14 Jan 2019 22:33:49 -0800 Subject: [PATCH 6/7] tweak doc formatting --- content/collections/kb/slowwww-reordering.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/content/collections/kb/slowwww-reordering.md b/content/collections/kb/slowwww-reordering.md index 94295d24..68afa179 100644 --- a/content/collections/kb/slowwww-reordering.md +++ b/content/collections/kb/slowwww-reordering.md @@ -29,11 +29,11 @@ An additional piece of the puzzle is that *some* of the commits/pushes will prob [Installing Redis on Ubuntu 16.04](https://www.digitalocean.com/community/tutorials/how-to-install-and-configure-redis-on-ubuntu-16-04) - **Note that you may ALSO need to sort out a way to run the queue listener `php please queue:listen`, in the background, as a daemon or somesuch thing (so quoth the coding gods), in order for Spock to continue properly enqueueing its commands, without needing to keep the queue listener open in a terminal window — again, details about how to achieve this will likely differ based on your server environment.** + *Note that you may **also** need to sort out a way to run the queue listener `php please queue:listen`, in the background, as a daemon or somesuch thing (so quoth the coding gods), in order for Spock to continue properly enqueueing its commands, without needing to keep the queue listener open in a terminal window — again, details about how to achieve this will likely differ based on your server environment.* One way to do this (if your environment supports it) is to install and configure [Supervisor](http://supervisord.org/) on your server to run the `php please queue:listen` process for you — and keep it running/relaunch it if the process gets terminated, server gets rebooted, etcetera. From the *Supervisor* website: - Supervisor is a client/server system that allows its users to monitor and control a number of processes on UNIX-like operating systems [...] it is meant to be used to control processes related to a project or a customer, and is meant to start like any other program at boot time. + > Supervisor is a client/server system that allows its users to monitor and control a number of processes on UNIX-like operating systems [...] it is meant to be used to control processes related to a project or a customer, and is meant to start like any other program at boot time. The [program:x](http://supervisord.org/configuration.html#program-x-section-values) section in the documentation is of particular relevance in setting *Supervisor* up to run `php please queue:listen` for you in a daemonized capacity. From 889807ea193c25c6b3c6c579be94d5f9491bbf54 Mon Sep 17 00:00:00 2001 From: timichango Date: Mon, 14 Jan 2019 22:44:16 -0800 Subject: [PATCH 7/7] =?UTF-8?q?fix=20spelling=20of=20=E2=80=98queueing?= =?UTF-8?q?=E2=80=99?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- content/collections/kb/slowwww-reordering.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/content/collections/kb/slowwww-reordering.md b/content/collections/kb/slowwww-reordering.md index 68afa179..ffaaac46 100644 --- a/content/collections/kb/slowwww-reordering.md +++ b/content/collections/kb/slowwww-reordering.md @@ -18,7 +18,7 @@ An additional piece of the puzzle is that *some* of the commits/pushes will prob - **Disable Spock's Automatic `git push`** If Spock isn't attempting to `git push` each commit it makes, in sequence, this problem seems to be eliminated — or at least the execution time required for all of the commits is far less than if each of them is also being pushed, in sequence, one at a time. With this solution/workaround, you'll need to remember to `git push` manually at the end of your content editing/managing session in order to propagate your automagically-Spock-committed changes back to your repo. -- **Install and enable Redis queuing** +- **Install and enable Redis queueing** In Spock v2.2.0, the ability to have Spock queue its commands was added. You can take advantage of this to allow Spock to apply its Vulcan logic to your files in the background, while your Control Panel stays snappy for you (and the site's other users). You'll need to have Redis installed and configured on the server in question, and your Statamic `.env` file will need to be modified to identify Redis as the queue driver. Please see the [Spock docs](https://statamic.com/marketplace/addons/spock/docs#queueing-commands) for configuration information. Installing and configuring Redis on your server is going to differ depending on the server configuration. Here are some links to a few of the more common server/OS scenarios: