Combining React for the front-end, PHP for the back-end, and Apache as the web server provides a robust stack for modern web development. This article will guide you through setting up and automating the deployment of a React application with an Apache server and a PHP backend. By the end, you’ll have automated scripts for building and deploying your React app, configuring Apache, and setting up your PHP backend.
Prerequisites
Before you start, ensure you have the following installed:
- Node.js and npm: For building the React application.
- Apache: To serve the React application and PHP scripts.
- PHP: For handling server-side logic and providing API endpoints.
- Basic understanding of React, PHP, and Apache configuration.
Step 1: Set Up the React Application
First, create your React application and prepare it for deployment.
1.1 Create a React Application
Use create-react-app
to set up a new React project:
npx create-react-app my-app
cd my-app
1.2 Build the React Application
Build the React application to generate static files suitable for deployment:
npm run build
The build output will be in the build
directory.
Step 2: Set Up the PHP Backend
Create a PHP script that will serve as your API endpoint or handle server-side logic.
2.1 Create a PHP Script
Create a file named api.php
with the following content:
api.php
<?php
header('Content-Type: application/json');
// Example data
$data = [
['id' => 1, 'name' => 'John Doe'],
['id' => 2, 'name' => 'Jane Smith']
];
echo json_encode($data);
?>
This script returns a JSON response with sample data.
Step 3: Configure Apache
Configure Apache to serve the React application and PHP scripts.
3.1 Deploy the React Build Files
Copy the contents of the build
directory from your React app to the Apache server directory:
sudo cp -r build/* /var/www/html/my-app/
3.2 Set Up Apache Virtual Host
Create and configure an Apache virtual host file to serve the React application and handle PHP scripts.
Create a new configuration file:
/etc/apache2/sites-available/react-app.conf
<VirtualHost *:80>
ServerAdmin webmaster@mydomain.com
DocumentRoot /var/www/html/my-app
ServerName mydomain.com
<Directory /var/www/html/my-app>
Options Indexes FollowSymLinks
AllowOverride All
Require all granted
</Directory>
# Add PHP configuration for handling .php files
<FilesMatch \.php$>
SetHandler application/x-httpd-php
</FilesMatch>
ErrorLog \${APACHE_LOG_DIR}/error.log
CustomLog \${APACHE_LOG_DIR}/access.log combined
</VirtualHost>
Replace /var/www/html/my-app
with the path to your React build directory and mydomain.com
with your domain name.
3.3 Enable the Virtual Host
Enable the new virtual host configuration:
sudo a2ensite react-app.conf
3.4 Reload Apache
Apply the changes by reloading Apache:
sudo systemctl reload apache2
Step 4: Handle Client-Side Routing in React
To ensure React Router handles routing correctly, create a .htaccess
file in your React build directory.
/var/www/html/my-app/.htaccess
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /
RewriteRule ^index\.html$ - [L]
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule . /index.html [L]
</IfModule>
Step 5: Automate the Deployment
Automate the setup with scripts to streamline deployment and configuration.
5.1 React Build and Deployment Script
Create a script to automate the build and deployment of your React application.
deploy-react.sh
#!/bin/bash
# Define variables
REACT_APP_DIR="/path/to/your/react-app"
APACHE_DIR="/var/www/html/my-app"
# Navigate to the React app directory
cd $REACT_APP_DIR
# Build the React application
echo "Building React application..."
npm install
npm run build
# Clean the old build files from the Apache directory
echo "Cleaning old build files..."
sudo rm -rf $APACHE_DIR/*
# Copy the new build files to the Apache directory
echo "Deploying new build files..."
sudo cp -r build/* $APACHE_DIR/
echo "Deployment completed."
Make the script executable and run it:
chmod +x deploy-react.sh
./deploy-react.sh
5.2 Apache Configuration Script
Create a script to automate Apache configuration.
setup-apache.sh
#!/bin/bash
# Define variables
VHOST_CONF="/etc/apache2/sites-available/react-app.conf"
APACHE_DIR="/var/www/html/my-app"
# Create Apache virtual host configuration
echo "Creating Apache virtual host configuration..."
sudo tee $VHOST_CONF > /dev/null <<EOL
<VirtualHost *:80>
ServerAdmin webmaster@mydomain.com
DocumentRoot $APACHE_DIR
ServerName mydomain.com
<Directory $APACHE_DIR>
Options Indexes FollowSymLinks
AllowOverride All
Require all granted
</Directory>
# Add PHP configuration for handling .php files
<FilesMatch \.php$>
SetHandler application/x-httpd-php
</FilesMatch>
ErrorLog \${APACHE_LOG_DIR}/error.log
CustomLog \${APACHE_LOG_DIR}/access.log combined
</VirtualHost>
EOL
# Enable the new virtual host configuration
echo "Enabling virtual host..."
sudo a2ensite react-app.conf
# Reload Apache to apply changes
echo "Reloading Apache..."
sudo systemctl reload apache2
echo "Apache setup completed."
Make the script executable and run it:
chmod +x setup-apache.sh
./setup-apache.sh
5.3 PHP Deployment Script
Create a script to automate the deployment of your PHP script.
deploy-php.sh
#!/bin/bash
# Define variables
PHP_SCRIPT_SRC="/path/to/your/api.php"
APACHE_PHP_DIR="/var/www/html/my-app"
# Copy PHP script to Apache directory
echo "Deploying PHP script..."
sudo cp $PHP_SCRIPT_SRC $APACHE_PHP_DIR/
echo "PHP script deployment completed."
Make the script executable and run it:
chmod +x deploy-php.sh
./deploy-php.sh
5.4 Master Automation Script
Create a master script to run all the individual setup scripts.
setup-full.sh
#!/bin/bash
# Run individual setup scripts
./deploy-react.sh
./setup-apache.sh
./deploy-php.sh
echo "Full setup completed."
Make the script executable and run it:
chmod +x setup-full.sh
./setup-full.sh
Conclusion
Automating the deployment of a React application with Apache and PHP simplifies the process, reduces the risk of errors, and improves efficiency. By using the provided scripts, you can quickly deploy and configure your application, ensuring that updates and changes are applied consistently.
Feel free to adapt these scripts to fit your specific project requirements and deployment environments. For a more advanced setup, consider integrating these scripts into a CI/CD pipeline using tools like Jenkins, GitHub Actions, or GitLab CI to further streamline your deployment process.
Links
Written by Dimitrios S. Sfyris, founder and developer of AspectSoft, a software company specializing in innovative solutions. Follow me on LinkedIn for more insightful articles and updates on cutting-edge technologies.
Subscribe to our newsletter!
+ There are no comments
Add yours