References:
- What Is Xmlrpc.php in WordPress and Why You Should Disable It
- How to Disable XML-RPC for Better WordPress Security
- Huge increase in WordPress xmlrpc.php POST requests
Recently I noticed a flood of xmlrpc.php POSTs in my Apache access_log for a new WordPress site just deployed, using a Bitnami image on AWS Lightsail. Basically it was flooding the site a few times every second! Eventually it gets overloaded and shuts down Apache.
data:image/s3,"s3://crabby-images/3337c/3337c4902aa37221b254c520ed695364e68fbaa0" alt="xmlrpc access log"
After doing a bit of research, aka… I checked Google, I learned this is a known problem. In a nutshell, hackers can use xmlrpc.php for botnets, brute force attacks, etc. Although there is some value with xmlrpc.php within WordPress (pingbacks, etc), I was not using that functionality.
I addressed the issue with the iThemes Security plugin. Easy to install and configure, it only took a few minutes to make the site much more secure, including two-factor authentication, brute-force login attempt lockout, etc.
data:image/s3,"s3://crabby-images/72f11/72f11d817aa78b9c18e8ab90fed18dafe84a45d5" alt="iThemes Security"
For the xmlrpc issue, be sure to go into Settings -> Advanced -> API Access – XML-RPC – select Disable XML-RPC, and also for REST-API -> select Restricted Access.
data:image/s3,"s3://crabby-images/1055e/1055e01462488f1301748bbd35a2796f35a18d14" alt="Disable XML-RPC"
Within only a couple days, the plugin has already locked out a few bad IPs attempting brute force attacks. No problems with the XMLRPC floods since, fingers crossed.