Rumah  >  Artikel  >  Operasi dan penyelenggaraan  >  Analisis contoh fail konfigurasi Nginx

Analisis contoh fail konfigurasi Nginx

PHPz
PHPzke hadapan
2023-05-17 19:25:04887semak imbas

fungsi biasa nginx

1 proksi http, proksi terbalik: Sebagai salah satu fungsi pelayan web yang paling biasa digunakan, terutamanya proksi terbalik.

Di sini saya akan memberikan anda dua gambar untuk menerangkan agen positif dan agen reaktif Anda boleh membaca maklumat untuk butiran khusus.

Analisis contoh fail konfigurasi Nginx

nginx menyediakan prestasi yang stabil apabila digunakan sebagai proksi terbalik, dan boleh menyediakan fungsi pemajuan dengan konfigurasi yang fleksibel. nginx boleh menggunakan strategi pemajuan yang berbeza berdasarkan padanan biasa yang berbeza, seperti pergi ke pelayan fail pada akhir fail imej, dan pergi ke pelayan web untuk halaman dinamik selagi anda tidak mempunyai masalah menulis peraturan biasa dan mempunyai yang sepadan penyelesaian pelayan, anda boleh melakukan apa sahaja yang anda mahukan. Dan nginx melakukan lompatan halaman ralat, pertimbangan pengecualian, dll. pada hasil yang dikembalikan. Jika pelayan yang diedarkan tidak normal, dia boleh memajukan semula permintaan ke pelayan lain dan kemudian mengalih keluar pelayan yang tidak normal secara automatik.

2. Pengimbangan beban

nginx menyediakan dua jenis strategi pengimbangan beban: strategi terbina dalam dan strategi lanjutan. Strategi terbina dalam ialah tinjauan pendapat, tinjauan wajaran dan cincangan ip. Strategi pengembangan adalah imaginatif kerana ia tidak dapat dibayangkan. Tiada apa yang anda tidak boleh fikirkan yang tidak boleh dilakukan. Anda boleh merujuk kepada semua algoritma pengimbangan beban untuk mencarinya satu demi satu dan melaksanakannya.

Tiga gambar di atas, fahami pelaksanaan ketiga-tiga algoritma pengimbangan beban ini

Analisis contoh fail konfigurasi Nginx

algoritma cincang ip, lakukan operasi cincang pada IP yang diminta oleh pelanggan , dan kemudian Mengagihkan permintaan daripada IP klien yang sama ke pelayan yang sama untuk pemprosesan berdasarkan hasil cincang boleh menyelesaikan masalah sesi tidak dikongsi.

Analisis contoh fail konfigurasi Nginx

3. Cache web

nginx boleh melakukan pemprosesan cache yang berbeza untuk fail yang berbeza, dengan konfigurasi fleksibel dan menyokong fastcgi_cache, yang digunakan terutamanya untuk fastcgi Dynamic program dicache. Bekerjasama dengan ngx_cache_purge pihak ketiga, kandungan cache URL yang ditentukan boleh ditambah dan dipadamkan untuk diurus.

4. alamat berkaitan nginx

Kod sumber:

Tapak web rasmi:

struktur fail konfigurasi nginx

Jika Sekarang anda telah memuat turun fail pemasangan anda, anda juga boleh membuka fail nginx.conf dalam folder conf Konfigurasi asas pelayan nginx dan konfigurasi lalai juga disimpan di sini.

Dalam bit simbol ulasan nginx.conf #

Struktur fail nginx, pelajar yang baru bermula boleh melihat ini kali kedua.

Konfigurasi lalai

#user nobody;
worker_processes 1;
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid    logs/nginx.pid;
events {
  worker_connections 1024;
}
http {
  include    mime.types;
  default_type application/octet-stream;
  #log_format main '$remote_addr - $remote_user [$time_local] "$request" '
  #         '$status $body_bytes_sent "$http_referer" '
  #         '"$http_user_agent" "$http_x_forwarded_for"';
  #access_log logs/access.log main;
  sendfile    on;
  #tcp_nopush   on;
  #keepalive_timeout 0;
  keepalive_timeout 65;
  #gzip on;
  server {
    listen    80;
    server_name localhost;
    #charset koi8-r;
    #access_log logs/host.access.log main;
    location / {
      root  html;
      index index.html index.htm;
    }
    #error_page 404       /404.html;
    # redirect server error pages to the static page /50x.html
    #
    error_page  500 502 503 504 /50x.html;
    location = /50x.html {
      root  html;
    }
    # proxy the php scripts to apache listening on 127.0.0.1:80
    #
    #location ~ \.php$ {
    #  proxy_pass  http://127.0.0.1;
    #}
    # pass the php scripts to fastcgi server listening on 127.0.0.1:9000
    #
    #location ~ \.php$ {
    #  root      html;
    #  fastcgi_pass  127.0.0.1:9000;
    #  fastcgi_index index.php;
    #  fastcgi_param script_filename /scripts$fastcgi_script_name;
    #  include    fastcgi_params;
    #}
    # deny access to .htaccess files, if apache's document root
    # concurs with nginx's one
    #
    #location ~ /\.ht {
    #  deny all;
    #}
  }
  # another virtual host using mix of ip-, name-, and port-based configuration
  #
  #server {
  #  listen    8000;
  #  listen    somename:8080;
  #  server_name somename alias another.alias;
  #  location / {
  #    root  html;
  #    index index.html index.htm;
  #  }
  #}
  # https server
  #
  #server {
  #  listen    443 ssl;
  #  server_name localhost;
  #  ssl_certificate   cert.pem;
  #  ssl_certificate_key cert.key;
  #  ssl_session_cache  shared:ssl:1m;
  #  ssl_session_timeout 5m;
  #  ssl_ciphers high:!anull:!md5;
  #  ssl_prefer_server_ciphers on;
  #  location / {
  #    root  html;
  #    index index.html index.htm;
  #  }
  #}
}

