Heim  >  Artikel  >  Backend-Entwicklung  >  Ausführliche Erläuterung der PHP-Anwendungs-Caching-Technologie auf Unternehmensebene

Ausführliche Erläuterung der PHP-Anwendungs-Caching-Technologie auf Unternehmensebene

巴扎黑
巴扎黑Original
2016-11-23 15:36:091264Durchsuche

Wir haben die PHP-Caching-Technologie bereits ausführlich besprochen, wobei es hauptsächlich um das Daten-Caching ging. Das Daten-Caching bezieht sich hauptsächlich auf das Caching von Datenbankabfragen. Bei jedem Zugriff auf eine Seite wird zunächst festgestellt, ob die entsprechenden zwischengespeicherten Daten vorhanden sind. Stellen Sie eine Verbindung zur Datenbank her, rufen Sie die Daten ab und vervollständigen Sie das Abfrageergebnis.




Wir haben die PHP-Caching-Technologie bereits ausführlich besprochen, wobei es hauptsächlich um das Daten-Caching ging. Das Daten-Caching bezieht sich hauptsächlich auf das Caching von Datenbankabfragen. Bei jedem Zugriff auf eine Seite wird zunächst erkannt, ob die entsprechenden zwischengespeicherten Daten vorhanden sind. Wenn diese nicht vorhanden sind, wird eine Verbindung zur Datenbank hergestellt, die Daten abgerufen, die Abfrageergebnisse serialisiert und gespeichert in eine Datei. Die gleichen Abfrageergebnisse werden direkt aus der Cache-Tabelle oder Datei erhalten.

Das am weitesten verbreitete Beispiel ist die Suchfunktion von Discuz, die die Ergebnis-ID in einer Tabelle zwischenspeichert und bei der nächsten Suche nach demselben Schlüsselwort zuerst die Cache-Tabelle durchsucht.

Wenn mehrere Tabellen verknüpft sind, wird der Inhalt der angehängten Tabelle generiert und in einem Array in einem Feld der Haupttabelle gespeichert. Der Vorteil davon ist Da nur eine Tabelle gelesen werden kann, ist der Nachteil, dass es viele weitere Schritte zum Synchronisieren der beiden Daten gibt. Der entscheidende Punkt hierbei ist die Datenbank.

Seitencache

Bei jedem Zugriff auf eine Seite wird zunächst erkannt, ob die entsprechende zwischengespeicherte Seitendatei vorhanden ist. Wenn sie nicht vorhanden ist, stellen Sie eine Verbindung zur Datenbank her, rufen Sie die Daten ab und zeigen Sie sie an Seite und generieren Sie gleichzeitig eine zwischengespeicherte Seitendatei, sodass die Seitendatei beim nächsten Besuch eine Rolle spielt. (Template-Engines und einige gängige Cache-Klassen im Internet verfügen normalerweise über diese Funktion)

Zeitgesteuertes Caching

Überprüfen Sie, ob die Datei vorhanden ist und der Zeitstempel kleiner als die festgelegte Ablaufzeit ist Der Zeitstempel der Dateiänderung ist kleiner als. Wenn der aktuelle Zeitstempel minus dem Ablaufzeitstempel größer ist, verwenden Sie den Cache, andernfalls aktualisieren Sie den Cache.

Inhalt löst Caching aus

Wenn Daten eingefügt oder aktualisiert werden, wird eine Aktualisierung des Caches erzwungen.

Statischer Cache

Der hier erwähnte statische Cache bezieht sich auf statische, direkt generierte Textdateien wie HTML oder XML und deren Neugenerierung bei Aktualisierungen, was für Seiten geeignet ist, die sich nicht ändern viel. Das werde ich nicht mehr sagen.

Memcached

Memcached ist ein leistungsstarkes, verteiltes Speicherobjekt-Caching-System, das zur Reduzierung der Datenbanklast und zur Verbesserung der Zugriffsgeschwindigkeit in dynamischen Anwendungen verwendet wird.



  $memcache = new Memcache;

$memcache->connect('localhost', 11211) oder sterben („Konnte nicht connect");

$version = $memcache->getVersion();

echo "Serverversion: ".$version."n";

$tmp_object = new stdClass;

$tmp_object->str_attr = 'test';

$tmp_object->int_attr = 123; $tmp_object, false, 10) oder die („ Daten konnten nicht auf dem Server gespeichert werden“);

 echo „Daten im Cache speichern (Daten laufen in 10 Sekunden ab)n“; 'key');

 echo „Daten aus dem Cache:n“;

 var_dump($get_result);



Beispiel zum Auslesen der Datenbank:



  $sql = 'SELECT * FROM users ';

 $key = md5( $sql); //memcached-Objekt-ID

  if ( !($datas = $mc->get($key)) ) {

  // Wenn zwischengespeicherte Daten nicht abgerufen werden memcached, Datenbankabfrage verwenden, um den Datensatz zu erhalten

  echo „n“.str_pad('Daten aus MySQL lesen.', 60, '_') ."n" $conn = mysql_connect('localhost', 'test', 'test');

mysql_select_db('test');

$result = mysql_query($sql);

while ($row = mysql_fetch_object($result))

$datas[] = $row;

// Aus der Datenbank abrufen Die erhaltenen Ergebnissatzdaten werden im Memcached zur Verwendung in gespeichert beim nächsten Besuch

 $mc->add($key, $datas);

 } else {

echo "n".str_pad('Daten aus Memcached lesen .', 60, '_')."n";

 }

