AlmaLinux 9: How to Configure Apache (httpd) to Use PHP Scripts

PHP is one of the most widely used server-side scripting languages for building dynamic websites and web applications. Running PHP scripts on an Apache web server is a common setup in the LAMP (Linux, Apache, MySQL, PHP) stack. AlmaLinux 9, a powerful and stable RHEL-based Linux distribution, is ideal for this setup.

In this detailed guide, we’ll cover how to configure Apache (httpd) on AlmaLinux 9 to use PHP scripts. This includes installing and configuring both Apache and PHP, verifying that they work together, and setting up some basic PHP scripts to test the configuration. Table of Contents

  • Introduction to PHP and Apache

  • Prerequisites

  • Step 1: Installing Apache and PHP on AlmaLinux 9

  • Step 2: Configuring Apache to Use PHP

  • Step 3: Testing PHP with Apache

  • Step 4: Configuring PHP for Optimal Performance

  • Step 5: Securing Your PHP Installation

  • Conclusion

1. Introduction to PHP and Apache

Apache, also known as httpd, is one of the most popular web servers in the world, and PHP is a highly versatile scripting language that can be embedded into HTML. When these two technologies are combined, Apache serves the web pages while PHP processes any server-side scripts within them.

Configuring Apache to use PHP scripts involves installing both Apache and PHP, ensuring that Apache recognizes and properly executes PHP scripts, and adjusting configurations to ensure secure and efficient operation.

In this tutorial, we’ll guide you step by step to set up and configure Apache to use PHP scripts on AlmaLinux 9.

2. Prerequisites

Before you start, make sure you meet the following requirements:

  • AlmaLinux 9 installed on your system.

  • Root or sudo access to configure Apache and PHP.

  • A basic understanding of how to use the Linux terminal.

3. Step 1: Installing Apache and PHP on AlmaLinux 9

The first step in configuring Apache to use PHP is to install both Apache and PHP. These packages are available in the AlmaLinux 9 repository and can be installed using the dnf package manager.

Install Apache

To install Apache, run the following command:

sudo dnf install httpd

After installation, enable and start the Apache service:

sudo systemctl enable httpd
sudo systemctl start httpd

You can verify that Apache is running with this command:

sudo systemctl status httpd

Install PHP

Next, install PHP along with some common PHP extensions. The basic PHP package includes the core functionality, but many applications and frameworks require additional extensions. You can install PHP and its commonly used extensions using the following command:

sudo dnf install php php-mysqlnd php-pdo php-gd php-mbstring php-xml php-json

Here’s a breakdown of the PHP packages installed:

  • php: The core PHP package.

  • php-mysqlnd: The MySQL driver for PHP.

  • php-pdo: The PHP Data Objects (PDO) extension.

  • php-gd: PHP support for image processing.

  • php-mbstring: Provides multibyte string support in PHP.

  • php-xml: PHP support for XML processing.

  • php-json: PHP support for working with JSON data. Once PHP is installed, restart the Apache service to load the PHP module:

sudo systemctl restart httpd

4. Step 2: Configuring Apache to Use PHP

Once Apache and PHP are installed, you need to configure Apache to handle PHP files correctly. This is done by ensuring that Apache can recognize PHP files, pass them to the PHP interpreter, and then return the output to the client (browser).

Check PHP Module for Apache

The PHP module should have been installed and enabled automatically with the php package. You can confirm that PHP support is loaded by checking the Apache configuration files.

Open the Apache configuration file located at /etc/httpd/conf/httpd.conf to check for PHP module configuration:

sudo nano /etc/httpd/conf/httpd.conf```

Ensure that the following lines exist in the file:
```bash
LoadModule php_module modules/libphp.so
AddHandler php-script .php
DirectoryIndex index.php index.html

These lines ensure that Apache loads the PHP module and treats files with the .php extension as PHP scripts.

Test the PHP Configuration

To verify that PHP is properly integrated with Apache, create a simple PHP file in the web root directory. The default document root for Apache on AlmaLinux is /var/www/html.

Create a PHP test file:

sudo nano /var/www/html/info.php

Add the following PHP code to the file:

<?php
phpinfo();
?>

This script will display detailed information about your PHP installation.

