Heim  >  Artikel  >  Backend-Entwicklung  >  Eine Erläuterung der Zusammenfassung der 9 wichtigsten Caching-Technologien in PHP

Eine Erläuterung der Zusammenfassung der 9 wichtigsten Caching-Technologien in PHP

黄舟
黄舟Original
2017-08-13 09:11:201211Durchsuche

1. Statisches Caching der gesamten Seite

Das heißt, alle Seiten werden in statische HTML-Seiten generiert, wenn Benutzer sie besuchen, ohne dazu zu gehen Analysieren Sie sie. Diese Methode ist in CMS-Systemen häufiger anzutreffen, beispielsweise in dedecms. Eine häufigere Implementierungsmethode ist die Verwendung von Ausgabe-Caching:

Ob_start()
******要运行的代码*******
$content = Ob_get_contents();
****将缓存内容写入html文件*****
Ob_end_clean();
2

Diese Methode besteht darin, die Teile einer Seite, die sich nicht häufig ändern, statisch zwischenzuspeichern, während die sich häufig ändernden Blöcke nicht zwischengespeichert und schließlich zur Anzeige zusammengesetzt werden. Sie kann mit einer Methode ähnlich wie ob_get_contents implementiert werden , oder Sie können Seitenfragment-Caching-Strategien wie ESI verwenden, um relativ statische Fragmente in dynamischen Seiten zwischenzuspeichern.

Der Inhalt jeder Website wird ständig aktualisiert und geändert, dies bedeutet jedoch nicht, dass der Inhalt davon Bei einer Website handelt es sich tatsächlich um dynamischen Inhalt, der von einer Webserveranwendung wie gewöhnlichem ASP, JSP usw. generiert wird und daher statisch ist Unter Inhalt versteht man im Allgemeinen Text, Bilder und Multimedia und bleibt grundsätzlich unverändert, jedes Mal, wenn der Benutzer auf den entsprechenden Link klickt. Die neueste Technologie zur Lösung des dynamischen Inhalts-Caching besteht darin, den Inhalt der Website mithilfe der ESI-Technologie zu gestalten.

Funktionsweise der ESI-Technologie Dynamisch generierte Inhalte können den Benutzern reichhaltige und spannende Seiten und Websites bieten Entwickler können damit auch verwandte Inhalte einfacher und flexibler steuern, doch während sie diese Annehmlichkeiten genießen, erhöht sich dadurch auch der Verarbeitungsdruck auf der Website-Datenbank und dem Anwendungsserver. Wenn die Anzahl der Besuche auf einer Website zunimmt, sind die Investitionen in Hardware und Datenbanken sehr hoch. Dennoch kann es immer noch zu erheblichen Verzögerungen auf der Seite oder sogar zu Zugriffsausfällen kommen.

Der Hauptgrund dafür, dass Benutzer auf dynamisch generierte Inhalte langsam zugreifen, besteht darin, dass dynamisch generierte Inhalte einen komplexen Prozess durchlaufen müssen. Zunächst wird die Anforderung des Benutzers dem Anwendungsserver zugewiesen Im entsprechenden Softwaremodul muss das Softwaremodul durch Berechnung ermitteln, welche Daten aus der Datenbank an den Benutzer extrahiert werden müssen, und dann die entsprechenden Daten aus der Datenbank extrahieren und im definierten Format an den Benutzer übergeben . Diese langwierigen Prozesse verlangsamen den Benutzerzugriff und erhöhen die Belastung des Servers.

In der tatsächlichen Umgebung enthält eine dynamisch generierte Seite möglicherweise nur eine geringe Menge an Inhalten, die sich häufig ändern oder für herkömmliche Cache-Server personalisiert sind, um die Aktualität der Seite sicherzustellen , aber aufgrund der geringen Menge an dynamischem Inhalt auf der Seite kann nicht die gesamte Seite zwischengespeichert werden. ESI (Edge Side Include) verwendet eine einfache Auszeichnungssprache, um Inhaltsfragmente in Webseiten zu beschreiben, die beschleunigt werden können und nicht. Jede Webseite wird in verschiedene kleine Teile unterteilt und unterschiedlichen Cache-Kontrollstrategien zugewiesen, sodass der Cache auf diesen Richtlinien basiert Der Server kann verschiedene kleine Teile dynamisch kombinieren, bevor er die vollständige Webseite an den Benutzer sendet. Durch diese Steuerung kann die Häufigkeit des Crawlens der gesamten Seite vom Server effektiv reduziert werden und nur eine kleine Anzahl von Fragmenten, die nicht zwischengespeichert werden können, vom ursprünglichen Server extrahiert werden. Daher kann die Belastung des ursprünglichen Servers effektiv verringert werden reduziert und die Reaktionszeit des Benutzerzugriffs verbessert werden.

ESI ist eine einfache Auszeichnungssprache, mit der Entwickler Inhaltsfragmente markieren können, um das Caching über den entsprechenden Cache-Server zu beschleunigen. Gleichzeitig definiert ESI auch eine Reihe von Inhaltsvalidierungsstandards, mit denen die Verwaltung zwischengespeicherter Inhalte auf dem Cache-Server durch den ursprünglichen Server realisiert und die Fähigkeit der Website zur Inhaltskontrolle verbessert werden kann. Das CDN-Netzwerk kann auch Cache-Server verwenden, die ESI unterstützen und in im ganzen Land verteilten Knoten installiert werden, um CDN-Dienste für den dynamischen Inhalt der Website bereitzustellen.

Diese Methode kann für Produktseiten in Einkaufszentren verwendet werden

3. Daten-Caching

Wie der Name schon sagt, wird es zwischengespeichert Wenn beispielsweise bestimmte Produktinformationen im Einkaufszentrum mithilfe der Produkt-ID angefordert werden, können Daten, einschließlich Geschäftsinformationen, Produktinformationen usw., in einer PHP-Datei zwischengespeichert werden, um eine eindeutige Produkt-ID zu erstellen Wenn jemand dieses Produkt das nächste Mal anzeigen möchte, werden die Informationen in dieser Datei zuerst direkt angepasst, ohne dass die Datenbank abgefragt werden muss. Tatsächlich ist das, was in der Cache-Datei zwischengespeichert wird, ein PHP-Array >Diese Methode wird im Ecmall-Einkaufszentrumssystem verwendet

4

其实这跟数据缓存是一个思路,就是根据查询语句来缓存;将查询得到的数据缓存在一个文件中,下次遇到相同的查询时,就直接先从这个文件里面调数据,不会再去查数据库;但此处的缓存文件名可能就需要以查询语句为基点来建立唯一标示;

按时间变更进行缓存

其实,这一条不是真正的缓存方式;上面的2、3、4的缓存技术一般都用到了时间变更判断;就是对于缓存文件您需要设一个有效时间,在这个有效时间 内,相同的访问才会先取缓存文件的内容,但是超过设定的缓存时间,就需要重新从数据库中获取数据,并生产最新的缓存文件;比如,我将我们商城的首页就是设 置2个小时更新一次;

5、按内容变更进行缓存

这个也并非独立的缓存技术,需结合着用;就是当数据库内容被修改时,即刻更新缓存文件;

比如,一个人流量很大的商城,商品很多,商品表必然比较大,这表的压力也比较重;我们就可以对商品显示页进行页面缓存;

当商家在后台修改这个商品的信息时,点击保存,我们同时就更新缓存文件;那么,买家访问这个商品信息时,实际上访问的是一个静态页面,而不需要再去访问数据库;

试想,如果对商品页不缓存,那么每次访问一个商品就要去数据库查一次,如果有10万人在线浏览商品,那服务器压力就大了;

6、内存式缓存

提到这个,可能大家想到的首先就是Memcached;memcached是高性能的分布式内存缓存服务器。 一般的使用目的是,通过缓存数据库查询结果,减少数据库访问次数,以提高动态Web应用的速度、 提高可扩展性。

它就是将需要缓存的信息,缓存到系统内存中,需要获取信息时,直接到内存中取;比较常用的方式就是 key–>value方式;

<?php 
     $memcachehost = &#39;192.168.6.191&#39;;
     $memcacheport = 11211;
     $memcachelife = 60;
     $memcache = new Memcache;
     $memcache->connect($memcachehost,$memcacheport) or die ("Could not connect");
     $memcache->set(&#39;key&#39;,&#39;缓存的内容&#39;);
     $get = $memcache->get($key);       //获取信息
?>

7、apache缓存模块

apache安装完以后,是不允许被cache的。如果外接了cache或squid服务器要求进行web加速的话,就需要在htttpd.conf里进行设置,当然前提是在安装apache的时候要激活mod_cache的模块。

安装apache时:./configure –enable-cache –enable-disk-cache –enable-mem-cache

8、php APC缓存扩展

Php有一个APC缓存扩展,windows下面为php_apc.dll,需要先加载这个模块,然后是在php.ini里面进行配置:

[apc] 
     extension=php_apc.dll 
     apc.rfc1867 = on 
     upload_max_filesize = 100M 
     post_max_size = 100M 
     apc.max_file_size = 200M 
     upload_max_filesize = 1000M 
     post_max_size = 1000M 
     max_execution_time = 600 ;   每个PHP页面运行的最大时间值(秒),默认30秒 
     max_input_time = 600 ;       每个PHP页面接收数据所需的最大时间,默认60 
     memory_limit = 128M ;       每个PHP页面所吃掉的最大内存,默认8M

9、Opcode缓存

我们知道,php的执行流程可以用下图来展示:

首先php代码被解析为Tokens,然后再编译为Opcode码,最后执行Opcode码,返回结果;所以,对于相同的php文件,第一次运行时 可以缓存其Opcode码,下次再执行这个页面时,直接会去找到缓存下的opcode码,直接执行最后一步,而不再需要中间的步骤了。

比较知名的是XCache、Turck MM Cache、PHP Accelerator等。

Das obige ist der detaillierte Inhalt vonEine Erläuterung der Zusammenfassung der 9 wichtigsten Caching-Technologien in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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