var_dump($datas> ?> >
PHP-Puffer

Wie Eaccelerator, APC, PHPA, Xcache usw.

 MySQL-Cache

Dies gilt auch für die Verwendung dieser Methode auf Nicht-Code-Ebene. Sie beträgt etwa 0,09xxx.



 [client]

 ……

 default-character-set=gbk

 default-storage-engine=MYISAM 🎜 >
max_connections=600

max_connect_errors=500

back_log=200

Interactive_timeout=7200

query_cache_size=64M



table_cache=512

 ... _size=1024M

 read_buffer_size=512M

 ……

Thread_concurrency=8



Web-Cache basierend auf Reverse-Proxy

Wie Nginx, SQUID, mod_PRoxy(apache2 Das Obige ist in mod_proxy und mod_cache unterteilt)

Beispiel für NGINX:



#user niemand;

worker_processes 4;

pid logs/nginx.pid;

worker_rlimit_nofile 10240;
events { 🎜> worker_connections 51200; 224: 80 Weight =1;

Server 10.10.10.221:80 Gewicht=1; {

 Server 10.10.10.204:80 Gewicht=1; 🎜> Upstream bspwsisvr { }>
}

UPSTREAM BSPADMINSVR {

Server 10.10.10.222:80 Gewicht = 1;

}

Upstream bspbuyersvr {

Server 10.10.10.223:80 Weight=1;

}

Upstream bspsellersvr { > }

Upstream bsploginsvr {

server 10.10.10.220:443 Weight=1;

} er 10.10.10.220:80 Weight=1; "$http_referer" "$http_user_agent" '; >
listen 10.10.10.230:80;

server_name img.test.com; >proxy_pass http://bspimgsvr;
 #style.test .com

 server {

 listen 10.10.10.230:80;

 server_name style.test.com;

 location / {

Proxy_pass http://bspstylesvr

include Proxy_setting.conf

access_log logs/style.log test_com; #help.test.com

 server {

 listen 10.10.10.230:80;

 server_name help.test.com> Standort / {

Proxy_Pass http://bsphelpsvr;

include Proxy_setting.conf; .log test_com; 🎜> Server { Servername admin.test.com;

Proxy_pass http://bspadminsvr;

include Proxy_setting.conf; }

access_log logs/admin.log test_com;

server_name seller.test.com; > Proxy_pass http://bspbuyersvr;

include Proxy_setting.conf;


  server { 

  listen 10.10.10.230:80; 

  Servername seller.test.com; 

  location / { 

  proxy_pass http://bspsellersvr; 

  include Proxy_setting.conf; 

  } 

  access_log logs/seller.log test_com; 

  } 

  #wsi.test.com 

  server { 

  listen 10.10.10.230:80; 

  Servername wsi.test.com; 

  location / { 

  proxy_pass http://bspwsisvr; 

  include Proxy_setting.conf; 

  } 

  access_log logs/wsi.log test_com; 

  } 

  #www.test.com 

  server { 

  listen 10.10.10.230:80; 

  Servername www.test.com *.test.com; 

  location ~ ^/NginxStatus/ { 

  stub_status on; 

  access_log off; 

  } 

  location / { 

  proxy_pass http://bspfrontsvr; 

  include Proxy_setting.conf; 

  } 

  access_log logs/www.log test_com; 

  error_page 500 502 503 504 /50x.html; 

  location = /50x.html { 

  root html; 

  } 

  } 

  #login.test.com 

  server { 

  listen 10.10.10.230:443; 

  Servername login.test.com; 

  ssl on; 

  ssl_certificate cert.pem; 

  ssl_certificate_key cert.key; 

  ssl_session_timeout 5m; 

  ssl_protocols SSLv2 SSLv3 TLSv1; 

  ssl_ciphers ALL:!ADH:!EXPORT56:RC4 RSA: HIGH: MEDIUM: LOW: SSLv2: EXP; 

  ssl_prefer_server_ciphers on; 

  location / { 

  proxy_pass https://bsploginsvr; 

  include Proxy_setting.conf; 

  } 

  access_log logs/login.log test_com; 

  } 

  #login.test.com für die Registrierung 

  server { 

  listen 10.10.10.230:80; 

  Servername login.test.com; 

  location / { 

  proxy_pass http://bspregistersvr; 

  include Proxy_setting.conf; 

  } 

  access_log logs/register.log test_com; 

  } 

  } 

   

  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; 

  client_max_body_size 10m; 

  client_body_buffer_size 128k; 

  proxy_connect_timeout 90; 

  proxy_send_timeout 90; 

  proxy_read_timeout 90; 

  proxy_buffer_size 4k; 

  proxy_buffers 4 32k; 

  proxy_busy_buffers_size 64k; 

  proxy_temp_file_write_size 64k; 



  mod_proxy的例子: 



   

  ServerName www.zxsv.com 

  ServerAdmin admin@zxsv.com 

  # Reverse-Proxy-Einstellung 

  ProxyPass / http://www.zxsv. com:8080/ 

  ProxyPassReverse / http://www.zxsv.com:8080/ 

  # Cache-Verzeichnisstamm 

  CacheRoot „/var/www/proxy“ 

  # max. Cache-Speicher 

  CacheSize 50000000 

  # Stunde: alle 4 Stunden 

  CacheGcInterval 4 

  # max Ablaufzeit der Seite: Stunde

  CacheMaxExpire 240 

  # Ablaufzeit = (jetzt – last_modified) * CacheLastModifiedFactor 

  CacheLastModifiedFactor 0.1 

  # defaltiertes Ablaufdatum : Stunde 

  CacheDefaultExpire 1 

  # Force Complete nach Prozent des abgerufenen Inhalts: 60–90 % 

  CacheForceCompletion 80 

  CustomLog /usr/local/apache/logs/dev_access_log kombiniert 

  

Stellungnahme:
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