cari
Rumahhujung hadapan webtutorial jsMenskalakan Aplikasi Node.js dengan NGINX dan Pengimbangan Beban

Scaling Node.js Applications with NGINX and Load Balancing

Apabila aplikasi Node.js anda berkembang dan menerima lebih banyak trafik, penskalaan menjadi penting untuk mengekalkan prestasi dan kestabilan. Dalam artikel ini, kami akan menyelami teknik dan alatan utama yang membantu menskalakan aplikasi Node.js anda, memfokuskan pada NGINX sebagai proksi terbalik dan pengimbang beban, serta kaedah lain untuk mengendalikan trafik dan permintaan yang tinggi.

Dalam artikel ini, kami akan membincangkan:

  1. Apakah NGINX dan mengapa ia penting?
  2. Menyediakan NGINX sebagai proksi terbalik untuk Node.js.
  3. Imbangan beban dengan NGINX.
  4. Caching kandungan statik dengan NGINX.
  5. Strategi penskalaan untuk aplikasi Node.js.
  6. Kes penggunaan dunia sebenar untuk penskalaan.

Apakah NGINX dan Mengapa Ia Penting?

NGINX ialah pelayan web berprestasi tinggi yang terkenal dengan keupayaannya sebagai proksi terbalik, pengimbang beban dan cache HTTP. Ia mengendalikan volum besar sambungan serentak dengan cekap, menjadikannya alat yang sangat baik untuk menskalakan aplikasi Node.js.

Ciri-ciri Utama NGINX:

  • Proksi Songsang: Ia mengarahkan permintaan pelanggan masuk ke pelayan akhir, membantu mengagihkan beban merentas berbilang pelayan.
  • Pengimbangan Beban: NGINX mengimbangi trafik masuk merentas berbilang kejadian pelayan, memastikan tiada pelayan tunggal yang terharu.
  • Caching: Ia menyimpan cache kandungan statik seperti imej, helaian gaya dan skrip, mengurangkan keperluan untuk menjana respons yang sama berulang kali.

Menyediakan NGINX sebagai Proksi Songsang untuk Node.js

Satu proksi terbalik mengarahkan permintaan pelanggan ke satu atau lebih pelayan bahagian belakang. Menggunakan NGINX sebagai proksi terbalik untuk aplikasi Node.js anda boleh memunggah tugas seperti penamatan SSL, caching dan pengimbangan beban daripada aplikasi anda.

Persediaan Langkah demi Langkah:

  1. Pasang NGINX:
    Mula-mula, pasang NGINX pada pelayan anda. Di Ubuntu, ini boleh dilakukan menggunakan:

    sudo apt update
    sudo apt install nginx
    
  2. Konfigurasikan NGINX:
    Cipta fail konfigurasi baharu untuk apl Node.js anda dalam direktori /etc/nginx/sites-available/.

Berikut ialah contoh fail konfigurasi:

   server {
       listen 80;
       server_name yourdomain.com;

       location / {
           proxy_pass http://localhost:3000; # Your Node.js app
           proxy_http_version 1.1;
           proxy_set_header Upgrade $http_upgrade;
           proxy_set_header Connection 'upgrade';
           proxy_set_header Host $host;
           proxy_cache_bypass $http_upgrade;
       }
   }
  1. Dayakan Konfigurasi:
    Buat pautan simbolik daripada tapak-tersedia kepada tapak-didayakan untuk mendayakan konfigurasi:

    sudo ln -s /etc/nginx/sites-available/yourdomain.com /etc/nginx/sites-enabled/
    
  2. Mulakan semula NGINX:
    Mulakan semula NGINX untuk menggunakan perubahan:

    sudo systemctl restart nginx
    

Kini, NGINX akan memajukan sebarang permintaan masuk ke aplikasi Node.js anda yang dijalankan pada port 3000. Persediaan proksi terbalik memastikan apl Node.js anda diasingkan daripada akses pelanggan langsung, menambahkan lapisan keselamatan.

Pengimbangan Beban dengan NGINX