Save and close the file, then open a web browser and navigate to the following URL:

http://your-server-ip/info.php

You should see a PHP information page showing details about your PHP installation, including loaded modules, configuration settings, and environment variables. If this page loads, it means PHP is working correctly with Apache.

5. Step 3: Testing PHP with Apache

To further confirm that PHP is working with Apache, you can create another PHP script that outputs dynamic content.

Create another PHP file in the document root:

sudo nano /var/www/html/test.php

Add the following PHP code:

<?php
echo "Hello, AlmaLinux! PHP is working on Apache.";
?>

Save the file and access it in your browser at:

http://your-server-ip/test.php

If the PHP script works correctly, you should see the message: “Hello, AlmaLinux! PHP is working on Apache.”

6. Step 4: Configuring PHP for Optimal Performance

Now that PHP is functioning, it’s important to configure it for optimal performance. AlmaLinux uses PHP 7 or later, which includes several improvements in performance and memory usage, but there are still a few settings you can adjust to get the most out of your server.

Adjust PHP Settings

The PHP configuration file is located at /etc/php.ini. Open this file in a text editor:

sudo nano /etc/php.ini```

Here are some important PHP settings you may want to tweak:
* **Memory Limit**: Defines the maximum amount of memory a PHP script is allowed to use. You can increase this value based on your server resources. For example:

```bash
  memory_limit = 256m
  • Upload File Size: Defines the maximum allowed size for file uploads. If you’re running applications that handle file uploads, such as a CMS, you may need to increase this value:
  upload_max_filesize = 20M
  post_max_size = 20m
  • Max Execution Time: Specifies the maximum time in seconds a PHP script is allowed to run before it is terminated. This can help prevent poorly written scripts from using up server resources:
  max_execution_time = 60```

After making any changes, save the file and restart Apache:
```bash
sudo systemctl restart httpd

Opcode Caching

PHP includes a built-in opcode cache called OPcache that speeds up script execution by storing precompiled script bytecode in memory. To check if OPcache is enabled, look for it in the output of the phpinfo() function (from the info.php file we created earlier).

If it’s not enabled, you can enable it in the /etc/php.d/10-opcache.ini file. Set the following options to enable and configure OPcache:

opcache.enable=1
opcache.memory_consumption=128
opcache.max_accelerated_files=4000
opcache.revalidate_freq=60```

Restart Apache again to apply the changes:
```bash
sudo systemctl restart httpd

7. Step 5: Securing Your PHP Installation

Running PHP scripts can expose your server to potential vulnerabilities if not properly secured. Here are some tips to help secure your PHP environment:

Disable Unnecessary Functions

Many PHP installations enable potentially dangerous functions by default. These functions can be disabled to reduce the risk of exploitation. Open the /etc/php.ini file and find the disable_functions directive. Add the following functions to the list to disable them:

disable_functions = exec,passthru,shell_exec,system,proc_open,popen,curl_exec,curl_multi_exec```

This will prevent these functions from being used in PHP scripts.

Hide PHP Version

By default, PHP exposes its version number in HTTP headers and error messages. To disable this, set the following directive in `/etc/php.ini`:
```bash
expose_php = Off```

Enable Error Logging

Instead of displaying errors on web pages (which could expose sensitive information to attackers), log errors to a file:
```bash
log_errors = On
error_log = /var/log/php_errors.log```

Make sure the log file is only accessible by root:
```bash
sudo touch /var/log/php_errors.log
sudo chown root:root /var/log/php_errors.log
sudo chmod 600 /var/log/php_errors.log```
## 8. Conclusion

Configuring Apache to use PHP on AlmaLinux 9 is an essential step in setting up a powerful

web server capable of hosting dynamic web applications. In this guide, we covered how to install Apache and PHP, configure Apache to use PHP scripts, and optimize PHP for better performance and security.

With Apache and PHP working together, you’re ready to deploy web applications, content management systems like WordPress, or any custom PHP-based web project. Following the best practices in performance tuning and security will ensure that your server remains efficient and secure.

By completing these steps, you now have a fully functioning LAMP (Linux, Apache, MySQL, PHP) stack on AlmaLinux 9!
Last modified 17.01.2025: new translations (f32b526)