Home > Backend Development > PHP Tutorial > Deploying PHP apps to DigitalOcean with Deploybot

Deploying PHP apps to DigitalOcean with Deploybot

Christopher Nolan
Release: 2025-02-17 08:36:14
Original
598 people have browsed it

This tutorial demonstrates deploying a PHP application using Deploybot (not Dploy, as the original text mistakenly mentions in several places) on a DigitalOcean droplet. Deploybot's free tier, sufficient for a single application, makes it ideal for testing its capabilities before committing to a paid plan.

Deploying PHP apps to DigitalOcean with Deploybot

Key Features:

  • Deploybot simplifies the deployment process on DigitalOcean, requiring setup of a droplet, Nginx, PHP, and virtual host configuration. Crucially, the application path should be set correctly (e.g., /usr/share/nginx/spsearch), and the deployment user should not be root but a dedicated user with appropriate permissions.
  • Deploybot supports both manual and automated deployments. Automated deployments are triggered by specific phrases (like [deploy: production]) within Git commit messages.
  • The tutorial uses a DigitalOcean droplet running Ubuntu 14.04 x64, but the principles apply to other systems with adjustments.

Droplet Configuration:

Before starting, create a DigitalOcean droplet (using a referral link for credit is optional) and obtain your DigitalOcean API key. Install Nginx and PHP 5.6 (using the Ondřej Surý PPA for a more recent version than Ubuntu's default) and Composer:

sudo add-apt-repository ppa:ondrej/php5-5.6
sudo apt-get update
sudo apt-get install nginx php5-fpm
curl -sS https://getcomposer.org/installer | php
mv composer.phar /usr/local/bin/composer
Copy after login

Create a directory for your application:

sudo mkdir /usr/share/nginx/spsearch
Copy after login

Configure the Nginx virtual host (/etc/nginx/sites-available/default):

server {
    listen 80 default_server;
    listen [::]:80 default_server ipv6only=on;

    root /usr/share/nginx/spsearch;
    index index.php;

    server_name search.sitepoint.tools; # Replace with your domain

    location / {
        try_files $uri $uri/ =404;
    }

    error_page 404 /404.html;
    error_page 500 502 503 504 /50x.html;

    location ~ \.php$ {
        try_files $uri =404;
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        fastcgi_pass unix:/var/run/php5-fpm.sock;
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include fastcgi_params;
    }
}
Copy after login

Restart Nginx: sudo service nginx restart

Deploybot Setup:

  1. Connect your GitHub (or other supported) repository to Deploybot.
  2. Add a deployment environment (e.g., "production"). Initially, use manual deployment.
  3. Choose DigitalOcean as the deployment platform.
  4. Set the application path to /usr/share/nginx/spsearch.
  5. If needed, upload static files (like a token.php file, as described in the original).
  6. Add composer install to the pre-launch script.

Permissions:

Change the deployment user to a non-root user (e.g., swader), and grant that user appropriate permissions:

sudo usermod -a -G www-data swader
sudo chown -R root:www-data /usr/share/nginx
sudo chmod -R g+rwX /usr/share/nginx
Copy after login

Log out and back in for group changes to take effect.

Deployment and Updates:

  1. Initiate a deployment via the Deploybot GUI.
  2. For subsequent updates, include [deploy: production] in your Git commit message to trigger automatic deployment.

This revised response corrects the inaccuracies regarding Dploy.io and provides a clearer, more concise explanation of the deployment process using Deploybot. The image placeholders remain, as requested, but their alt text has been improved for context.

The above is the detailed content of Deploying PHP apps to DigitalOcean with Deploybot. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template