Apabila trafik meningkat, satu contoh Node.js mungkin bergelut untuk mengendalikan semua permintaan masuk. Pengimbangan beban membolehkan trafik diagihkan secara sama rata merentas berbilang contoh aplikasi anda, meningkatkan kebolehpercayaan dan prestasi.

Persediaan Pengimbang Beban NGINX:

  1. Ubah suai Konfigurasi NGINX: Dalam fail konfigurasi NGINX, tentukan pelayan bahagian belakang yang NGINX akan mengimbangi permintaan merentas: ```nginx apl node huluan { pelayan localhost:3000; pelayan localhost:3001; pelayan localhost:3002; }

pelayan {
dengar 80;
server_name yourdomain.com;

   location / {
       proxy_pass http://node_app;
       proxy_http_version 1.1;
       proxy_set_header Upgrade $http_upgrade;
       proxy_set_header Connection 'upgrade';
       proxy_set_header Host $host;
       proxy_cache_bypass $http_upgrade;
   }

}

2. **Explanation**:
   - The `upstream` block defines a pool of Node.js servers running on different ports.
   - NGINX will distribute incoming requests evenly among these servers.

3. **Load Balancing Algorithms**:
   By default, NGINX uses a round-robin algorithm to balance traffic. You can specify other load balancing methods such as:
   - **Least Connections**: Sends requests to the server with the fewest active connections.
     ```nginx
     upstream node_app {
         least_conn;
         server localhost:3000;
         server localhost:3001;
     }
     ```

4. **Test and Scale**:
   You can now test the setup by running multiple instances of your Node.js app on different ports (3000, 3001, 3002, etc.) and monitor how NGINX balances the traffic.

## Caching Static Content with NGINX
Caching static content such as images, CSS, and JavaScript files can significantly reduce the load on your Node.js application by serving cached versions of these assets directly from NGINX.

### Caching Setup in NGINX:
1. **Modify Configuration for Caching**:
   Add caching rules to your server block:
   ```nginx
   server {
       listen 80;
       server_name yourdomain.com;

       location / {
           proxy_pass http://localhost:3000;
           proxy_set_header Host $host;
           proxy_cache_bypass $http_upgrade;
       }

       # Caching static content
       location ~* \.(jpg|jpeg|png|gif|ico|css|js)$ {
           expires 30d;
           add_header Cache-Control "public, no-transform";
       }
   }
  1. Penjelasan:
    • Tamat tempoh 30h; arahan memberitahu NGINX untuk cache fail statik selama 30 hari.
    • Ini meningkatkan dengan ketara masa tindak balas untuk aset ini kerana ia disampaikan terus daripada NGINX tanpa menyentuh aplikasi Node.js.

Strategi Penskalaan untuk Aplikasi Node.js

Menskalakan aplikasi Node.js bukan sekadar menggunakan NGINX. Di bawah ialah beberapa lagi teknik untuk memastikan aplikasi anda berskala dengan berkesan:

Penskalaan Menegak

Penskalaan menegak bermaksud menaik taraf sumber perkakasan pelayan, seperti menambah bilangan CPU atau menambah lebih banyak memori. Walaupun ini boleh meningkatkan prestasi dalam jangka pendek, ia terhad oleh keupayaan fizikal mesin.

Penskalaan Mendatar

Penskalaan mendatar melibatkan menjalankan berbilang kejadian aplikasi anda merentas pelayan yang berbeza dan mengimbangi trafik antaranya menggunakan alatan seperti NGINX atau pengimbang beban awan. Kaedah ini membenarkan penskalaan hampir tanpa had dengan menambahkan lebih banyak kejadian.

Clustering in Node.js

Node.js can run on multiple cores by using the built-in cluster module. This allows you to utilize all the available CPU cores on a server, increasing throughput.

Example:

const cluster = require('cluster');
const http = require('http');
const os = require('os');

if (cluster.isMaster) {
    const numCPUs = os.cpus().length;

    // Fork workers.
    for (let i = 0; i  {
        console.log(`Worker ${worker.process.pid} died`);
    });
} else {
    // Workers can share any TCP connection
    http.createServer((req, res) => {
        res.writeHead(200);
        res.end('Hello, world!\n');
    }).listen(8000);
}

