Rumah Operasi dan penyelenggaraan Nginx Cara menggunakan Nginx untuk melaksanakan kluster web yang sangat tersedia

Cara menggunakan Nginx untuk melaksanakan kluster web yang sangat tersedia

Aug 03, 2023 pm 12:07 PM
nginx Ketersediaan tinggi kelompok web

Cara menggunakan Nginx untuk melaksanakan kluster web yang sangat tersedia

Pengenalan:
Dalam aplikasi Internet moden, ketersediaan yang tinggi adalah pertimbangan yang sangat penting. Untuk memastikan kestabilan dan kebolehpercayaan aplikasi di bawah trafik tinggi, selalunya perlu untuk membina kelompok web yang sangat tersedia. Antaranya, Nginx ialah pelayan proksi terbalik yang sangat popular, yang boleh mencapai pengimbangan beban dan ketersediaan tinggi melalui beberapa konfigurasi mudah. Artikel ini akan memperkenalkan cara menggunakan Nginx untuk membina kluster web yang sangat tersedia dan memberikan contoh kod.

1. Pasang dan konfigurasikan Nginx
Pertama, kita perlu memasang dan mengkonfigurasi Nginx pada setiap pelayan web.

  1. Pasang Nginx:
    Dalam sistem Ubuntu, anda boleh memasang Nginx melalui arahan berikut:

    $ sudo apt-get update
    $ sudo apt-get install nginx
    Salin selepas log masuk
  2. Konfigurasi Nginx:
    Buka fail konfigurasi Nginx nginx.conf, laluan lalai ialah /etc/nginx/nginx.conf, gunakan editor teks untuk mengeditnya. nginx.conf,默认路径是 /etc/nginx/nginx.conf,使用文本编辑器进行编辑。
    以下是一个简单的示例配置:

    http {
     upstream backend {
         server backend1.example.com;
         server backend2.example.com;
         server backend3.example.com;
     }
      
     server {
         listen 80;
         
         location / {
             proxy_pass http://backend;
             proxy_redirect off;
         
             proxy_set_header Host $host;
             proxy_set_header X-Real-IP $remote_addr;
             proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
         }
     }
    }
    Salin selepas log masuk

    其中,

  3. upstream 块定义了一组负载均衡后端服务器;
  4. server 块定义了监听的端口和访问配置。

保存并退出配置文件,然后重启 Nginx 服务以使配置生效:

$ sudo systemctl restart nginx
Salin selepas log masuk

二、配置负载均衡策略
为了实现负载均衡,可以在 Nginx 配置文件中定义不同的负载均衡策略。以下是一些常用的负载均衡策略。

  1. 轮询(Round-Robin)策略:
    该策略按照后端服务器的顺序依次分配请求。

    upstream backend {
     server backend1.example.com;
     server backend2.example.com;
     server backend3.example.com;
    }
    Salin selepas log masuk
  2. IP 哈希(IP Hash)策略:
    该策略通过对客户端 IP 地址进行哈希计算,将同一个客户端的请求发送到同一台后端服务器上。

    upstream backend {
     ip_hash;
     server backend1.example.com;
     server backend2.example.com;
     server backend3.example.com;
    }
    Salin selepas log masuk
  3. 加权轮询(Weighted Round-Robin)策略:
    该策略根据后端服务器的权重大小进行请求分配。

    upstream backend {
     server backend1.example.com weight=3;
     server backend2.example.com weight=2;
     server backend3.example.com weight=1;
    }
    Salin selepas log masuk

三、配置健康检查和容错
为了实现高可用性,我们需要对后端服务器进行健康检查,并在服务器不可用时进行容错处理。

  1. 健康检查:
    可以通过 nginx_http_healthcheck_modulenginx-stream-healthcheck-module 模块实现 Nginx 对后端服务器的健康检查。
  2. 容错处理:
    当某台后端服务器不可用时,Nginx 可以将请求发送至其他可用服务器,以实现容错。以下是一个简单的容错配置示例:

    http {
     upstream backend {
         server backend1.example.com;
         server backend2.example.com backup;
         server backend3.example.com;
     }
      
     server {
         listen 80;
         ...
     }
    }
    Salin selepas log masuk

以上配置中,backup 参数指定了备用服务器,当主服务器不可用时,请求会转发到备用服务器。

