Heim > Schlagzeilen > Hauptteil

PHP-Nginx-Optimierung mit hoher Parallelität und hohem Datenverkehr

无忌哥哥
Freigeben: 2018-06-27 14:53:24
Original
2404 Leute haben es durchsucht

Unsere Website kann derzeit Dutzende Millionen PVs und Millionen Parallelität verarbeiten. Ich habe ein wenig Erfahrung in der PHP+Nginx-Optimierung, also werde ich es aufschreiben, um einige Aufzeichnungen zu machen.

1.TCP-Sockets und Unix-Sockets

Unix-Sockets bieten eine bessere Leistung als TCP-Sockets (da weniger E/A-Daten gelesen und geschrieben werden und weniger Kontextwechsel stattfinden).

upstream backend 
{ 
  server unix:/var/run/fastcgi.sock; 
  # server 127.0.0.1:8080; 
}
Nach dem Login kopieren

2. Access_log deaktivieren oder optimieren

Bei Zugriffen mit großem Datenverkehr führt ein größerer Zugriff dazu, dass das Zugriffsprotokoll sehr große Datenträgermengen liest und schreibt. Wenn die Protokollierung nicht erforderlich ist, kann sie deaktiviert werden.

access_log off; 
log_not_found off;
Nach dem Login kopieren

oder schalten Sie die Pufferung ein

access_log /var/log/nginx/access.log main buffer=32k;
Nach dem Login kopieren

3. Schalten Sie Gzip ein

gzip on;
gzip_min_length 1k;
gzip_buffers 4 16k;
gzip_http_version 1.0;
gzip_comp_level 2;
gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;
gzip_vary on;
gzip_proxied expired no-cache no-store private auth;
gzip_disable "MSIE [1-6]\.";
Nach dem Login kopieren


4. Optimieren Sie das Ausgabe-Caching

fastcgi_buffers 256 16k; 
fastcgi_buffer_size 128k; 
fastcgi_connect_timeout 3s; 
fastcgi_send_timeout 120s; 
fastcgi_read_timeout 120s; 
fastcgi_busy_buffers_size 256k; 
fastcgi_temp_file_write_size 256k;
Nach dem Login kopieren

5. Arbeitsprozesse optimieren

Nginx ist Multiprozess statt Multithread. Wir müssen die prozessbezogene Konfiguration wie folgt optimieren.

Schauen Sie sich zunächst die Anzahl der Prozessoren auf dem Server an.

cat /proc/cpuinfo | grep processor
Nach dem Login kopieren

Dann legen Sie worker_processes fest, und die Anzahl der Prozesse ist die Anzahl der erhaltenen Prozessoren. worker_connections ist die maximale Anzahl von Verbindungen, die jeder Prozess öffnen kann, die erhöht werden kann. Hier ist eine Referenz.

# We have 16 cores 
worker_processes 16; 
# connections per worker 
events 
{ 
  worker_connections 4096; 
  multi_accept on; 
}
 记住multi_accept 必须打开。
Nach dem Login kopieren
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage