mirror of
https://github.com/LemmyNet/lemmy-docs.git
synced 2025-01-15 14:15:48 +00:00
Add nginx caching as possible solution for slow lemmy-ui (#334)
* Add nginx caching as possible solution for slow lemmy-ui * Update troubleshooting.md * Update troubleshooting.md
This commit is contained in:
parent
e2d4089545
commit
6230839e45
1 changed files with 3 additions and 3 deletions
|
@ -223,11 +223,11 @@ Each of these folders contains a `down.sql` file. We need to run that against ou
|
||||||
|
|
||||||
If you notice that your lemmy-ui sometimes becomes sluggish or unresponsive over a period of minutes/hours and then it passes, you might be getting targeted by scraping bots.
|
If you notice that your lemmy-ui sometimes becomes sluggish or unresponsive over a period of minutes/hours and then it passes, you might be getting targeted by scraping bots.
|
||||||
|
|
||||||
There's a lot of scraping bots online and they can easily overwhelm your site when they're behaving too "greedily".
|
There's a lot of scraping bots online and they can easily overwhelm your site when they're behaving too "greedily". Unfortunately the existing lemmy-ui has a habit of falling over when polled too eagerly, while the backend still continues to work.
|
||||||
|
|
||||||
Unfortunately the existing lemmy-ui has a habit of falling over when polled too eagerly, while the backend still continues to work.
|
A solution is to cache responses in nginx as seen in lemmy-ansible [here](https://github.com/LemmyNet/lemmy-ansible/blob/1.5.3/templates/nginx.conf#L2-L3) and [here](https://github.com/LemmyNet/lemmy-ansible/blob/1.5.3/templates/nginx.conf#L66-L71). This way lemmy-ui doesn't have to generate all responses from scratch, which reduces CPU load. However it won't help if a single crawler goes through thousands of unique urls in a short time.
|
||||||
|
|
||||||
One solution to deal with the scraping bots is to block their user agents. To do so, you can modify your `nginx_internal.conf` to block some of the usual suspects, with this line under `server`
|
Another option is to block the scraper's user agents. To do so, you can modify your `nginx_internal.conf` to block some of the usual suspects, with this line under `server`
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
if ($http_user_agent ~* " Bytedance|Bytespider|Amazonbot|ClaudeBot") { return 444; }
|
if ($http_user_agent ~* " Bytedance|Bytespider|Amazonbot|ClaudeBot") { return 444; }
|
||||||
|
|
Loading…
Reference in a new issue