The LAMP Stack (Linux, Apache, MySQL, and PHP) is the most popular web hosting environment for the PHP based application. Here Linux is an operating system, Apache is the popular web server developed by Apache Foundation, MySQL is relational database management system used for storing data and PHP is the widely used programming language.
This article explain you to how to install Linux, Apache, MySQL and PHP (LAMP Stack) on Ubuntu 18.04 (Bionic Beaver) Linux Systems.
You must have root or sudo privileged user access to your Ubuntu 18.04 system. Login to your Ubuntu system using GUI for Desktop and SSH for the server edition.
Now upgrade current packages to latest version.
sudo apt update
sudo apt upgrade
Step 1 – Installing Apache2
After installing PHP on your system, let’s start the installation of Apache2 in your system. Your also required to install libapache2-mod-php module to work PHP with Apache2.
sudo apt install apache2 -y
To create additional virtual hosts visit this tutorial.
Open a web browser and access your server via IP address on port 80. You will see the default Apache page.
Step 2 – Installing PHP
Ubuntu 18.04 has default PHP 7.2 for installation. But we suggest adding additional PPA for PHP installation which includes multiple other versions of PHP. Use the following commands to update apt cache and install PHP packages on your system.
sudo apt-get install software-properties-common
sudo add-apt-repository ppa:ondrej/php
sudo apt update
sudo apt install -y php7.2
You may also need to install some additional PHP modules for supporting various tasks
sudo apt install php7.2-curl php7.2-gd php7.2-json php7.2-mbstring php7.2-xml
Verify the installed PHP version
php -vPHP 7.2.34-8+ubuntu18.04.1+deb.sury.org+1 (cli) (built: Oct 31 2020 16:57:15) ( NTS ) Copyright (c) 1997-2018 The PHP Group Zend Engine v3.2.0, Copyright (c) 1998-2018 Zend Technologies with Zend OPcache v7.2.34-8+ubuntu18.04.1+deb.sury.org+1, Copyright (c) 1999-2018, by Zend Technologies
Step 3 – Installing MySQL
Finally, install mysql-server packages for the MySQL database. Also, install the php-mysql package to use MySQL support using PHP. Use the following command to install it.
sudo apt install mysql-server php7.2-mysql
The installer will prompt for the root password, This password will work for your MySQL root user. After installing MySQL execute the following command for initial settings of MySQL server.
The configuration wizzard will ask to your setup root password, password policy and removal test account and database. Complete wizard as per your required settings.
Step 4 – Installing phpMyAdmin
You can also install phpMyAdmin for the administration of MySQL using web interface.
sudo apt install phpmyadmin
Once the installation finished, you can access phpMyAdmin by usign server ipaddress like: http://server-ip/phpmyadmin/
Step 5 – Manage Services
After installing all the services on your system. Restart MySQL and Apache service to reload any changes done manually.
sudo systemctl restart apache2
sudo systemctl restart mysql
Step 6 – Configure Firewall
The systems with iptables/ufw enabled, execute the following commands to open port 80 for public access of web server.
sudo firewall-cmd --permanent --zone=public --add-port=3306/tcp
sudo ufw allow 80/tcp
Step 7 – Test Setup
After completing all setup. Let’s create a info.php file website document root with following content.
<?php phpinfo(); ?>
Now access this file in web browser. You will see the screen like below with all details of PHP on server.