struktur fail nginx

...       #全局块
events {     #events块
  ...
}
http   #http块
{
  ...  #http全局块
  server    #server块
  { 
    ...    #server全局块
    location [pattern]  #location块
    {
      ...
    }
    location [pattern] 
    {
      ...
    }
  }
  server
  {
   ...
  }
  ...   #http全局块
}

1. Secara amnya, terdapat kumpulan pengguna untuk menjalankan pelayan nginx, laluan penyimpanan pid proses nginx, laluan storan log, pengenalan fail konfigurasi, bilangan proses pekerja yang dibenarkan untuk dihasilkan, dsb.

2. Blok acara: Konfigurasi mempengaruhi pelayan nginx atau sambungan rangkaian dengan pengguna. Terdapat bilangan maksimum sambungan bagi setiap proses, yang model dipacu peristiwa untuk dipilih untuk mengendalikan permintaan sambungan, sama ada membenarkan berbilang sambungan rangkaian diterima pada masa yang sama, membolehkan bersiri berbilang sambungan rangkaian, dsb.

3. Blok http: Anda boleh menyusun berbilang pelayan, mengkonfigurasi proksi, cache, definisi log dan kebanyakan fungsi lain dan mengkonfigurasi modul pihak ketiga. Seperti pengenalan fail, definisi jenis mime, penyesuaian log, sama ada menggunakan fail hantar untuk memindahkan fail, tamat masa sambungan, bilangan permintaan sambungan tunggal, dsb.

4. Sekatan pelayan: Konfigurasikan parameter yang berkaitan bagi hos maya.

5. Blok lokasi: Konfigurasikan penghalaan permintaan dan pemprosesan pelbagai halaman.

Berikut ialah fail konfigurasi untuk anda fahami, dan ia juga dipasang ke dalam mesin ujian yang saya bina untuk memberi anda contoh.

########### 每个指令必须有分号结束。#################
#user administrator administrators; #配置用户或者组,默认为nobody nobody。
#worker_processes 2; #允许生成的进程数,默认为1
#pid /nginx/pid/nginx.pid;  #指定nginx进程运行文件存放地址
error_log log/error.log debug; #制定日志路径,级别。这个设置可以放入全局块,http块,server块,级别以此为:debug|info|notice|warn|error|crit|alert|emerg
events {
  accept_mutex on;  #设置网路连接序列化,防止惊群现象发生,默认为on
  multi_accept on; #设置一个进程是否同时接受多个网络连接,默认为off
  #use epoll;   #事件驱动模型,select|poll|kqueue|epoll|resig|/dev/poll|eventport
  worker_connections 1024;  #最大连接数,默认为512
}
http {
  include    mime.types;  #文件扩展名与文件类型映射表
  default_type application/octet-stream; #默认文件类型,默认为text/plain
  #access_log off; #取消服务日志  
  log_format myformat '$remote_addr–$remote_user [$time_local] $request $status $body_bytes_sent $http_referer $http_user_agent $http_x_forwarded_for'; #自定义格式
  access_log log/access.log myformat; #combined为日志格式的默认值
  sendfile on;  #允许sendfile方式传输文件,默认为off,可以在http块,server块,location块。
  sendfile_max_chunk 100k; #每个进程每次调用传输数量不能大于设定的值,默认为0,即不设上限。
  keepalive_timeout 65; #连接超时时间,默认为75s,可以在http,server,location块。

  upstream mysvr {  
   server 127.0.0.1:7878;
   server 192.168.10.121:3333 backup; #热备
  }
  error_page 404 https://www.baidu.com; #错误页
  server {
    keepalive_requests 120; #单连接请求上限次数。
    listen    4545;  #监听端口
    server_name 127.0.0.1;  #监听地址    
    location ~*^.+$ {    #请求的url过滤,正则匹配,~为区分大小写,~*为不区分大小写。
      #root path; #根目录
      #index vv.txt; #设置默认页
      proxy_pass http://mysvr; #请求转向mysvr 定义的服务器列表
      deny 127.0.0.1; #拒绝的ip
      allow 172.18.5.54; #允许的ip      
    } 
  }
}

Di atas adalah konfigurasi asas nginx Anda perlu memberi perhatian kepada perkara berikut:

1. $remote_addr dan $http_x_forwarded_for sudah biasa merekodkan alamat IP pelanggan ; 🎜>

5. $status: Digunakan untuk merekod status permintaan ialah 200, 6.$body_bytes_s ent: Rekod saiz kandungan fail yang dihantar kepada klien 7.$http_referer: Digunakan untuk merekod pautan halaman diakses daripada; 8.$http_user_agent: Rekod maklumat berkaitan pelayar klien

2. Fenomena gerombolan gemuruh: apabila sambungan rangkaian tiba, beberapa proses tidur dibangkitkan oleh rakan sekerja, tetapi hanya satu proses boleh mendapatkan pautan, yang akan menjejaskan prestasi sistem .

3. Setiap arahan mesti diakhiri dengan koma bertitik.

Atas ialah kandungan terperinci Analisis contoh fail konfigurasi Nginx. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:yisu.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam