Server Blocks Nginx memungkinkan Anda untuk menjalankan lebih dari satu situs web pada satu server. Dengan Server Blocks, Anda dapat menentukan root dokumen situs (direktori yang berisi file situs web), membuat kebijakan keamanan terpisah untuk setiap situs, menggunakan sertifikat SSL berbeda untuk setiap situs dan banyak lagi.

Dalam tutorial ini, kami akan memberikan panduan langkah demi langkah tentang cara menyiapkan server blocks Nginx (mirip dengan Apache Virtual Hosts) di  CentOS 7.

Kami sarankan Anda untuk menguji setiap tutorial atau panduan yang ada di Internet di virtual machine (vmware atau virtualbox) sebelum menerapkan ke server produksi, agar tidak mengacaukan sistem yang berjalan ketika ada kesalahan.

Prasyarat

Pastikan Anda telah memenuhi prasyarat berikut sebelum melanjutkan dengan tutorial ini:

Dalam beberapa dokumentasi, Anda akan melihat Server Blocks dirujuk sebagai Virtual host. Virtual host adalah istilah Apache.

Membuat Struktur Direktori

Root dokumen adalah direktori tempat file situs web untuk nama domain disimpan dan disajikan sebagai respons terhadap permintaan. Kita dapat mengatur root dokumen ke lokasi mana pun yang kita inginkan tetapi dalam panduan ini kita akan menggunakan struktur direktori berikut:

/var/www/
├── example.com
│   └── public_html
├── example2.com
│   └── public_html
├── example3.com
│   └── public_html

Pada dasarnya kita akan membuat direktori terpisah untuk setiap domain yang ingin kita host di dalam direktori /var/www. Dalam direktori ini, kita akan membuat direktori public_html yang akan menjadi direktori root dokumen domain dan yang akan menyimpan file situs web domain.

Mari kita mulai dengan membuat direktori root untuk domain kami example.com:

sudo mkdir -p /var/www/example.com/public_html

Untuk tujuan pengujian, kita akan membuat file index.html di dalam direktori root dokumen domain.

Buka text editor Anda dan buat file demo index.html:

sudo nano /var/www/example.com/public_html/index.html

Copy dan paste kode berikut ke dalam file :

<!DOCTYPE html>
<html lang="en" dir="ltr">
  <head>
    <meta charset="utf-8">
    <title>Selamat Datang di Server CentOS</title>
  </head>
  <body>
    <h1>Sukses, Server CentOS Online!</h1>
  </body>
</html>

Dalam panduan ini, kita menjalankan perintah sebagai user sudo dan file serta direktori yang baru dibuat dimiliki oleh user root.

Untuk menghindari masalah izin, kita dapat mengubah kepemilikan direktori root dokumen domain menjadi user Nginx (nginx):

sudo chown -R nginx: /var/www/example.com

Membuat Server Block

File konfigurasi server block nginx harus diakhiri dengan .conf dan disimpan di direktori /etc/nginx/conf.d.

Buka editor pilihan Anda dan buat file konfigurasi server block untuk example.com

sudo nano /etc/nginx/conf.d/example.com.conf

Anda dapat memberi nama file konfigurasi sesuka Anda, tetapi disarankan untuk menggunakan nama domain.

Salin dan tempel kode berikut ke dalam file:

server {
    listen 80;
    listen [::]:80;

    root /var/www/example.com/public_html;

    index index.html;

    server_name example.com www.example.com;

    access_log /var/log/nginx/example.com.access.log;
    error_log /var/log/nginx/example.com.error.log;

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

Simpan file dan uji konfigurasi Nginx untuk sintaks yang benar:

sudo nginx -t

Jika tidak ada kesalahan, hasilnya akan terlihat seperti ini

nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful

Restart layanan Nginx agar perubahan diterapkan:

sudo systemctl restart nginx

Terakhir untuk memverifikasi server block berfungsi seperti yang diharapkan, buka http://example.com di browser pilihan Anda, dan Anda akan melihat tampilan seperti berikut :

Server CentOS

Kesimpulan

Anda telah belajar cara membuat konfigurasi server block di Nginx untuk meng-host beberapa domain pada satu server CentOS. Anda dapat mengulangi langkah-langkah yang kami uraikan di atas dan membuat server block tambahan untuk semua domain Anda.

Jika Anda ingin mengamankan situs web Anda dengan sertifikat SSL gratis Let’s Encrypt , Anda dapat memeriksa panduan berikut: Amankan Nginx dengan Let’s Encrypt di CentOS 7