Install LAMP (Linux Apache MySQL and PHP) phpMyAdmin on CentOS 6 7

LAMP represents a full featured stack of the most popular web server, database, web programming language known as Apache, MySQL and PHP. This article will cover the steps on how to install the LAMP on a CentOS 6 and CentOS 7.

Step 1, make sure your system is up to date.

yum update -y

Step 2, install Apache and add Apache to your system’s startup.
Apache is available as a package in the official Cent-OS repositories. The installation of Apache can be as easy as this.

yum install httpd -y
chkconfig --levels 235 httpd on

Step 3, check your Apache installation.

service httpd start

Open your domain in web browser you will be able to see Apache’s default page in your browser.
If you are testing the installing without a domain, use the server IP instead.

To find your Server's IP address, use the command below (You might need to change eth0 to match your VPS):

ifconfig eth0 | grep inet | awk '{ print $2 }'

Step 4, install MySQL server and add MySQL to your system’s startup.

yum install mysql-server -y
chkconfig --levels 235 mysqld on

Start MySQL and run the mysql_secure_installation script. The script will help you to set the MySQL 'root' password, disable remote 'root' login, remove anonymous users and remove the 'test' database.

service mysqld start

It's easiest just to say Yes to all the options. At the end, MySQL will reload and implement the new changes.

By default, a MySQL installation has an anonymous user, allowing anyone to log into MySQL without having to have a user account created for them. This is intended only for testing, and to make the installation go a bit smoother. You should remove them before moving into a production environment.

Remove anonymous users? [Y/n] y
... Success!

Normally, root should only be allowed to connect from 'localhost'. This ensures that someone cannot guess at the root password from the network.

Disallow root login remotely? [Y/n] y
... Success!

By default, MySQL comes with a database named 'test' that anyone can access. This is also intended only for testing, and should be removed before moving into a production environment.

Remove test database and access to it? [Y/n] y
- Dropping test database...
... Success!
- Removing privileges on test database...
... Success!

Reloading the privilege tables will ensure that all changes made so far will take effect immediately.

Reload privilege tables now? [Y/n] y
... Success!

Cleaning up...

All done! If you've completed all of the above steps, your MySQL installation should now be secure.

Thanks for using MySQL!

Step 5, install PHP as an Apache module (mod_php) so you can execute PHP scripts under your Apache web server.

yum install php -y

Step 6, install PHP Modules. PHP has a variety of useful libraries and modules that you can add onto your server.

Check the libraries that are available:

yum search php-

The following is a list of the available PHP modules:

php-bcmath => A module for PHP applications using the bcmath library
php-cli => Command-line interface for PHP
php-common => Common files for PHP
php-dba => A database abstraction layer module for PHP applications
php-devel => Files needed for building PHP extensions
php-embedded => PHP library for embedding in applications
php-enchant => Human Language and Character Encoding Support
php-gd => A module for PHP applications using the gd graphics library
php-imap => A module for PHP applications that use IMAP
php-intl => Internationalization extension for PHP applications
php-ldap => A module for PHP applications that use LDAP
php-mbstring => A module for PHP applications which need multi-byte string handling
php-mysql => A module for PHP applications that use MySQL databases
php-odbc => A module for PHP applications that use ODBC databases
php-pdo => A database access abstraction module for PHP applications
php-pear.noarch => PHP Extension and Application Repository framework
php-pecl-apc => APC cache optimizing PHP intermediate code
php-pecl-memcache => Extension to work with the Memcached caching daemon
php-pgsql => A PostgreSQL database module for PHP
php-process => Modules for PHP scripts using system process interfaces
php-pspell => A module for PHP applications using pspell interfaces
php-recode => A module for PHP applications using the recode library
php-snmp => A module for PHP applications that query SNMP-managed devices
php-soap => A module for PHP applications that use the SOAP protocol
php-tidy => Standard PHP module provides tidy library support
php-xml => A module for PHP applications which use XML
php-xmlrpc => A module for PHP applications which use the XML-RPC protocol
php-zts => Thread-safe PHP interpreter for use with the Apache HTTP Server

Install some necessary modules. For example: PHP's common files and MySQL support for PHP

yum install php-cli php-common php-gd php-mysql php-mbstring

Note: php-mbstring is needed for phpMyAdmin

Step 7, check your PHP installation.

Create a PHP info page within Apache’s document root (/var/www/html).

echo -e "<?php\n\tphpinfo();\n?>" > /var/www/html/info.php

Reload Apache to make the newly installed PHP module take effect.

service httpd restart

Now open "your domain/info.php" in web browser ( and you should see various information page about your PHP installation.

Step 8, install phpMyAdmin so you can easily manage your MySQL databases via a nice frontend written in PHP. phpMyAdmin is NOT available as a package in the official Cent-OS repositories.

Important: before continue the following step, go and check what is the latest version available.
(At the time of writing this article the latest version of phpMyAdmin is 4.2.5. You can replace the version number in the following command.)

wget -P /tmp
tar -zxf /tmp/phpMyAdmin*.tar.gz -C /var/www/html/
mv /var/www/html/phpMyAdmin-4.2.5-english /var/www/html/dbAdmin
cd /var/www/html/mysql

Finish up by visiting your phpMyadmin: http://yourdomain/mysql

Leave a Reply

Your email address will not be published. Required fields are marked *