Apple released its 2020 newest macOS Big Sur on November 12, 2020. It is a time of the year again that you might need to reconfigure your macOS if you are upgrading from the macOS Catalina. Or if you have a new macOS, follow the below steps to enable your local web server on macOS Big Sur (version 11.0.1)
NOTE: For macOS 12 Monterey, please check out the How to Setup MAMP (MacOS, Apache, MySQL, PHP) on macOS12 Monterey (2021)
Table of Contents
Start the Apache Server
macOS comes with Apache Server by default. To start the built-in Apache server, open the Terminal
app from your Application folder or type Terminal
in the Spotlight Search (shortcut: Command + Space Bar)
Type sudo apachectl start
and press enter
Open any of your favorite browser (e.g. Safari, Chrome)
Type localhost
or 127.0.0.1
in the address bar
If Apache Server is started, you should see the below:
Create Sites Directory
It is recommended to create a Sites
directory under username folder (username is your mac login name) This directory will be your document root for any web-related stuff.
- Go to
Mac HDD
>Users
>[your account folder]
- Create a folder with the name
Sites
. When the folder is created, it will generate a folder with a compass image on the folder as you can see from the below screenshot.
Create username.conf file
To be able to recognize the files putting into Sites
directory, username.conf
needed to be setup.
1. Type whoami
and press enter. (Note down the name. this is your account name / username) For example, if your username is developer
, we will be making a .conf
file with the name of developer.conf
under /etc/apache2/users
2. Type cd /etc/apache2/users
and press enter.
3. Type ls
and press enter. Check if there is an existing username.conf
file (username
is your account name)
4. If there is an existing username.conf, make a backup copy by typing sudo cp username.conf username.conf.bak
5. Type sudo nano username.conf
and press enter (note: username
will be your account name e.g. developer.conf
)
6. Copy and paste the following configuration.
<Directory "/Users/developer/Sites/">
AllowOverride All
Options Indexes MultiViews FollowSymLinks
Require all granted
</Directory>
7. Press Control + o
and press enter to save the file.
8. Press Control + x
to exit the nano editor.
Configure the httpd.conf file
1. Open the Terminal
app from your Application folder or type Terminal
in the Spotlight Search (shortcut: Command + Space Bar
)
2. Type cd /etc/apache2 and press enter.
3. Type sudo cp httpd.conf httpd.conf.bak
and press enter. (This step is optional if you want to keep the copy of the original config file but I would recommend keeping one just in case.)
4. Type sudo nano /etc/apache2/httpd.conf
and press enter.
5. Press control + w
and type LoadModule authz_core_module
and press enter. (control + w
will activate the search and it will look for a line with the keyword you put in)
Uncomment the following modules. The #
you see in front of each line means that line is commented out. That means that a specific line or module on that line will be ignored. What we want to do is, uncomment this so the module is enabled.
6. Use control + w
to find each of the modules below.
LoadModule authn_core_module libexec/apache2/mod_authn_core.so
LoadModule authz_host_module libexec/apache2/mod_authz_host.so
LoadModule userdir_module libexec/apache2/mod_userdir.so
LoadModule include_module libexec/apache2/mod_include.so
LoadModule rewrite_module libexec/apache2/mod_rewrite.so
7. Uncomment the following line for the User home directories.
Include /private/etc/apache2/extra/httpd-userdir.conf
8. Replace the below two lines with your username document root. (You can comment on those two lines by putting #
in front of them.
DocumentRoot "/Library/WebServer/Documents"
<Directory "/Library/WebServer/Documents">
9. Replace with the following:
Note: USERNAME needs be replaced with your username (e.g. developer)
DocumentRoot "/Users/USERNAME/Sites/"
<Directory "/Users/USERNAME/Sites/">
10. Press control + w
and type AllowOverride None
then enter
Replace AllowOverride None
to AllowOverride All
Your DocumentRoot
configuration in httpd.conf
will look like below:
DocumentRoot "/Users/developer/Sites/"
<Directory "/Users/developer/Sites/">
#
# Possible values for the Options directive are "None", "All",
# or any combination of:
# Indexes Includes FollowSymLinks SymLinksifOwnerMatch ExecCGI MultiViews
#
# Note that "MultiViews" must be named *explicitly* --- "Options All"
# doesn't give it to you.
#
# The Options directive is both complicated and important. Please see
# http://httpd.apache.org/docs/2.4/mod/core.html#options
# for more information.
#
Options FollowSymLinks Multiviews
MultiviewsMatch Any
#
# AllowOverride controls what directives may be placed in .htaccess files.
# It can be "All", "None", or any combination of the keywords:
# AllowOverride FileInfo AuthConfig Limit
#
AllowOverride All
#
# Controls who can get stuff from this server.
#
Require all granted
</Directory>
11. Press control + o
and press enter to save the file.
12. Press control + x
to exit the nano editor.
Configure the httpd-userdir.conf file
1. Type cd /etc/apache2/extra
and press enter.
2. Type sudo cp httpd-userdir.conf httpd-userdir.conf.bak
and press enter. (this step is optional if you want to keep the copy of original file.)
3. Type sudo nano httpd-userdir.conf and press enter.
Uncomment the following line.
Include /private/etc/apache2/users/*.conf
4. Press control + o
and press enter to save the file.
5. Press control + x
to exit the nano editor.
6. Type sudo apachectl restart
(this step will restart the Apache server to take effect of the changes made in the config file)
Enable the PHP
macOS has built-in PHP (at least in Big Sur and prior versions) You just need to enable the PHP from the Apache’s config file. Follow the below steps to do so.
1. Open the Terminal
app from your Application folder or type Terminal
in the Spotlight Search (shortcut: Command + Space Bar
)
2. Type cd /etc/apache2
and press enter.
3. Type sudo nano /etc/apache2/httpd.conf
and press enter.
4. Press control + w
and type php
(this will search for a line with keyword php
in Apache’s config file.)
You should be seeing the following line. Uncomment the LoadModule php7_module libexec/apache2/libphp7.so
by removing the #
in the front of that line of code.
5. Press control + o
and press enter to save the file.
6. Press control + x
to exit the nano editor.
7. Type sudo apachectl restart
(this step will restart the Apache server to take effect of the changes made in the config file)
Create a phpinfo() page
To try out the PHP is working on your local mac web server, create a phpinfo() file and load it on the browser.
1. Open the Terminal
app from your Application folder or type Terminal
in the Spotlight Search (shortcut: Command + Space Bar
)
2. Type cd ~/Sites/ and press enter.
3. Type sudo nano phpinfo.php and press enter. (this will bring up the nano editor with blank screen since the phpinfo.php is newly created file and has no code at this point)
4. Put the following code.
<?php phpinfo(); ?>
5. Press control + o
and press enter to save the file.
6. Press control + x
to exit the nano editor.
7. Open a browser and type the following in the address bar.
http://localhost/~developer/phpinfo.php
You should be seeing a page something like below. This means, the PHP is working on your local mac server.
Setting Up the MySQL Server
To be able to use a local database, you need to install a database server. In this case, we will be installing the MySQL Server. Follow the below steps to setup your MySQL Server on your local macOS.
2. Download the installer with DMG file.
3. Double click the MySQL server installer.
Follow the instructions on the Installer.
If above message shows up, click Allow.
Select Use Strong Password Encryption
Setup a password for “root” user and click Finish to complete the setup.
Once the installation is complete, you can move the installer to the trash.
Now, if you go to System Preferences, you should be seeing MySQL.
If you check, it should have the green indicator showing it is up and running.
If you need to setup a MySQL Workbench, you can refer to Using MySQL Workbench on macOS Catalina (2019)
If you are using macOS Catalina, check out Setting Up Your Local Server on macOS Catalina (2019) – MAMP – macOS, Apache, MySQL, PHP to setup your mac local web server.
Latest Post
- How to convert MD (markdown) file to PDF using Pandoc on macOS Ventura 13
- How to make MD (markdown) document
- How to Install Docker Desktop on mac M1 chip (Apple chip) macOS 12 Monterey
- How to install MySQL Workbench on macOS 12 Monterey mac M1 (2021)
- How to install MySQL Community Server on macOS 12 Monterey (2021)
Pingback: Setting Up Your Local Server on macOS Catalina (2019) - MAMP - macOS, Apache, MySQL, PHP | Tech CookBook