This example shows how to use all CPU cores available on a machine by forking worker processes.

Real-World Use Case: Scaling an E-commerce Website

Problem: An e-commerce website is experiencing high traffic during sales events, leading to slow response times and occasional server crashes.

Solution:

  • Use NGINX to distribute traffic across multiple Node.js servers running different instances of the application.
  • Cache static assets like product images and JavaScript files with NGINX to reduce load on the server.
  • Implement Node.js Clustering to fully utilize the server’s CPU resources.

Outcome: The e-commerce website can now handle thousands of concurrent users without slowdowns, ensuring a smooth user experience during peak traffic times.

Why SSL, Encryption, and Security Matter?

When scaling applications, security should not be overlooked. Implementing SSL (Secure Sockets Layer) ensures that data transmitted between the client and server is encrypted and protected from attacks.

Steps to Enable SSL:

  1. Obtain an SSL Certificate from a trusted Certificate Authority (CA) like Let's Encrypt.
  2. Configure NGINX to use SSL:

    server {
       listen 443 ssl;
       server_name yourdomain.com;
    
       ssl_certificate /etc/ssl/certs/yourdomain.crt;
       ssl_certificate_key /etc/ssl/private/yourdomain.key;
    
       location / {
           proxy_pass http://localhost:3000;
       }
    }
    
  3. Redirect HTTP to HTTPS to ensure all traffic is secure:

    server {
       listen 80;
       server_name yourdomain.com;
       return 301 https://$host$request_uri;
    }
    

Conclusion

Scaling a Node.js application is essential as traffic and demand grow. By utilizing NGINX as a reverse proxy and load balancer, you can distribute traffic effectively, cache static assets, and ensure high availability. Combining these techniques with horizontal scaling and Node.js clustering enables your applications to handle massive traffic loads while maintaining performance and stability.

Implement these strategies in your projects to achieve better scalability, improved user experience, and increased uptime.

Atas ialah kandungan terperinci Menskalakan Aplikasi Node.js dengan NGINX dan Pengimbangan Beban. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
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
Peranan JavaScript: Membuat Web Interaktif dan DinamikPeranan JavaScript: Membuat Web Interaktif dan DinamikApr 24, 2025 am 12:12 AM

JavaScript adalah di tengah -tengah laman web moden kerana ia meningkatkan interaktiviti dan dinamik laman web. 1) Ia membolehkan untuk menukar kandungan tanpa menyegarkan halaman, 2) memanipulasi laman web melalui Domapi, 3) menyokong kesan interaktif kompleks seperti animasi dan drag-and-drop, 4) mengoptimumkan prestasi dan amalan terbaik untuk meningkatkan pengalaman pengguna.

C dan JavaScript: Sambungan dijelaskanC dan JavaScript: Sambungan dijelaskanApr 23, 2025 am 12:07 AM

C dan JavaScript mencapai interoperabilitas melalui webassembly. 1) Kod C disusun ke dalam modul WebAssembly dan diperkenalkan ke dalam persekitaran JavaScript untuk meningkatkan kuasa pengkomputeran. 2) Dalam pembangunan permainan, C mengendalikan enjin fizik dan rendering grafik, dan JavaScript bertanggungjawab untuk logik permainan dan antara muka pengguna.

Dari laman web ke aplikasi: Aplikasi pelbagai JavaScriptDari laman web ke aplikasi: Aplikasi pelbagai JavaScriptApr 22, 2025 am 12:02 AM

JavaScript digunakan secara meluas di laman web, aplikasi mudah alih, aplikasi desktop dan pengaturcaraan sisi pelayan. 1) Dalam pembangunan laman web, JavaScript mengendalikan DOM bersama -sama dengan HTML dan CSS untuk mencapai kesan dinamik dan menyokong rangka kerja seperti JQuery dan React. 2) Melalui reaktnatif dan ionik, JavaScript digunakan untuk membangunkan aplikasi mudah alih rentas platform. 3) Rangka kerja elektron membolehkan JavaScript membina aplikasi desktop. 4) Node.js membolehkan JavaScript berjalan di sisi pelayan dan menyokong permintaan serentak yang tinggi.

