Heim > Artikel > Backend-Entwicklung > Ausführliche Erläuterung der PHP-Anwendungs-Caching-Technologie auf Unternehmensebene
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