Setup Apache/PHP/MariaDB development environment on Apple M1/M2/M3 based machines for local PHP development.
This setup works fine on my macOS machines. I am certainly no Apache, PHP and MariaDB expert so should something go wrong in your setup, check the sources I used.
- macOS Sonoma (tested on macOS Sonoma 14.4.1).
macOS 14.0 Sonoma Apache Setup: Multiple PHP Versions
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
After installation add Homebrew path to your profile. For Bash:
(echo; echo 'eval "$(/opt/homebrew/bin/brew shellenv)"') >> ~/.bash_profile
eval "$(/opt/homebrew/bin/brew shellenv)"
For Zsh:
(echo; echo 'eval "$(/opt/homebrew/bin/brew shellenv)"') >> ~/.zprofile
eval "$(/opt/homebrew/bin/brew shellenv)"
brew --version
Homebrew 4.2.19
The Homebrew version at the time of this writing was 4.1.24. Your version might be newer.
brew install wget
When you prefer working in the bash shell, it is advised to upgrade bash through Homebrew.
First, install bash:
brew install bash
The new bash is installed in /opt/homebrew/bin/bash. We need to add it to the list of permitted shells:
echo $(brew --prefix)/bin/bash | sudo tee -a /private/etc/shells
Enter your Mac account password when the system asks for it.
Finally, you will need to update your user’s shell with the chpass command line.
sudo chpass -s /opt/homebrew/bin/bash your_user
Replace your_user your own macOS username.
sudo apachectl -k stop
sudo launchctl unload -w /System/Library/LaunchDaemons/org.apache.httpd.plist 2>/dev/null
Don't worry about the messages you're getting when you're stopping the existing Apache.
brew install httpd
You can setup Apache so it starts at every (re)boot of your machine.
brew services start httpd
You can also start, stop or restart Apache manually
brew services start httpd
brew services stop httpd
brew services restart httpd
Test Apache by going in your browser to: http://localhost:8080 You should see a message with the text It works!
To edit configuration files we setup Visual Sudio Code. Go to the Visual Studio Code site and click Download Mac Universal.
Once downloaded, drag the application to your preffered Applications location. Next, you want to install the command line tools, so follow the official step-by-step instructions so that you can use the code command from the Terminal.
In my setup I put my website projects in my home folder submap Development/Sites so we need to create a folder for that.
$ mkdir -p ~/Development/Sites
code /opt/homebrew/etc/httpd/httpd.conf
Replace:
Listen 8080
with:
Listen 80
Replace:
DocumentRoot "/opt/homebrew/var/www"
with:
DocumentRoot "/Users/your_user/Development/Sites"
Replace your_user with your own macOS username.
Replace:
<Directory "/opt/homebrew/var/www">
with:
<Directory "/Users/your_user/Development/Sites"> (so WITH quotes)
Replace your_user with your own macOS username.
In the same <Directory ...> block:
Replace:
AllowOverride None
with:
AllowOverride All
Search for:
#LoadModule rewrite_module lib/httpd/modules/mod_rewrite.so
And replace with:
LoadModule rewrite_module lib/httpd/modules/mod_rewrite.so (so remove #)
Replace:
User _www
Group _www
with:
User your_user
Group staff
Replace your_user with your own macOS username.
Replace:
#ServerName www.example.com:8080
with:
ServerName localhost
Save the file /opt/homebrew/etc/httpd/httpd.conf
$ echo "<h1>My User Web Root</h1>" > ~/Development/Sites/index.html
brew services restart httpd
In your browser go to http://localhost, there the My User Web Root should appear.
First, add a tap from @shivammahtur that has many PHP versions pre-built.
brew tap shivammathur/php
Proceed by installing PHP versions:
brew install shivammathur/php/[email protected]
brew install shivammathur/php/[email protected]
brew install shivammathur/php/[email protected]
brew install shivammathur/php/[email protected]
To have webapplications work well we need to modify a number of php.ini settings. The following values need to be modified for every installed PHP version. Search the setting in php.ini and enter the new value.
For display_errors you might want make an exception and leave that to 'On', but that is however you prefer.
output_buffering = Off
max_execution_time = 180
max_input_time = 180
memory_limit = 512M
display_errors = Off
post_max_size = 256M
upload_max_filesize = 256M
max_file_uploads = 50
date.timezone = Europe/Amsterdam
Modify php.ini PHP 7.4:
code /opt/homebrew/etc/php/7.4/php.ini
Modify php.ini PHP 8.2:
code /opt/homebrew/etc/php/8.2/php.ini
Modify php.ini PHP 8.3:
code /opt/homebrew/etc/php/8.3/php.ini
Modify php.ini PHP 8.4:
code /opt/homebrew/etc/php/8.4/php.ini
Restart Apache after the php.ini modifications:
brew services restart httpd
At this point, you must close ALL your terminal tabs and windows. This will mean opening a new terminal to continue with the next step. This is strongly recommended because some really strange path issues can arise with existing terminals.
Switch back yo the first PHP version
brew unlink php && brew link --overwrite --force [email protected]
Quick test that we're in the correct version:
php -v
PHP 7.4.33 (cli) (built: Apr 12 2024 22:29:56) ( NTS )
Copyright (c) The PHP Group
Zend Engine v3.4.0, Copyright (c) Zend Technologies
with Zend OPcache v7.4.33, Copyright (c), by Zend Technologies
code /opt/homebrew/etc/httpd/httpd.conf
Find the line that loads the mod_rewrite module:
LoadModule rewrite_module lib/httpd/modules/mod_rewrite.so
Below this add the following libphp modules:
LoadModule php7_module /opt/homebrew/opt/[email protected]/lib/httpd/modules/libphp7.so
#LoadModule php_module /opt/homebrew/opt/[email protected]/lib/httpd/modules/libphp.so
#LoadModule php_module /opt/homebrew/opt/[email protected]/lib/httpd/modules/libphp.so
#LoadModule php_module /opt/homebrew/opt/[email protected]/lib/httpd/modules/libphp.so
Replace:
<IfModule dir_module>
DirectoryIndex index.html
</IfModule>
with:
<IfModule dir_module>
DirectoryIndex kick.php index.php index.html
</IfModule>
<FilesMatch \.php$>
SetHandler application/x-httpd-php
</FilesMatch>
I've added kick.php which is nice if you work with Akeeba Backup Kickstart. Save the file and restart Apache:
brew services restart httpd
Create a file info.php in your ~/Development/Sites folder:
echo "<?php phpinfo();" > ~/Development/Sites/info.php
Check if it is working by going in your browser to http://localhost/info.php
To easily switch between PHP versions we install a PHP switcher script.
curl -L https://gist.githubusercontent.com/rhukster/f4c04f1bf59e0b74e335ee5d186a98e2/raw/7227b6e8eab67fbdb5bd1053d7d761eb1507e8ac/sphp.sh > /opt/homebrew/bin/sphp
chmod +x /opt/homebrew/bin/sphp
We need to modify the sphp script to allow it to work with PHP 8.3 and 8.4.
code /opt/homebrew/bin/sphp
Change the line with:
brew_array=("5.6","7.0","7.1","7.2","7.3","7.4","8.0","8.1","8.2")
to
brew_array=("7.4","8.2","8.3","8.4")
Change the line with:
php_array=("[email protected]" "[email protected]" "[email protected]" "[email protected]" "[email protected]" "[email protected]" "[email protected]" "[email protected]" "[email protected]")
to
php_array=("[email protected]" "[email protected]" "[email protected]" "[email protected]")
Test the switcher script:
sphp 8.2
Switching to [email protected]
Switching your shell
Unlinking /opt/homebrew/Cellar/[email protected]/7.4.33_6... 25 symlinks removed.
Unlinking /opt/homebrew/Cellar/[email protected]/8.2.18... 0 symlinks removed.
Unlinking /opt/homebrew/Cellar/php/8.3.6... 0 symlinks removed.
Unlinking /opt/homebrew/Cellar/[email protected]/8.4.0_1... 0 symlinks removed.
Linking /opt/homebrew/Cellar/[email protected]/8.2.18... 25 symlinks created.
If you need to have this software first in your PATH instead consider running:
echo 'export PATH="/opt/homebrew/opt/[email protected]/bin:$PATH"' >> ~/.zshrc
echo 'export PATH="/opt/homebrew/opt/[email protected]/sbin:$PATH"' >> ~/.zshrc
Switching your apache conf
Restarting apache
Stopping `httpd`... (might take a while)
==> Successfully stopped `httpd` (label: homebrew.mxcl.httpd)
==> Successfully started `httpd` (label: homebrew.mxcl.httpd)
PHP 8.2.18 (cli) (built: Apr 9 2024 18:46:23) (NTS)
Copyright (c) The PHP Group
Zend Engine v4.2.18, Copyright (c) Zend Technologies
with Zend OPcache v8.2.18, Copyright (c), by Zend Technologies
All done!
Refresh the page http://localhost/info.php in your browser.
Brew makes it super easy to update PHP and the other packages you install. The first step is to update Brew so that it gets a list of available updates:
brew update
This will spit out a list of available updates, and any deleted formulas. To upgrade the packages simply type:
brew upgrade
To update all of your PHP versions you have to switch to them with the sphp script, and then run brew update.
Do note, you cannot run multiple versions of MySQL on the same machine because brew will install the database directory in the same location. So choose wisely which version you want to install.
brew update
brew install mariadb
brew services start mariadb
mysql
MariaDB [(none)]> SET PASSWORD FOR root@localhost = PASSWORD('root');
MariaDB [(none)]> EXIT;
/opt/homebrew/bin/mysql_secure_installation
Answers:
Switch to unix_socket authentication [Y/n] n
Change the root password? [Y/n] n
Remove anonymous users? [Y/n] Y
Disallow root login remotely? [Y/n] Y
Remove test database and access to it? [Y/n] Y
Reload privilege tables now? [Y/n] Y
If you need to stop the MariaDB server, you can use this command:
brew services stop mariadb
Now that we have PHP and MariaDB running we need a tool to administrate our MariaDB database. Two native macOS applications that are quite good are Sequel Pro and DBeaver.
But personally I prefer Adminer, a PHP based tool that runs in the browser. You can download Adminer from the Adminer.org website
The most minimalistic version the version for MySQL, English only. Download the file and save it as adminer.php in your Development/Sites folder. You can then open it at http://localhost/adminer.php.
Then login with username 'root' and password 'root' (without the quotes).
We can now very easily add a new virtual host. By creating a subfolder in ~/Development/Sites/, for example, 'testsite', this new website is immediately accessible through the domain name 'testsite.test'.
But we need to modify DNS so it resolves to this domain. Therefor we install Dnsmasq.
brew install dnsmasq
Setup *.dev.test hosts:
echo 'address=/.dev.test/127.0.0.1' >> /opt/homebrew/etc/dnsmasq.conf
Start Dnsmasq and make sure it starts at every reboot:
sudo brew services start dnsmasq
Add to resolvers:
sudo mkdir -v /etc/resolver
sudo bash -c 'echo "nameserver 127.0.0.1" > /etc/resolver/test'
Test this by pinging to an unknown .dev.test name. Thex§re should come a reply from 127.0.0.1:
ping newsite.dev.test
PING newsite.dev.test (127.0.0.1): 56 data bytes
64 bytes from 127.0.0.1: icmp_seq=0 ttl=64 time=0.102 ms
64 bytes from 127.0.0.1: icmp_seq=1 ttl=64 time=0.274 ms
64 bytes from 127.0.0.1: icmp_seq=2 ttl=64 time=0.214 ms
64 bytes from 127.0.0.1: icmp_seq=3 ttl=64 time=0.255 ms
Restart apache:
brew services restart httpd
To have PHP run faster we install APCu Cache. Zend OPcache was already installed with the PHP installation.
sphp 7.4
Before you install apcu there might be a problem with a missing pcre2.h file. To fix that you should create a symbolic link to pcre2.h:
ln -s /opt/homebrew/Cellar/pcre2/10.43/include/pcre2.h /opt/homebrew/Cellar/[email protected]/7.4.33_6/include/php/ext/pcre/pcre2.h
But be carefull here. 10.43 was the current version on my machine of the original /opt/homebrew/Cellar/pcre2/10.43/include/pcre2.h file. Replace 10.43 with the version on your machine.
7.4.33_6 was the current version of my PHP 7.4. Replace 7.4.33_6 with the version on your machine.
pecl install apcu
Answer any question by simply pressing Return to accept the default values.
code /opt/homebrew/etc/php/7.4/php.ini
Delete the line
extension="apcu.so"
that was added at the top of php.ini. Save and close php.ini. Then create a new separate .ini file for APCu:
code /opt/homebrew/etc/php/7.4/conf.d/ext-apcu.ini
Put the following contents in that file:
[apcu]
extension="apcu.so"
apc.enabled=1
apc.shm_size=64M
apc.ttl=7200
apc.enable_cli=1
Save and close the file.
Switch to PHP 8.2.
sphp 8.2
Before you install apcu there might be a problem with a missing pcre2.h file. To fix that you should create a symbolic link to pcre2.h:
ln -s /opt/homebrew/Cellar/pcre2/10.43/include/pcre2.h /opt/homebrew/Cellar/[email protected]/8.2.18/include/php/ext/pcre/pcre2.h
But be carefull here. 10.43 was the current version on my machine of the original /opt/homebrew/Cellar/pcre2/10.43/include/pcre2.h file. Replace 10.43 with the version on your machine.
8.2.18 was the current version of my PHP 8.2. Replace 8.2.18 with the version on your machine.
pecl install apcu
Answer any question by simply pressing Return to accept the default values.
code /opt/homebrew/etc/php/8.2/php.ini
Delete the line
extension="apcu.so"
that was added at the top of php.ini. Save and close php.ini. Then create a new separate .ini file for APCu:
code /opt/homebrew/etc/php/8.2/conf.d/ext-apcu.ini
Put the following contents in that file:
[apcu]
extension="apcu.so"
apc.enabled=1
apc.shm_size=64M
apc.ttl=7200
apc.enable_cli=1
Save and close the file.
Switch to PHP 8.3.
sphp 8.3
Before you install apcu there might be a problem with a missing pcre2.h file. To fix that you should create a symbolic link to pcre2.h:
ln -s /opt/homebrew/Cellar/pcre2/10.43/include/pcre2.h /opt/homebrew/Cellar/php/8.3.6/include/php/ext/pcre/pcre2.h
But be carefull here. 10.43 was the current version on my machine of the original /opt/homebrew/Cellar/pcre2/10.43/include/pcre2.h file. Replace 10.43 with the version on your machine.
8.3.6 was the current version of my PHP 8.3. Replace 8.3.6 with the version on your machine.
pecl install apcu
Answer any question by simply pressing Return to accept the default values.
code /opt/homebrew/etc/php/8.3/php.ini
Delete the line
extension="apcu.so"
that was added at the top of php.ini. Save and close php.ini. Then create a new separate .ini file for APCu:
code /opt/homebrew/etc/php/8.3/conf.d/ext-apcu.ini
Put the following contents in that file:
[apcu]
extension="apcu.so"
apc.enabled=1
apc.shm_size=64M
apc.ttl=7200
apc.enable_cli=1
Save and close the file.
Switch to PHP 8.4.
sphp 8.4
Before you install apcu there might be a problem with a missing pcre2.h file. To fix that you should create a symbolic link to pcre2.h:
ln -s /opt/homebrew/Cellar/pcre2/10.43/include/pcre2.h /opt/homebrew/Cellar/[email protected]/8.4.0_1/include/php/ext/pcre/pcre2.h
But be carefull here. 10.43 was the current version on my machine of the original /opt/homebrew/Cellar/pcre2/10.43/include/pcre2.h file. Replace 10.43 with the version on your machine.
8.4.0_1 was the current version of my PHP 8.4. Replace 8.4.0_1 with the version on your machine.
pecl install apcu
Answer any question by simply pressing Return to accept the default values.
code /opt/homebrew/etc/php/8.4/php.ini
Delete the line
extension="apcu.so"
that was added at the top of php.ini. Save and close php.ini. Then create a new separate .ini file for APCu:
code /opt/homebrew/etc/php/8.4/conf.d/ext-apcu.ini
Put the following contents in that file:
[apcu]
extension="apcu.so"
apc.enabled=1
apc.shm_size=64M
apc.ttl=7200
apc.enable_cli=1
Save and close the file and restart Apache:
brew services restart httpd
sphp 7.4
pecl install xdebug-3.1.6
You will now need to remove the zend_extension="xdebug.so"" entry that PECL adds to the top of your php.ini. So edit this file and remove the top line:
code /opt/homebrew/etc/php/7.4/php.ini
Create a new config file for XDebug:
code /opt/homebrew/etc/php/7.4/conf.d/ext-xdebug.ini
And add the following to it:
[xdebug]
zend_extension="xdebug.so"
xdebug.mode=develop,debug
xdebug.start_with_request=yes
xdebug.client_host=127.0.0.1
xdebug.discover_client_host=1
xdebug.client_port=9003
Save and close the file.
sphp 8.2
pecl install xdebug
You will now need to remove the zend_extension="xdebug.so"" entry that PECL adds to the top of your php.ini. So edit this file and remove the top line:
code /opt/homebrew/etc/php/8.2/php.ini
Create a new config file for XDebug:
code /opt/homebrew/etc/php/8.2/conf.d/ext-xdebug.ini
And add the following to it:
[xdebug]
zend_extension="xdebug.so"
xdebug.mode=develop,debug
xdebug.start_with_request=yes
xdebug.client_host=127.0.0.1
xdebug.discover_client_host=1
xdebug.client_port=9003
Save and close the file.
sphp 8.3
pecl install xdebug
You will now need to remove the zend_extension="xdebug.so"" entry that PECL adds to the top of your php.ini. So edit this file and remove the top line:
code /opt/homebrew/etc/php/8.3/php.ini
Create a new config file for XDebug:
code /opt/homebrew/etc/php/8.3/conf.d/ext-xdebug.ini
And add the following to it:
[xdebug]
zend_extension="xdebug.so"
xdebug.mode=develop,debug
xdebug.start_with_request=yes
xdebug.client_host=127.0.0.1
xdebug.discover_client_host=1
xdebug.client_port=9003
Save and close the file and restart Apache:
brew services restart httpd
For PHP 8.4 there is no XDebug available at the time of writing these instructions.
W00fz created a Xdebug Toggler for MacOS. It's a nice tool for quickly enabling/disabling xdebug. Install this with brew:
curl -L https://gist.githubusercontent.com/rhukster/073a2c1270ccb2c6868e7aced92001cf/raw/c1629293bcf628cd6ded20c201c4ef0a2fa79144/xdebug > /opt/homebrew/bin/xdebug
chmod +x /opt/homebrew/bin/xdebug
You can now simply turn xdebug on or off with these commands:
xdebug on
xdfebug off
MailHog is a small application which intercepts email sent out of your sites and keeps it locally. You can use a web interface to review the mail. This comes in handy when testing the email features of the sites you are building without risking any email accidentally escaping to the wild.
brew install mailhog
brew services start mailhog
Mailhog runs a SMTP mailserver at port 1025. To intercept all outgoing emails from a local Joomla website for example setup your Joomla mail settings as follows:
Send Mail: yes
From Email: <sending emailadrress>
From Name: <sender name>
Mailer: SMTP
SMTP Host: 127.0.0.1
SMTP Port: 1025
SMTP Security: None
SMTP Authentication: No
Open your webbrowser at http://127.0.0.1:8025 and see all outgoing emails collected there. Emails are not sent to the Internet.
For even easier user of Mailhog we install mhsendmail and configure that in php.ini. This way emails sent through PHP will automatically be caught by Mailhog. Install go:
brew install go
Install mhsendmail through go:
go install github.com/mailhog/mhsendmail@latest
Move the mhsendmail binary to /usr/local/bin:
sudo mv ./go/bin/mhsendmail /usr/local/bin
Now all we need to do is configure mhsendmail in php.ini. Edit the php.ini's:
code /opt/homebrew/etc/php/7.4/php.ini
code /opt/homebrew/etc/php/8.2/php.ini
code /opt/homebrew/etc/php/8.3/php.ini
code /opt/homebrew/etc/php/8.4/php.ini
Once you have php.ini loaded in Visual Studio Code find the line with:
;sendmail_path =
and change that to:
sendmail_path = /usr/local/bin/mhsendmail
Save and close php.ini and restart apache:
brew services restart httpd
To use a local SSL certificate we need to install two tools.
brew install mkcert nss
Next we have to install the server and run it (enter your password when prompted):
mkcert -install
You have to input your password (or fingerprint) a few times and then you should get the following message:
Created a new local CA 💥
The local CA is now installed in the system trust store! ⚡️
The local CA is now installed in the Firefox trust store (requires browser restart)! 🦊
Create a location for the certificates:
cd /opt/homebrew/etc/httpd
mkdir certs && cd certs
Generate a certificate for localhost:
mkcert localhost
Generate a wildcard certificate for *.dev.test:
mkcert "*.dev.test"
Now we need to modify our Apache SSL configuration:
code /opt/homebrew/etc/httpd/httpd.conf
Uncomment the line with:
#LoadModule socache_shmcb_module lib/httpd/modules/mod_socache_shmcb.so
So, remove the # at the beginning of the line.
Uncomment the line with:
#LoadModule ssl_module lib/httpd/modules/mod_ssl.so
Here too, remove the # at the beginning of the line.
Uncomment the line with:
#Include /opt/homebrew/etc/httpd/extra/httpd-ssl.conf
Here too, remove the # at the beginning of the line. Save and close the file.
Modify the httpd-ssl configuration:
code /opt/homebrew/etc/httpd/extra/httpd-ssl.conf
Change the line with:
Listen 8443
to
Listen 443
Then, find the line that starts with:
<VirtualHost _default_:8443>
and delete that line and all lines below it. So the file should end with:
##
## SSL Virtual Host Context
##
Save and close the file.
code /opt/homebrew/etc/httpd/httpd.conf
Replace:
#LoadModule vhost_alias_module lib/httpd/modules/mod_vhost_alias.so
with:
LoadModule vhost_alias_module lib/httpd/modules/mod_vhost_alias.so
Replace:
#Include /opt/homebrew/etc/httpd/extra/httpd-vhosts.conf
with:
Include /opt/homebrew/etc/httpd/extra/httpd-vhosts.conf
Modify httpd-vhosts.conf:
code /opt/homebrew/etc/httpd/extra/httpd-vhosts.conf
Remove all existing lines below the comments block and add the following lines:
<Directory "/Users/your_user/Development/Sites">
Allow From All
AllowOverride All
Options +Indexes
Require all granted
</Directory>
<VirtualHost *:80>
DocumentRoot "/Users/your_user/Development/Sites"
ServerName localhost
RewriteEngine On
RewriteCond %{HTTPS} off
RewriteRule ^(.*)$ https://%{HTTP_HOST}$1 [R=301,L]
ErrorLog "/opt/homebrew/var/log/httpd/error_log"
CustomLog "/opt/homebrew/var/log/httpd/access_log" common
</VirtualHost>
<VirtualHost *:443>
DocumentRoot "/Users/your_user/Development/Sites"
ServerName localhost
SSLEngine on
SSLCertificateFile "/opt/homebrew/etc/httpd/certs/localhost.pem"
SSLCertificateKeyFile "/opt/homebrew/etc/httpd/certs/localhost-key.pem"
</VirtualHost>
<Virtualhost *:80>
VirtualDocumentRoot "/Users/your_user/Development/Sites/%1"
ServerAlias *.dev.test
RewriteEngine On
RewriteCond %{HTTPS} off
RewriteRule ^(.*)$ https://%{HTTP_HOST}$1 [R=301,L]
UseCanonicalName Off
</Virtualhost>
<VirtualHost *:443>
VirtualDocumentRoot "/Users/your_user/Development/Sites/%1"
ServerAlias *.dev.test
SSLEngine on
SSLCertificateFile "/opt/homebrew/etc/httpd/certs/_wildcard.dev.test.pem"
SSLCertificateKeyFile "/opt/homebrew/etc/httpd/certs/_wildcard.dev.test-key.pem"
</VirtualHost>
Replace your_user everywhere with your own macOS username.
brew services restart httpd
For easy starting, stopping and restarting the proicesses for Apache and MySQL and Mailhog I use these three simple scripts. Add these scripts to a folder that is inside your path, for example in /usr/local/bin or in /opt/homebrew/bin :
sudo nano /usr/local/bin/startdev
Add the following code:
#!/bin/zsh
# Start Dnsmasq
sudo brew services start dnsmasq
# Start Apache
brew services start httpd
# Start MariaDB
brew services start mariadb
# Start Mailhog
brew services start mailhog
Save the file by pressing Ctrl-X followed by Y and Enter.
sudo nano /usr/local/bin/stopdev
Add the following code:
#!/bin/zsh
# Stop Mailhog
brew services stop mailhog
# Stop MariaDB
brew services stop mariadb
# Stop Apache
brew services stop httpd
# Stop Dnsmasq
sudo brew services stop dnsmasq
Save the file by pressing Ctrl-X followed by Y and Enter.
sudo nano /usr/local/bin/restartdev
Add the following code:
#!/bin/zsh
# Restart Apache
brew services restart httpd
# Restart MariaDB
brew services restart mariadb
# Restart Mailhog
brew services restart mailhog
# Restart Dnsmasq
sudo brew services restart dnsmasq
sudo chmod +x /usr/local/bin/startdev /usr/local/bin/stopdev /usr/local/bin/restartdev
Your local Apache / PHP / MariaDB / Mailhog setup is now ready for use.