四、代码示例
以下是一个简单的基于 Node.js 的 Web 服务器示例,用于演示 Nginx 的负载均衡功能。

  1. server.js:

    const http = require('http');
    
    const server = http.createServer((req, res) => {
     res.statusCode = 200;
     res.setHeader('Content-Type', 'text/plain');
     res.end('Hello, World!');
    });
    
    server.listen(3000, 'localhost', () => {
     console.log('Server running at http://localhost:3000/');
    });
    Salin selepas log masuk
  2. 启动 3 个服务器:

    $ node server.js
    $ node server.js
    $ node server.js
    Salin selepas log masuk
  3. Nginx 配置文件(参考之前的示例)。

通过以上配置,我们可以在浏览器中访问 http://localhostBerikut ialah konfigurasi contoh mudah:

rrreee

Antaranya, blok

🎜hulu mentakrifkan satu set pelayan bahagian belakang pengimbangan beban 🎜🎜pelayan mentakrifkan mendengar Port dan konfigurasi capaian. 🎜🎜Simpan dan keluar dari fail konfigurasi, kemudian mulakan semula perkhidmatan Nginx untuk menjadikan konfigurasi berkuat kuasa: 🎜rrreee🎜 2. Konfigurasikan strategi pengimbangan beban 🎜Untuk mencapai pengimbangan beban, anda boleh menentukan pengimbangan beban yang berbeza strategi dalam fail konfigurasi Nginx. Berikut ialah beberapa strategi pengimbangan beban yang biasa digunakan. 🎜🎜🎜🎜Strategi Round-Robin: 🎜Strategi ini memperuntukkan permintaan secara berurutan dalam susunan pelayan bahagian belakang. 🎜rrreee🎜🎜🎜Strategi Cincang IP: 🎜Strategi ini menghantar permintaan daripada pelanggan yang sama ke pelayan bahagian belakang yang sama dengan mencincang alamat IP pelanggan. 🎜rrreee🎜🎜🎜Strategi Round-Robin Berwajaran: 🎜Strategi ini memperuntukkan permintaan berdasarkan berat pelayan bahagian belakang. 🎜rrreee🎜🎜3. Konfigurasikan pemeriksaan kesihatan dan toleransi kesalahan🎜Untuk mencapai ketersediaan yang tinggi, kami perlu melakukan pemeriksaan kesihatan pada pelayan bahagian belakang dan melakukan toleransi kesalahan apabila pelayan tidak tersedia. 🎜🎜🎜Pemeriksaan kesihatan: 🎜Anda boleh melaksanakan pemeriksaan kesihatan Nginx pada pelayan bahagian belakang melalui modul nginx_http_healthcheck_module atau nginx-stream-healthcheck-module. 🎜🎜🎜Pemprosesan toleransi kesalahan: 🎜Apabila pelayan bahagian belakang tidak tersedia, Nginx boleh menghantar permintaan kepada pelayan lain yang tersedia untuk mencapai toleransi kesalahan. Berikut ialah contoh konfigurasi toleransi kesalahan yang mudah: 🎜rrreee🎜🎜Dalam konfigurasi di atas, parameter sandaran menentukan pelayan sandaran Apabila pelayan utama tidak tersedia, permintaan akan dimajukan ke pelayan sandaran. 🎜🎜4. Contoh Kod🎜Berikut ialah contoh pelayan web berasaskan Node.js yang ringkas untuk menunjukkan fungsi pengimbangan beban Nginx. 🎜🎜🎜🎜server.js: 🎜rrreee🎜🎜🎜Mulakan 3 pelayan: 🎜rrreee🎜🎜Fail konfigurasi Nginx (rujuk contoh sebelumnya). 🎜🎜Dengan konfigurasi di atas, kami boleh mengakses http://localhost dalam penyemak imbas dan memerhatikan bahawa permintaan diedarkan kepada pelayan bahagian belakang yang berbeza setiap kali halaman dimuat semula. 🎜🎜Kesimpulan:🎜Artikel ini memperkenalkan cara menggunakan Nginx untuk membina kluster web yang sangat tersedia, dan menyediakan contoh pemasangan, konfigurasi dan kod. Dengan mengkonfigurasi strategi pengimbangan beban dengan betul, pemeriksaan kesihatan dan toleransi kesalahan, kestabilan dan kebolehpercayaan kelompok web di bawah trafik tinggi dapat dipastikan. Saya harap artikel ini berguna kepada anda, terima kasih kerana membaca! 🎜

