Question

How to Troubleshoot Common Apache Issues on Linux Server?

I have been seeing this question quite a lot recently, so I decided to put together a few steps on what to do in case that your website is not loading.

If you are using Nginx, you could follow the steps here:

https://www.digitalocean.com/community/questions/how-to-troubleshoot-common-nginx-issues-on-linux-server?answer=56476


Submit an answer


This textbox defaults to using Markdown to format your answer.

You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!

Sign In or Sign Up to Answer

These answers are provided by our Community. If you find them useful, show some love by clicking the heart. If you run into issues leave a comment, or add your own answer to help others.

Bobby Iliev
Site Moderator
Site Moderator badge
November 22, 2019
Accepted Answer

I would recommend following these steps in case that you are having any problems with your Apache server and you are unsure about what the problem is:

  • Check if Apache is running:
systemctl status apache2

If Apache is running you should see something like this:

● apache2.service - The Apache HTTP Server
   Loaded: loaded (/lib/systemd/system/apache2.service; enabled; vendor preset: enabled)
   Active: active (running) since Tue 2019-11-19 09:37:46 UTC; 2 days ago
     Docs: https://httpd.apache.org/docs/2.4/

If Apache is not running then the output would look like this:

● apache2.service - The Apache HTTP Server
   Loaded: loaded (/lib/systemd/system/apache2.service; enabled; vendor preset: enabled)
   Active: inactive (dead) since Fri 2019-11-22 08:41:01 UTC; 39s ago
     Docs: https://httpd.apache.org/docs/2.4/
  • If Apache is not running you could start it with:
systemctl start apache2

Then check the status agian and make sure that Apache remains running.

  • If Apache did not start after a reboot, you could enable it so that it starts after the next reboot:
systemctl enable apache2
  • Check your Apache config syntax:
apachectl -t

If you get an error, you would need to fix that problem and then you could restart Apache:

systemctl restart apache2
  • If you get Syntax OK when running apachectl -t then your configuration is correct, so I would recommend checking your error logs:
tail -f /var/log/apache2/error.log

With the -f argument, you would see the output of the log in real team, so you could visit your website via your browser, and you would be able to see the errors populating the log if there are any. To stop that, just press CTRL+C.

  • Check the permissions of the files and folders in your document root:

Find the user that your Apache service is running as:

ps auxf | grep apache

If you are using Ubuntu, the user should be www-data, so you would need to make sure that your files and folders are owned by that user, so Apache could read and write to those files:

chown -R www-data:www-data /var/www/yourdomain.com

Note: be careful with the above command as it could mess up the ownership of all of your files if you don’t specify the path correctly.

  • Check if Apache is binding to the default ports:
netstat -plant | grep '80\|443'
  • Check if ufw allows TCP connections on port 80 and 443:
ufw status

If this is the case, you can follow the steps from this article here on how to configure your ufw:

https://www.digitalocean.com/community/tutorials/how-to-set-up-a-firewall-with-ufw-on-ubuntu-18-04

That is pretty much it, with all of the above information you should be able to narrow down the problem.

For more information I would suggest checking out this article here:

https://www.digitalocean.com/community/tutorials/how-to-troubleshoot-common-site-issues-on-a-linux-server

Hope that this helps! Regards, Bobby

When I stopped nginx using sudo systemctl stop nginx

I was able to restart apache, but my application stopped running. I am unable to restart nginx. And some commands begin to fail

Also, when I ran some of the commands working before they failed. For instance:

sudo chgrp -R www-data storage bootstrap/cache

“no such file or directory exists”

The whole thing is just giving me stress

Do I need to downgrade to PHP 7.2 or will PHP 7.3 do it. I use PHP 7.3 ON MY LOCAL SYSTEM and it works

When I used: systemctl status apache2

I got:

https://i.stack.imgur.com/xnENV.png

and, systemctl start apache2

gives:

https://i.stack.imgur.com/AIQ35.png

https://i.stack.imgur.com/jApkJ.png

https://i.stack.imgur.com/tvMD0.png

Just totally confused.

What do I do?

Try DigitalOcean for free

Click below to sign up and get $200 of credit to try our products over 60 days!

Sign up

Become a contributor for community

Get paid to write technical tutorials and select a tech-focused charity to receive a matching donation.

DigitalOcean Documentation

Full documentation for every DigitalOcean product.

Resources for startups and SMBs

The Wave has everything you need to know about building a business, from raising funding to marketing your product.

Get our newsletter

Stay up to date by signing up for DigitalOcean’s Infrastructure as a Newsletter.

New accounts only. By submitting your email you agree to our Privacy Policy

The developer cloud

Scale up as you grow — whether you're running one virtual machine or ten thousand.

Get started for free

Sign up and get $200 in credit for your first 60 days with DigitalOcean.*

*This promotional offer applies to new accounts only.