Installing a LAMP Stack on CentOS 8
Updated by Linode Written by Linode
 
            
            
            
A LAMP stack is a particular bundle of software packages commonly used for hosting web content. The bundle consists of Linux, Apache, MariaDB, and PHP. This guide shows you how to install a LAMP stack on a CentOS 8 Linode.
Before You Begin
- Ensure that you have followed the Getting Started and Securing Your Server guides. Ensure that the Linode’s hostname is set. - Check your Linode’s hostname. The first command should show your short hostname and the second should show your fully qualified domain name (FQDN). - hostname hostname -f- Note If you have a registered domain name for your website, then add the domain to the Linode server on which you plan to install the LAMP stack. If you do not have a registered domain name, then replace- example.comwith the IP address of the Linode server in the following instructions.
- Update your system: - sudo yum update- Note This guide is written for a non-root user. Commands that require elevated privileges are prefixed with- sudo. If you’re not familiar with the- sudocommand, you can check our Users and Groups guide.
Apache
Install and Configure
- Install Apache 2.4: - sudo yum install httpd
- Enable Apache to start at boot and start the Apache service: - sudo systemctl enable httpd.service sudo systemctl start httpd.service
- Create a - httpd-mpm.conffile and add the code in the example to turn off KeepAlive and adjust the resource use settings. The settings shown below are a good starting point for a Linode 2GB:- Note - As a best practice, you should create a backup of your Apache configuration file, before making any configuration changes to your Apache installation. To make a backup in your home directory: - cp /etc/httpd/conf/httpd.conf ~/httpd.conf.backup- /etc/httpd/conf.modules.d/httpd-mpm.conf
- 
1 2 3 4 5 6 7 8 9KeepAlive Off <IfModule prefork.c> StartServers 4 MinSpareServers 20 MaxSpareServers 40 MaxClients 200 MaxRequestsPerChild 4500 </IfModule>
 