Atas ialah kandungan terperinci Cara menggunakan Nginx untuk melaksanakan kluster web yang sangat tersedia. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Cara memeriksa nama bekas Docker Cara memeriksa nama bekas Docker Apr 15, 2025 pm 12:21 PM

Anda boleh menanyakan nama kontena Docker dengan mengikuti langkah -langkah: Senaraikan semua bekas (Docker PS). Tapis senarai kontena (menggunakan arahan grep). Mendapat nama kontena (terletak di lajur "Nama").

Cara mengkonfigurasi nama domain pelayan awan di nginx Cara mengkonfigurasi nama domain pelayan awan di nginx Apr 14, 2025 pm 12:18 PM

Cara mengkonfigurasi nama domain Nginx pada pelayan awan: Buat rekod yang menunjuk ke alamat IP awam pelayan awan. Tambah blok hos maya dalam fail konfigurasi Nginx, menyatakan port pendengaran, nama domain, dan direktori akar laman web. Mulakan semula nginx untuk memohon perubahan. Akses konfigurasi ujian nama domain. Nota Lain: Pasang sijil SSL untuk membolehkan HTTPS, pastikan firewall membenarkan trafik port 80, dan tunggu resolusi DNS berkuatkuasa.

Cara memeriksa versi nginx Cara memeriksa versi nginx Apr 14, 2025 am 11:57 AM

Kaedah yang boleh menanyakan versi nginx adalah: gunakan perintah nginx -v; Lihat arahan versi dalam fail nginx.conf; Buka halaman ralat Nginx dan lihat tajuk halaman.

Cara Mengkonfigurasi Nginx di Windows Cara Mengkonfigurasi Nginx di Windows Apr 14, 2025 pm 12:57 PM

Bagaimana cara mengkonfigurasi nginx di Windows? Pasang Nginx dan buat konfigurasi hos maya. Ubah suai fail konfigurasi utama dan sertakan konfigurasi hos maya. Mulakan atau Muat semula Nginx. Uji konfigurasi dan lihat laman web. Selektif membolehkan SSL dan mengkonfigurasi sijil SSL. Selektif tetapkan firewall untuk membolehkan trafik port 80 dan 443.

Cara memulakan pelayan nginx Cara memulakan pelayan nginx Apr 14, 2025 pm 12:27 PM

Memulakan pelayan Nginx memerlukan langkah-langkah yang berbeza mengikut sistem operasi yang berbeza: Sistem Linux/Unix: Pasang pakej Nginx (contohnya, menggunakan apt-get atau yum). Gunakan SystemCTL untuk memulakan perkhidmatan Nginx (contohnya, SUDO SystemCTL Mula Nginx). Sistem Windows: Muat turun dan pasang fail binari Windows. Mula Nginx menggunakan nginx.exe executable (contohnya, nginx.exe -c conf \ nginx.conf). Tidak kira sistem operasi yang anda gunakan, anda boleh mengakses IP pelayan

Cara membuat bekas untuk Docker Cara membuat bekas untuk Docker Apr 15, 2025 pm 12:18 PM

Buat bekas di Docker: 1. Tarik Imej: Docker Pull [Nama Cermin] 2. Buat bekas: Docker Run [Options] [Mirror Name] [Command] 3. Mulailah bekas: Docker Start [Nama Container]

Cara memeriksa sama ada nginx dimulakan Cara memeriksa sama ada nginx dimulakan Apr 14, 2025 pm 01:03 PM

Bagaimana untuk mengesahkan sama ada nginx dimulakan: 1. Gunakan baris arahan: status sistem sistem nginx (linux/unix), netstat -ano | Findstr 80 (Windows); 2. Periksa sama ada port 80 dibuka; 3. Semak mesej permulaan Nginx dalam log sistem; 4. Gunakan alat pihak ketiga, seperti Nagios, Zabbix, dan Icinga.

Cara Memulakan Bekas oleh Docker Cara Memulakan Bekas oleh Docker Apr 15, 2025 pm 12:27 PM

Docker Container Startup Langkah: Tarik Imej Bekas: Run "Docker Pull [Mirror Name]". Buat bekas: Gunakan "Docker Buat [Pilihan] [Nama Mirror] [Perintah dan Parameter]". Mulakan bekas: Jalankan "Docker Start [Nama Container atau ID]". Semak Status Kontena: Sahkan bahawa bekas sedang berjalan dengan "Docker PS".

See all articles