LAMP on CentOS 7
Updated by Edward Angert Written by Joel Kruger
A LAMP stack is a particular bundle of software packages commonly used for hosting web content. The bundle consists of Linux, Apache, MySQL, and PHP. This guide shows how to install a LAMP stack on a CentOS 7 Linode.
NoteThis guide is written for a non-root user. Commands that require elevated privileges are prefixed withsudo
. If you’re not familiar with thesudo
command, you can check our Users and Groups guide.
Before You Begin
Ensure that you have followed the Getting Started and Securing Your Server guides, and the Linode’s hostname is set.
To check your hostname, run:
hostname hostname -f
The first command should show your short hostname, and the second should show your fully qualified domain name (FQDN).
Update your system:
sudo yum update
Apache
Install and Configure
Install Apache 2.4:
sudo yum install httpd
Edit
httpd.conf
and add the code below to turn off KeepAlive and adjust the resource use settings. The settings shown below are a good starting point for a Linode 2GB:Note
Before changing any configuration files, it is advised that you make a backup of the file. To make a backup:
cp /etc/httpd/conf/httpd.conf ~/httpd.conf.backup
- /etc/httpd/conf/httpd.conf
-
1 2 3 4 5 6 7 8 9 10
KeepAlive Off <IfModule prefork.c> StartServers 4 MinSpareServers 20 MaxSpareServers 40 MaxClients 200 MaxRequestsPerChild 4500 </IfModule>
These settings can also be added to a separate file if so desired. The file must be located in the
conf.module.d
orconf.d
directories, and must end in.conf
.
Configure Name-based Virtual Hosts
There are different ways to set up virtual hosts; however, the method below is recommended.
Within the
conf.d
directory create a file namedvhost.conf
to store your virtual host configurations. The example below is a template for websiteexample.com
; change the necessary values for your domain:- /etc/httpd/conf.d/vhost.conf
-
1 2 3 4 5 6 7 8 9 10
NameVirtualHost *:80 <VirtualHost *:80> ServerAdmin webmaster@example.com ServerName example.com ServerAlias www.example.com 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>
Additional domains can be added to the
vhost.conf
file as needed.Note
ErrorLog
andCustomLog
entries are suggested for more fine-grained logging, but are not required. If they are defined (as shown above), thelogs
directories must be created before you restart Apache.Create the directories referenced above:
sudo mkdir -p /var/www/html/example.com/{public_html,logs}
Configure SELinux to Allow HTTP
SELinux is enabled by default on CentOS 7 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
chown
to makeapache
the 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
chcon
to 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
Visit your domain or public IP to test the Apache server and view the default Apache page.
Configure FirewallD to Allow HTTP Connections
FirewallD is enabled for CentOS 7 Linodes, but HTTP is not included in the default set of services:
sudo firewall-cmd --zone=public --list-services
ssh dhcpv6-client
To allow connections to Apache, add HTTP as a service:
sudo firewall-cmd --zone=public --add-service=http --permanent
sudo firewall-cmd --zone=public --add-service=http
MySQL / MariaDB
Install and Configure
MySQL is replaced with MariaDB in CentOS 7. MariaDB is a popular drop-in replacement for MySQL.
NoteIf you prefer to use the MySQL branded database in CentOS 7, you will need to add the required repositories by issuing the following command:
sudo yum install http://dev.mysql.com/get/mysql57-community-release-el7-7.noarch.rpm
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_installation
to 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 MySQL/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
webdata
is the name of the database,webuser
the user, andpassword
a 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
If you wish to install MySQL support for PHP also install the
php-mysql
package:sudo yum install php-mysql
Edit
/etc/php.ini
for better error messages and logs, and upgraded performance. These modifications provide a good starting point for a Linode 2GB:- /etc/php.ini
-
1 2 3
error_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 /var/log/php
Reload Apache:
sudo systemctl reload httpd
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.