Rumah > Artikel > Operasi dan penyelenggaraan > Analisis contoh fungsi asas Nginx
1. Pelayan http statik
Pertama sekali, nginx ialah pelayan http yang boleh memaparkan fail statik (seperti html dan gambar) pada pelayan kepada klien melalui http protokol. Konfigurasi:
server { listen 80; # 端口号 location / { root /usr/share/nginx/html; # 静态文件路径 } }
2. Pelayan proksi terbalik
Apakah proksi terbalik?
Klien boleh terus mengakses pelayan aplikasi laman web melalui protokol http Pentadbir laman web boleh menambah nginx di tengah-tengah Pelanggan meminta nginx, nginx meminta pelayan aplikasi, dan kemudian mengembalikan hasilnya kepada klien. Nginx ini ialah pelayan proksi terbalik.
Konfigurasi:
server { listen 80; location / { proxy_pass http://192.168.20.1:8080; # 应用服务器http地址 } }
Memandangkan pelayan boleh diakses melalui http secara langsung, mengapa menambah proksi terbalik di tengah bukan? Apakah yang dilakukan oleh proksi terbalik?
Terus melihat ke bawah, pengimbangan beban berikut, hos maya, dsb. semuanya berdasarkan proksi terbalik Sudah tentu, fungsi proksi terbalik bukan sahaja ini.
3. Load Balancing
Apabila trafik laman web sangat besar, webmaster senang untuk membuat wang, tetapi pada masa yang sama dia juga menghadapi masalah. Kerana laman web semakin perlahan dan perlahan, satu pelayan tidak lagi mencukupi.
Jadi aplikasi yang sama digunakan pada berbilang pelayan dan permintaan daripada sebilangan besar pengguna diedarkan kepada berbilang mesin untuk diproses. Pada masa yang sama, faedahnya ialah jika salah satu pelayan ranap, selagi pelayan lain berjalan seperti biasa, ia tidak akan menjejaskan penggunaan pengguna. nginx boleh mencapai pengimbangan beban melalui proksi terbalik.
Konfigurasi:
upstream myapp { server 192.168.20.1:8080; # 应用服务器1 server 192.168.20.2:8080; # 应用服务器2 } server { listen 80; location / { proxy_pass http://myapp; } }
Konfigurasi di atas akan memperuntukkan undian permintaan kepada pelayan aplikasi, iaitu, berbilang permintaan daripada satu pelanggan mungkin diproses oleh berbilang yang diproses oleh pelayan yang berbeza. Anda boleh menggunakan ip-hash untuk menetapkan permintaan kepada pelayan tetap untuk pemprosesan berdasarkan nilai cincang alamat IP pelanggan.
Konfigurasi:
upstream myapp { ip_hash; # 根据客户端ip地址hash值将请求分配给固定的一个服务器处理 server 192.168.20.1:8080; server 192.168.20.2:8080; } server { listen 80; location / { proxy_pass http://myapp; } }
Selain itu, konfigurasi perkakasan pelayan mungkin baik atau buruk Jika anda ingin memperuntukkan kebanyakan permintaan kepada pelayan yang baik dan sebilangan kecil permintaan kepada pelayan yang lemah, anda boleh menggunakan berat badan untuk mengawal.
Konfigurasi:
upstream myapp { server 192.168.20.1:8080 weight=3; # 该服务器处理3/4请求 server 192.168.20.2:8080; # weight默认为1,该服务器处理1/4请求 } server { listen 80; location / { proxy_pass http://myapp; } }
4. Hos maya
Sesetengah tapak web mempunyai jumlah lawatan yang banyak dan memerlukan pengimbangan beban. Walau bagaimanapun, tidak semua tapak web sangat baik Sesetengah tapak web perlu menjimatkan kos dengan menggunakan berbilang tapak web pada pelayan yang sama kerana bilangan lawatan adalah terlalu kecil.
Contohnya, jika dua tapak web www.aaa.com dan www.bbb.com digunakan pada pelayan yang sama, kedua-dua nama domain itu diselesaikan ke alamat IP yang sama, tetapi pengguna boleh membuka kedua-duanya melalui kedua-dua nama domain. Laman web yang sama sekali berbeza tidak menjejaskan satu sama lain, sama seperti mengakses dua pelayan, jadi mereka dipanggil dua hos maya.
Konfigurasi:
server { listen 80 default_server; server_name _; return 444; # 过滤其他域名的请求,返回444状态码 } server { listen 80; server_name www.aaa.com; # www.aaa.com域名 location / { proxy_pass http://localhost:8080; # 对应端口号8080 } } server { listen 80; server_name www.bbb.com; # www.bbb.com域名 location / { proxy_pass http://localhost:8081; # 对应端口号8081 } }
Membuka aplikasi pada pelayan 8080 dan 8081 masing-masing Pelanggan mengakses melalui nama domain yang berbeza Menurut nama_server, ia boleh membalikkan proksi ke pelayan aplikasi yang sepadan.
Prinsip hos maya direalisasikan dengan sama ada hos dalam pengepala permintaan http sepadan dengan nama_server Pelajar yang berminat boleh mempelajari protokol http.
Selain itu, konfigurasi nama_server juga boleh menapis orang yang secara berniat jahat menunjukkan nama domain tertentu ke pelayan hos anda.
5. fastcgi
nginx sendiri tidak menyokong bahasaseperti php, tetapi ia boleh menghantar permintaan ke bahasa atau rangka kerja tertentu melalui fastcgi (seperti php, python, perl).
server { listen 80; location ~ \.php$ { include fastcgi_params; fastcgi_param script_filename /php文件路径$fastcgi_script_name; # php文件路径 fastcgi_pass 127.0.0.1:9000; # php-fpm地址和端口号 # 另一种方式:fastcgi_pass unix:/var/run/php5-fpm.sock; } }
Dalam konfigurasi, permintaan yang berakhir dengan .php diserahkan kepada php-fpm untuk diproses melalui fashcgi php-fpm ialah pengurus fastcgi untuk PHP. Anda boleh menyemak maklumat lain tentang fashcgi, yang tidak akan diperkenalkan dalam artikel ini.
Apakah perbezaan antara fastcgi_pass dan proxy_pass? Gambar di bawah akan membantu anda memahami:
Atas ialah kandungan terperinci Analisis contoh fungsi asas Nginx. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!