- Stop Apache Mac Catalina
- Apache Macos Catalina Update
- Apache Directory Studio Macos Catalina
- Disable Apache Mac Catalina
The reason is that I am using the homebrew version of both Apache and PHP. The current version of PHP that I am using is PHP 7 as you can see in the screenshot below but when I use php -v in the terminal it shows me PHP version 5.6. See screenshot below. MacOS 10.13 High Sierra and 10.14 Mojave come with Apache pre-installed. However, instead of using the delivered version we’re going to install Apache via Homebrew and then configure it to run. The new macOS Catalina comes with Apache pre-installed. All we have to do is switch it on. Open Terminal using macOS Spotlight or go to /Applications/Utilities and open Terminal. To check the version of Apache installed run the following command in the Terminal. $ httpd -v Server version: Apache/2.4.41 (Unix) Server built: Aug 29 2019.
Setting up Virtual Hosts in Apache on on macOS Big Sur is straight forward after you have your local Web Development environment up and running – get your web development up and running first including Apache, PHP and MySQL on macOS following this macOS Big Sur Apache/PHP/MySQL guide here if required.
This guide will also work in macOS Catalina, Mojave, High Sierra and Sierra.
The process of setting up Virtual Hosts is done easier in the Terminal either using nano or vi with sudo or as a root user, or you can you a GUI visual editor like BBEdit which allows access to the /private/etc directory by clicking ‘Show Everything” in the open dialog box.
Allow the vhosts configuration from the Apache configuration file httpd.conf
Open the httpd.conf
Search for ‘vhosts‘ and uncomment the include line
Edit the vhosts.conf file
Open this file to add in the virtual host.
An example domain in the file is given of the format required to add in additional domains, just follow this to create your new virtual host:
We can take this example and extend on it, if you wanted a domain named apple.com for example, you can copy the existing text block and edit to suit:
So in the example above a vhost for apple.com is created and the document root is in the Sites/apple folder, in the text block above I have also added in some log files, what you need to change is the document root location username and domain name to suit your needs. Finish and save the file.
Now also you need to map the IP address to be the localhost.
Map Your IP address to localhost
Add the Domain and ‘www‘ alias to resolve to the localhost address
Restart Apache
Check out your local vhost domain in the browser
Losing Localhost
One caveat to note about virtual hosts is that once set up you lose your older document root previously at /Library/WebServer/Documents or accessed in the browser at http://localhost what happens is that you get a 403 Forbidden Error. But the ~/username document root is still compatible.
To get around this, you need to add in a vhost for localhost and declare this vhost before any of the others, in the same file:
Add in:
Restart Apache
Changing the WebServer Default User
One of the frustrations of using the Users/username/Sites folder for vhosts is the permissions issues with things like updates and authentication.
This is because the default webserver user which runs httpd is known as _www, which will not be the user in your local account. If your machine is only in use by you and the webserver will run only under your account then you can change the user.
Find Your User and Group
In the Terminal use the id command to see your username and group
Stop Apache Mac Catalina
You will get a bunch of user groups, you need your primary user uid and group gid names
Change this back in /etc/apache2/httpd.conf
Restart Apache
Restart Apache and now you are running httpd as your local account.
That’s it, the guide will also work on macOS Catalina, Mojave, High Sierra and Sierra.
Setting up Virtual Hosts in Apache on on macOS Big Sur is straight forward after you have your local Web Development environment up and running – get your web development up and running first including Apache, PHP and MySQL on macOS following this macOS Big Sur Apache/PHP/MySQL guide here if required.
This guide will also work in macOS Catalina, Mojave, High Sierra and Sierra.
The process of setting up Virtual Hosts is done easier in the Terminal either using nano or vi with sudo or as a root user, or you can you a GUI visual editor like BBEdit which allows access to the /private/etc directory by clicking ‘Show Everything” in the open dialog box.
Allow the vhosts configuration from the Apache configuration file httpd.conf
Open the httpd.conf
Search for ‘vhosts‘ and uncomment the include line
Edit the vhosts.conf file
Open this file to add in the virtual host.
An example domain in the file is given of the format required to add in additional domains, just follow this to create your new virtual host:
We can take this example and extend on it, if you wanted a domain named apple.com for example, you can copy the existing text block and edit to suit:
So in the example above a vhost for apple.com is created and the document root is in the Sites/apple folder, in the text block above I have also added in some log files, what you need to change is the document root location username and domain name to suit your needs. Finish and save the file.

Now also you need to map the IP address to be the localhost.
Map Your IP address to localhost
Add the Domain and ‘www‘ alias to resolve to the localhost address
Restart Apache
Check out your local vhost domain in the browser
Losing Localhost
One caveat to note about virtual hosts is that once set up you lose your older document root previously at /Library/WebServer/Documents or accessed in the browser at http://localhost what happens is that you get a 403 Forbidden Error. But the ~/username document root is still compatible.
To get around this, you need to add in a vhost for localhost and declare this vhost before any of the others, in the same file:
Add in:
Apache Macos Catalina Update
Restart Apache
Changing the WebServer Default User
One of the frustrations of using the Users/username/Sites folder for vhosts is the permissions issues with things like updates and authentication.
This is because the default webserver user which runs httpd is known as _www, which will not be the user in your local account. If your machine is only in use by you and the webserver will run only under your account then you can change the user.
Find Your User and Group
In the Terminal use the id command to see your username and group
You will get a bunch of user groups, you need your primary user uid and group gid names
Change this back in /etc/apache2/httpd.conf
Restart Apache
Apache Directory Studio Macos Catalina
Restart Apache and now you are running httpd as your local account.
Disable Apache Mac Catalina
That’s it, the guide will also work on macOS Catalina, Mojave, High Sierra and Sierra.