Configure Name-based Virtual Hosts
There are different ways to set up virtual hosts; however, the method below is recommended.
- Create the directories to store your site files and logs. Replace - example.comwith your own site’s domain name.- sudo mkdir -p /var/www/html/example.com/{public_html,logs}
- Create the directories to store your site’s virtual hosts files: - sudo mkdir -p /etc/httpd/sites-available /etc/httpd/sites-enabled
- Edit Apache’s configuration file to let it know to look for virtual host files in the - /etc/httpd/sites-enableddirectory. Add the example line to the bottom of your- httpd.conffile:- /etc/httpd/conf/httpd.conf
- 
1 2IncludeOptional sites-enabled/*.conf
 
- Navigate to your - /var/www/html/example.comdirectory if you are not already there:- cd /var/www/html/example.com
- Using your preferred text editor create a virtual hosts file. Copy the basic settings in the example below and paste them into the file. Replace all instances of - example.comwith your domain name:- /etc/httpd/sites-available/example.com.conf
- 
1 2 3 4 5 6 7 8 9 10 11<Directory /var/www/html/example.com/public_html> Require all granted </Directory> <VirtualHost *:80> ServerName example.com ServerAdmin webmaster@localhost DocumentRoot /var/www/html/example.com/public_html ErrorLog /var/www/html/example.com/logs/error.log CustomLog /var/www/html/example.com/logs/access.log combined </VirtualHost>
 
- Create a symbolic link from your virtual hosts file in the - sites-availabledirectory to the- sites-enableddirectory. Replace- example.com.confwith the name of your own virtual hosts file.- sudo ln -s /etc/httpd/sites-available/example.com.conf /etc/httpd/sites-enabled/example.com.conf
- Reload to apply your new configuration: - sudo systemctl reload httpd.service- Note If you receive an error when trying to reload your- httpdservice, follow the steps in the Configure SELinux to Allow HTTP section and then reattempt to reload the service.- Additional domains can be added to the - example.com.conffile as needed.- Note - ErrorLogand- CustomLogentries are suggested for more fine-grained logging, but are not required. If they are defined (as shown above), the- logsdirectories must be created before you restart Apache.
Configure SELinux to Allow HTTP
SELinux is enabled by default on CentOS 8 Linodes. Its default setting is to restrict Apache’s access to directories until explicit permissions are granted.
Without these steps, Apache will not start and may give the following error:
  
Jun 21 17:58:09 example.com systemd[1]: Failed to start The Apache HTTP Server.
Jun 21 17:58:09 example.com systemd[1]: Unit httpd.service entered failed state.
Jun 21 17:58:09 example.com systemd[1]: httpd.service failed.
- Use - chownto make- apachethe owner of the web directory:- sudo chown apache:apache -R /var/www/html/example.com/
- Modify the permissions for files and directories: - cd /var/www/html/example.com/ find . -type f -exec sudo chmod 0644 {} \; find . -type d -exec sudo chmod 0755 {} \;
- Use SELinux’s - chconto change the file security context for web content:- sudo chcon -t httpd_sys_content_t /var/www/html/example.com -R sudo chcon -t httpd_sys_rw_content_t /var/www/html/example.com -R
- Enable Apache to start at boot, and restart the service for the above changes to take place: - sudo systemctl enable httpd.service sudo systemctl restart httpd.service
NoteIn addition, if you plan to use any HTTPD scripts on the server, update the corresponding SELinux boolean variable. To allow HTTPD scripts and modules to connect to the network, use thesudo setsebool -P httpd_can_network_connect oncommand.
Configure FirewallD to Allow HTTP and HTTPS Connections
FirewallD is enabled for CentOS 8 Linodes, but HTTP and HTTPS is not included in the default set of services.
- View the default set of services: - sudo firewall-cmd --zone=public --list-services- ssh dhcpv6-client
- To allow connections to Apache, add HTTP and HTTPS as a service: - sudo firewall-cmd --zone=public --add-service=http --permanent sudo firewall-cmd --zone=public --add-service=https --permanent sudo firewall-cmd --zone=public --add-service=http sudo firewall-cmd --zone=public --add-service=https- Visit your domain or public IP to test the Apache server and view the default Apache page. - Note - Rename Apache’s default welcome page. When this file is present it will take precedence over other configurations via the - LocationMatchdirective.- sudo mv /etc/httpd/conf.d/welcome.conf /etc/httpd/conf.d/welcome.conf.bk
MariaDB
Install and Configure
MariaDB is a relational database management system (RDBMS) and is a popular component of many applications.
- Install the MariaDB-server package: - sudo yum install mariadb-server
- Set MariaDB to start at boot and start the daemon for the first time: - sudo systemctl enable mariadb.service sudo systemctl start mariadb.service
- Run - mysql_secure_installationto secure MariaDB. You will be given the option to change the MariaDB root password, remove anonymous user accounts, disable root logins outside of localhost, and remove test databases and reload privileges. It is recommended that you answer yes to these options:- sudo mysql_secure_installation
Create a MariaDB Database
- Log in to MariaDB: - mysql -u root -p- Enter MariaDB’s root password. You will get the MariaDB prompt. 
- Create a new database and user with permissions to use it: - create database webdata; grant all on webdata.* to 'webuser' identified by 'password';- In the above example - webdatais the name of the database,- webuserthe user, and- passworda strong password.
- Exit MariaDB - quit
With Apache and MariaDB installed, you are now ready to move on to installing PHP to provide scripting support for your web pages.
PHP
Install and Configure
- Install PHP: - sudo yum install php php-pear php-mysqlnd
- Edit - /etc/php.inifor better error messages and logs, and upgraded performance. These modifications provide a good starting point for a Linode 2GB:- /etc/php.ini
- 
1 2 3error_reporting = E_COMPILE_ERROR|E_RECOVERABLE_ERROR|E_ERROR|E_CORE_ERROR error_log = /var/log/php/error.log max_input_time = 30
 - Note Ensure that all lines noted above are uncommented. A commented line begins with a semicolon (;).
- Create the log directory for PHP and give the Apache user ownership: - sudo mkdir /var/log/php sudo chown apache:apache /var/log/php- Note - You may need to enable and start the - php-fpm.service. This service provides an alternative PHP FastCGI implementation.- sudo systemctl enable php-fpm.service sudo systemctl start php-fpm.service
- Reload Apache: - sudo systemctl reload httpd.service
Optional: Test and Troubleshoot the LAMP Stack
In this section, you’ll create a test page that shows whether Apache can render PHP and connect to the MariaDB database. This can be helpful in locating the source of an error if one of the elements of your LAMP stack is not communicating with the others.
- Paste the following code into a new file, - phptest.php, in the- public_htmldirectory. Modify- webuserand- passwordto match the information entered in the Create a MariaDB Database section above:- /var/www/html/example.com/public_html/phptest.php
- 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26<html> <head> <title>PHP Test</title> </head> <body> <?php echo '<p>Hello World</p>'; // In the variables section below, replace user and password with your own MariaDB credentials as created on your server $servername = "localhost"; $username = "webuser"; $password = "password"; // Create MariaDB connection $conn = mysqli_connect($servername, $username, $password); // Check connection - if it fails, output will include the error message if (!$conn) { die('<p>Connection failed: </p>' . mysqli_connect_error()); } echo '<p>Connected successfully</p>'; ?> </body> </html>
 
- Navigate to - example.com/phptest.phpfrom your local machine. If the components of your LAMP stack are working correctly, the browser will display a “Connected successfully” message. If not, the output will be an error message.
- Remove the test file: - sudo rm /var/www/html/example.com/public_html/phptest.php
More Information
You may wish to consult the following resources for additional information on this topic. While these are provided in the hope that they will be useful, please note that we cannot vouch for the accuracy or timeliness of externally hosted materials.
Join our Community
Find answers, ask questions, and help others.
This guide is published under a CC BY-ND 4.0 license.