DEV Community

ServBay
ServBay

Posted on • Edited on • Originally published at support.servbay.com

3 1 1 2 1

How to Migrate NGINX Website to ServBay

ServBay comes with a built-in web server called Caddy, known for its simple configuration and automatic HTTPS. ServBay has already configured the Rewrite rules by default, so users usually do not need to configure them additionally. This article will detail how to migrate an NGINX website to ServBay, using examples with Laravel and WordPress.

Overview

Migrating a website involves transferring existing configurations and files to a new server environment. ServBay uses Caddy as the web server, and for most PHP frameworks and CMS systems, ServBay works out of the box without requiring additional configuration of Rewrite rules.

Preparation Before Migration

Before starting the migration, make sure you have backed up all website files and databases. Various issues may arise during migration, so backups are crucial.

Migrating Laravel Website

NGINX Configuration

The following is a typical NGINX configuration file for a Laravel website:

server {
    listen 80;
    server_name laravel.demo;

    root /Applications/ServBay/www/laravel/public;
    index index.php index.html index.htm;

    location / {
        try_files $uri $uri/ /index.php?$query_string;
    }

    location ~ \.php$ {
        include fastcgi_params;
        fastcgi_pass unix:/Applications/ServBay/tmp/php-cgi.sock;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
    }

    location ~ /\.ht {
        deny all;
    }
}
Enter fullscreen mode Exit fullscreen mode

Caddy Configuration

Important Notice
In ServBay, Rewrite rules and PHP processing rules are already configured by default, so users do not need to manually write configuration files.

The following is a theoretical example of Caddy configuration for comparison and understanding:

laravel.demo {
    root * /Applications/ServBay/www/laravel/public
    php_fastcgi unix//Applications/ServBay/tmp/php-cgi.sock
    file_server

    @notStatic {
        not {
            file {
                try_files {path} {path}/ /index.php?{query}
            }
        }
    }

    rewrite @notStatic /index.php
Enter fullscreen mode Exit fullscreen mode

Migrating WordPress Website

NGINX Configuration

The following is a typical NGINX configuration file for a WordPress website:

server {
    listen 80;
    server_name wordpress.demo;

    root /Applications/ServBay/www/wordpress;
    index index.php index.html index.htm;

    location / {
        try_files $uri $uri/ /index.php?$query_string;
    }

    location ~ \.php$ {
        include fastcgi_params;
        fastcgi_pass unix:/Applications/ServBay/tmp/php-cgi.sock;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
    }

    location ~ /\.ht {
        deny all;
    }
}
Enter fullscreen mode Exit fullscreen mode

Caddy Configuration

Important Notice
In ServBay, Rewrite rules and PHP processing rules are already configured by default, so users do not need to manually write configuration files.
The following is a theoretical example of Caddy configuration for comparison and understanding:

wordpress.demo {
    root * /Applications/ServBay/www/wordpress
    php_fastcgi unix//Applications/ServBay/tmp/php-cgi.sock
    file_server

    @notStatic {
        not {
            file {
                try_files {path} {path}/ /index.php?{query}
            }
        }
    }

    rewrite @notStatic /index.php
}
Enter fullscreen mode Exit fullscreen mode

Summary

Migrating an NGINX website to ServBay's Caddy server is very simple and does not require any configuration modifications. Users only need to add their website to ServBay. Caddy's configuration file syntax is simple and easy to read. ServBay has already configured the Rewrite rules and PHP processing by default, so users usually do not need additional configuration. This article guides you through the process of migrating Laravel and WordPress websites to ServBay.

Sentry blog image

How to reduce TTFB

In the past few years in the web dev world, we’ve seen a significant push towards rendering our websites on the server. Doing so is better for SEO and performs better on low-powered devices, but one thing we had to sacrifice is TTFB.

In this article, we’ll see how we can identify what makes our TTFB high so we can fix it.

Read more

Top comments (0)

Billboard image

Create up to 10 Postgres Databases on Neon's free plan.

If you're starting a new project, Neon has got your databases covered. No credit cards. No trials. No getting in your way.

Try Neon for Free →

👋 Kindness is contagious

Please leave a ❤️ or a friendly comment on this post if you found it helpful!

Okay