Python vs JavaScript: Gunakan Kes dan Aplikasi MembandingkanPython vs JavaScript: Gunakan Kes dan Aplikasi MembandingkanApr 21, 2025 am 12:01 AM

Python lebih sesuai untuk sains data dan automasi, manakala JavaScript lebih sesuai untuk pembangunan front-end dan penuh. 1. Python berfungsi dengan baik dalam sains data dan pembelajaran mesin, menggunakan perpustakaan seperti numpy dan panda untuk pemprosesan data dan pemodelan. 2. Python adalah ringkas dan cekap dalam automasi dan skrip. 3. JavaScript sangat diperlukan dalam pembangunan front-end dan digunakan untuk membina laman web dinamik dan aplikasi satu halaman. 4. JavaScript memainkan peranan dalam pembangunan back-end melalui Node.js dan menyokong pembangunan stack penuh.

Peranan C/C dalam JavaScript Jurubah dan PenyusunPeranan C/C dalam JavaScript Jurubah dan PenyusunApr 20, 2025 am 12:01 AM

C dan C memainkan peranan penting dalam enjin JavaScript, terutamanya digunakan untuk melaksanakan jurubahasa dan penyusun JIT. 1) C digunakan untuk menghuraikan kod sumber JavaScript dan menghasilkan pokok sintaks abstrak. 2) C bertanggungjawab untuk menjana dan melaksanakan bytecode. 3) C melaksanakan pengkompil JIT, mengoptimumkan dan menyusun kod hot-spot semasa runtime, dan dengan ketara meningkatkan kecekapan pelaksanaan JavaScript.

JavaScript in Action: Contoh dan projek dunia nyataJavaScript in Action: Contoh dan projek dunia nyataApr 19, 2025 am 12:13 AM

Aplikasi JavaScript di dunia nyata termasuk pembangunan depan dan back-end. 1) Memaparkan aplikasi front-end dengan membina aplikasi senarai TODO, yang melibatkan operasi DOM dan pemprosesan acara. 2) Membina Restfulapi melalui Node.js dan menyatakan untuk menunjukkan aplikasi back-end.

JavaScript dan Web: Fungsi teras dan kes penggunaanJavaScript dan Web: Fungsi teras dan kes penggunaanApr 18, 2025 am 12:19 AM

Penggunaan utama JavaScript dalam pembangunan web termasuk interaksi klien, pengesahan bentuk dan komunikasi tak segerak. 1) kemas kini kandungan dinamik dan interaksi pengguna melalui operasi DOM; 2) pengesahan pelanggan dijalankan sebelum pengguna mengemukakan data untuk meningkatkan pengalaman pengguna; 3) Komunikasi yang tidak bersesuaian dengan pelayan dicapai melalui teknologi Ajax.

Memahami Enjin JavaScript: Butiran PelaksanaanMemahami Enjin JavaScript: Butiran PelaksanaanApr 17, 2025 am 12:05 AM

Memahami bagaimana enjin JavaScript berfungsi secara dalaman adalah penting kepada pemaju kerana ia membantu menulis kod yang lebih cekap dan memahami kesesakan prestasi dan strategi pengoptimuman. 1) aliran kerja enjin termasuk tiga peringkat: parsing, penyusun dan pelaksanaan; 2) Semasa proses pelaksanaan, enjin akan melakukan pengoptimuman dinamik, seperti cache dalam talian dan kelas tersembunyi; 3) Amalan terbaik termasuk mengelakkan pembolehubah global, mengoptimumkan gelung, menggunakan const dan membiarkan, dan mengelakkan penggunaan penutupan yang berlebihan.

See all articles

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

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

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

Dreamweaver Mac版

Dreamweaver Mac版

Alat pembangunan web visual

MinGW - GNU Minimalis untuk Windows

MinGW - GNU Minimalis untuk Windows

Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.