data:image/s3,"s3://crabby-images/b904f/b904f7089405446639dfd840868b315a314e0fae" alt="Max retries has been reached, 503! image 123 - Max retries has been reached, 503!"
503 Service Unavailable error on a shop hosted on shared cPanel server, apache error log:
tail /usr/local/apache/logs/error_log
2022-04-29 11:04:21.728438 [T0] [31.32.33.34:49768-H3:3D8F707E6843B0DF-0#APVH_XXXXXX.com:443] Max retries has been reached, 503!
2022-04-29 11:04:21.728438 [NOTICE] [186810] [T0] [31.32.33.34:49768-H3:3D8F707E6843B0DF-0#APVH_XXXXXX.com:443] oops! 503 Service Unavailable
2022-04-29 11:04:21.728443 [NOTICE] [186810] [T0] [31.32.33.34:49768-H3:3D8F707E6843B0DF-0#APVH_XXXXXX.com:443] Content len: 0, Request line: ‘GET / HTTP/1.1’
2022-04-29 11:04:21.728448 [INFO] [186810] [T0] [31.32.33.34:49768-H3:3D8F707E6843B0DF-0#APVH_XXXXXX.com:443] abort request…, code: 4
2022-04-29 11:04:21.728499 [INFO] [186810] [T0] [31.32.33.34:49768-H3:3D8F707E6843B0DF-0#APVH_XXXXXX.com:443] File not found [/home/username/public_html/503.shtml]
data:image/s3,"s3://crabby-images/a188e/a188ebf527a94544d16f50c278709527d22efee9" alt="Max retries has been reached, 503! image 120 1024x269 - Max retries has been reached, 503!"
In my case, the user is hitting these limits because both PHP suEXEC Max Conn and NPROC are set to 100 and user is hitting this number.
So to fix it, there are different options:
- Restart CageFS
- Set PHP suEXEC Max Conn limit lower than NPROC limits
- Disable PHP suEXEC completely
- Change PHP version or handler to something different than suEXEC
Restart CageFS
If you use Cloudlinux, the first thing to do is to disable CageFS for that user and test if the issue is still present. If not, enable CageFS again and re-test. In 2/3 cases, CageFS is the problem.
Change Suexec limits
Since I also use CloudLinux on this server, I also have to take into consideration the LVE limits and make sure that Suexec limits in LSWS are lower than EP and NPROC limits defined in Cloudlinux.
To change Limits, navigate to LiteSpeed WebAdmin Console at SERVER:7080
data:image/s3,"s3://crabby-images/93d27/93d277ba39f2536a2a1edaf068bc17a5b2f450c4" alt="Max retries has been reached, 503! image 125 - Max retries has been reached, 503!"
From the terminal set a new user/password by running the script:
/usr/local/lsws/admin/misc/admpass.sh
data:image/s3,"s3://crabby-images/b422a/b422adcad8e79fd784571e17e4b7952b298f7a2a" alt="Max retries has been reached, 503! image 124 - Max retries has been reached, 503!"
After logging in the LSWS WebAdmin Console navigate to Server > General > Using Apache Configuration File and set PHP suEXEC Max Conn to a number lower than NPROC:
data:image/s3,"s3://crabby-images/e293a/e293a0c4e557071908b46627830118cdb4f4a988" alt="Max retries has been reached, 503! image 121 - Max retries has been reached, 503!"
In my case, NPROC is set to 200, so I will set 45 for suEXEC
data:image/s3,"s3://crabby-images/c424d/c424d280301ac2a834b9c8e4f4935f8c2702569a" alt="Max retries has been reached, 503! image 122 1024x236 - Max retries has been reached, 503!"
Now just restart LSWS and the website should load as expected.
Disable PHP suEXEC
To disable PHP suEXEC server-wide navigate to WHM > LiteSpeed > LiteSpeed configuration
data:image/s3,"s3://crabby-images/ad456/ad456783a6b1ac083c6f378dfbdda3458043f0c4" alt="Max retries has been reached, 503! image 129 - Max retries has been reached, 503!"
Select PHP suEXEC Quick Configuration
data:image/s3,"s3://crabby-images/18277/18277aebfe978bca059d7e47f5aeaa8c7d0dda56" alt="Max retries has been reached, 503! image 127 - Max retries has been reached, 503!"
And disable it.
data:image/s3,"s3://crabby-images/527dd/527dd7e7cf1e0b0cda6ed88d60820e2ec67eb0c0" alt="Max retries has been reached, 503! image 128 1024x354 - Max retries has been reached, 503!"
Change PHP version
From WHM > MultiPHP Manager > User Domain Settings find the domain and change the PHP version:
data:image/s3,"s3://crabby-images/68cf2/68cf2aae9aca29f793a402c68f1ebd52a216dcd0" alt="Max retries has been reached, 503! image 126 1024x700 - Max retries has been reached, 503!"