Heim >Backend-Entwicklung >PHP-Tutorial >PHP-Speicher-Caching-Funktion memcached example_php Beispiel
Im Folgenden werden die Anwendungsbeispiele der Memcached-Klasse kurz vorgestellt, die einen gewissen Referenzwert haben. Interessierte Freunde können sich darauf beziehen.
1. Einführung in memcached
Bei vielen Gelegenheiten hören wir den Namen im Speicher, aber viele Schüler haben nur davon gehört und ihn nicht verwendet oder tatsächlich verstanden. Sie wissen nur, dass es eine sehr gute Sache ist. Hier ist eine kurze Einführung: Memcached ist ein effizientes und schnelles Caching-System für verteilte Speicherobjekte, das hauptsächlich zur Beschleunigung dynamischer WEB-Anwendungen verwendet wird.
2. Memcached-Installation
Als Erstes müssen Sie memcached herunterladen. Die neueste Version ist 1.1.12. Sie können memcached-1.1.12.tar.gz direkt von der offiziellen Website herunterladen. Darüber hinaus verwendet memcached libevent und ich habe libevent-1.1a.tar.gz heruntergeladen.
Der nächste Schritt besteht darin, libevent-1.1a.tar.gz bzw. memcached-1.1.12.tar.gz zu entpacken, zu kompilieren und zu installieren:
# tar -xzf libevent-1.1a.tar.gz
# cd libevent-1.1a
# ./configure --prefix=/usr
# mache
# make install
#cd ..
# tar -xzf memcached-1.1.12.tar.gz
# cd memcached-1.1.12
# ./configure --prefix=/usr
# mache
# make install
Nach Abschluss der Installation sollte sich Memcached in /usr/bin/memcached befinden.
3. Führen Sie den Memcached-Daemon aus
Das Ausführen des Memcached-Daemons ist sehr einfach. Es ist lediglich eine Befehlszeile erforderlich. Es müssen keine Konfigurationsdateien geändert werden:
/usr/bin/memcached -d -m 128 -l 192.168.1.1 -p 11211 -u httpd
Parametererklärung:
4. Wie Memcached funktioniert
Zuallererst läuft memcached als Daemon auf einem oder mehreren Servern und akzeptiert jederzeit Client-Verbindungsvorgänge. Zu den derzeit bekannten Client-APIs gehören Perl/PHP/Python/Ruby/Java/C#. /C usw. Nachdem Clients wie PHP eine Verbindung mit dem Memcached-Dienst hergestellt haben, müssen die Objekte, auf die zugegriffen wird, über diesen Schlüssel aufgerufen und im Speicher abgelegt werden , nicht in Cache-Dateien gespeichert, weshalb Memcached so effizient und schnell sein kann. Beachten Sie, dass diese Objekte nicht dauerhaft sind und die darin enthaltenen Daten verloren gehen, wenn der Dienst beendet wird.
5. So verwenden Sie PHP als Memcached-Client
Es gibt zwei Möglichkeiten, PHP als Memcached-Client zu verwenden, um Memcached-Dienste für Objektzugriffsvorgänge aufzurufen.
Zuerst hat PHP eine Erweiterung namens memcache. Beim Kompilieren unter Linux müssen Sie die Option –enable-memcache[=DIR] mitbringen. Unter Windows müssen Sie den Kommentar vor php_memcache.dll in php.ini entfernen dass es verfügbar ist.
Darüber hinaus gibt es eine weitere Möglichkeit, die durch Erweiterung und Neukompilierung verursachten Probleme zu vermeiden, nämlich die direkte Verwendung von php-memcached-client.
In diesem Artikel wird die zweite Methode verwendet. Obwohl die Effizienz etwas schlechter ist als bei der Erweiterungsbibliothek, stellt dies kein großes Problem dar.
6. PHP-Memcached-Anwendungsbeispiel
Laden Sie zuerst memcached-client.php herunter. Nach dem Herunterladen von memcached-client.php können Sie den Memcached-Dienst über die Klasse „memcached“ in dieser Datei bedienen. Tatsächlich ist der Codeaufruf sehr einfach. Die wichtigsten Methoden sind add(), get(), replace() und delete(). Die Methodenbeschreibung lautet wie folgt:
add ($key, $val, $exp = 0)
get ($key)
replace ($key, $value, $exp=0)
delete ($key, $time = 0)Löschen Sie das Objekt mit der Kennung $key im Memcached. $time ist ein optionaler Parameter, der angibt, wie lange vor dem Löschen gewartet werden soll.
Das Folgende ist ein einfacher Testcode, der auf Objektdaten mit der Kennung „mykey“ zugreift:
是不是很简单,在实际应用中,通常会把数据库查询的结果集保存到 memcached 中,下次访问时直接从 memcached 中获取,而不再做数据库查询操作,这样可以在很大程度上减轻数据库的负担。通常会将 SQL 语句 md5() 之后的值作为唯一标识符 key。下边是一个利用 memcached 来缓存数据库查询结果集的示例(此代码片段紧接上边的示例代码):
<?php $sql = 'SELECT * FROM users'; $key = md5($sql); //memcached 对象标识符 { // 在 memcached 中未获取到缓存数据,则使用数据库查询获取记录集。 echo "n".str_pad('Read datas from MySQL.', 60, '_')."n"; $conn = mysql_connect('localhost', 'test', 'test'); mysql_select_db('test'); $result = mysql_query($sql); while ($row = mysql_fetch_object($result)) $datas[] = $row; // 将数据库中获取到的结果集数据保存到 memcached 中,以供下次访问时使用。 $mc->add($key, $datas); { echo "n".str_pad('Read datas from memcached.', 60, '_')."n"; } var_dump($datas); ?>
可以看出,使用 memcached 之后,可以减少数据库连接、查询操作,数据库负载下来了,脚本的运行速度也提高了。
之前我曾经写过一篇名为《PHP 实现多服务器共享 SESSION 数据》文章,文中的 SESSION 是使用数据库保存的,在并发访问量大的时候,服务器的负载会很大,经常会超出 MySQL 最大连接数,利用 memcached,我们可以很好地解决这个问题,工作原理如下:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。