Make linkvalidator crawling polite
Currently, linkvalidator does not apply common practice for being "nice" / "polite" when crawling other websites:
- It should be possible to see what is crawling your site. It is usually standard to add a URL and contact information to the User-Agent or referrer, e.g.
"Mozilla/5.0 (compatible; MetaJobBot; http://www.metajob.de/crawler)"
"https://www.google.de/" "Mozilla/5.0 (iPhone; CPU iPhone OS 12_4_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/12.1.2 Mobile/15E148 Safari/604.1"
- the crawler should respect the robots.txt
- the crawler should wait between consecutive requests (Crawl-Delay). A good minimum value is e.g. 1-5 second for requests done on same domain
While linkvalidator is not a full web crawler which downloads the entire pages on the site and it currently uses HEAD by default (and not GET) which does not download the entire page - so this is not as dramatic.
But preferably, I think we should follow these recommendations as well.
Not just for reducing load on other sites but also on the TYPO3 site, some changes might be made to the crawling process:
- when crawling external URLs, do not check right away but defer to a separate task which will handle the crawling of external URLs (with reasonable delays in between)
- do not keep crawling over and over but regularly only recrawl content which was recently modified
- optional: delegate the checking of external URLs, e.g. use a URLchecking service
This may make it necessary to make more things asynchronous and confine the link checking only to the scheduler.
About politeness of web crawlers:
URL checking site:
[FEATURE] Add additional configuration for external URLs
Additional configuration is added to customize settings for checking
Tested-by: TYPO3com <email@example.com>
Tested-by: Chris Müller <firstname.lastname@example.org>
Tested-by: Benni Mack <email@example.com>
Reviewed-by: Chris Müller <firstname.lastname@example.org>
Reviewed-by: Benni Mack <email@example.com>