Heim >Backend-Entwicklung >PHP-Tutorial >Beispiel für die PHP-Speicher-Caching-Funktion memcached

Beispiel für die PHP-Speicher-Caching-Funktion memcached

高洛峰
高洛峰Original
2016-12-30 13:36:421243Durchsuche

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 Memcached, aber viele Schüler haben nur davon gehört und ihn nicht verwendet oder tatsächlich verstanden Ich weiß nur, dass es eine ziemlich 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

Laden Sie zunächst Memcached-1.12 herunter .gz. 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
# make
# make install
# cd .
# tar -xzf memcached-1.1.12.tar.gz
# cd memcached-1.1.12
# ./configure --prefix=/usr
# make
# make install

Nachdem die Installation abgeschlossen ist, 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, nur eine Befehlszeile, keine Notwendigkeit, Konfigurationsdateien zu ändern (es gibt keine Konfigurationsdatei). Für Sie geändert):
/usr/bin/memcached -d -m 128 -l 192.168.1.1 -p 11211 -u httpd

Parametererklärung:

-d Führen Sie Memcached im Daemon-Modus aus.

-m legt die Speichergröße fest, die Memcached verwenden kann. In M legt

-l die Überwachungs-IP-Adresse fest muss nicht festgelegt werden;

-p legt den Überwachungsport fest, der Standardwert ist 11211, daher muss dieser Parameter nicht festgelegt werden;

-u gibt den Benutzer an, der erforderlich ist Wenn Sie derzeit Root sind, verwenden Sie diesen Parameter, um den Benutzer anzugeben.

Natürlich gibt es noch andere Parameter, die verwendet werden können. Sie können sie sehen, indem Sie man memcached ausführen.

4. Wie Memcached funktioniert

Zunächst läuft Memcached auf einem oder mehreren Servern als Daemon und akzeptiert jederzeit Client-Verbindungsvorgänge In verschiedenen Sprachen umfassen derzeit bekannte Client-APIs 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 den Memcached-Dienst für Objektzugriffsvorgänge aufzurufen.

Zuerst hat PHP eine Erweiterung namens memcache. Beim Kompilieren unter Linux müssen Sie die Option –enable-memcache[=DIR] verwenden. Entfernen Sie unter Windows php_memcache.dll. Kommentarzeichen davor, um es verfügbar zu machen.

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

Erstmals memcached-client.php herunterladen. Nach dem Herunterladen von memcached-client.php können Sie die Klasse „memcached“ in dieser Datei verwenden Dienst durchgeführt wurde. 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)

Objekte in den Memcache schreiben. $val ist die Ablaufzeit in Sekunden

get ($key)

Objektdaten aus dem Memcache über die eindeutige Kennung $key des Objekts abrufen

replace ($key, $value, $exp=0)

Verwenden Sie $value, um den Objektinhalt durch den Bezeichner $key in memcached zu ersetzen. Es funktioniert nur, wenn das $key-Objekt vorhanden ist 🎜>

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.
delete ($key, $time = 0)

Das Folgende ist ein einfacher Testcode, der auf Objektdaten mit der Kennung „mykey“ zugreift:


<?php
// 包含 memcached 类文件
require_once(&#39;memcached-client.php&#39;);
// 选项设置
$options = array(
 &#39;servers&#39; => array(&#39;192.168.1.1:11211&#39;), //memcached 服务的地址、端口,可用多个数组元素表示多个 memcached 服务
 &#39;debug&#39; => true, //是否打开 debug
 &#39;compress_threshold&#39; => 10240, //超过多少字节的数据时进行压缩
 &#39;persistant&#39; => false //是否使用持久连接
 );
// 创建 memcached 对象实例
$mc = new memcached($options);
// 设置此脚本使用的唯一标识符
$key = &#39;mykey&#39;;
// 往 memcached 中写入对象
$mc->add($key, &#39;some random strings&#39;);
$val = $mc->get($key);
echo "n".str_pad(&#39;$mc->add() &#39;, 60, &#39;_&#39;)."n";
var_dump($val);
// 替换已写入的对象数据值
$mc->replace($key, array(&#39;some&#39;=>&#39;haha&#39;, &#39;array&#39;=>&#39;xxx&#39;));
$val = $mc->get($key);
echo "n".str_pad(&#39;$mc->replace() &#39;, 60, &#39;_&#39;)."n";
var_dump($val);
// 删除 memcached 中的对象
$mc->delete($key);
$val = $mc->get($key);
echo "n".str_pad(&#39;$mc->delete() &#39;, 60, &#39;_&#39;)."n";
var_dump($val);
?>

是不是很简单,在实际应用中,通常会把数据库查询的结果集保存到 memcached 中,下次访问时直接从 memcached 中获取,而不再做数据库查询操作,这样可以在很大程度上减轻数据库的负担。通常会将 SQL 语句 md5() 之后的值作为唯一标识符 key。下边是一个利用 memcached 来缓存数据库查询结果集的示例(此代码片段紧接上边的示例代码):

<?php
$sql = &#39;SELECT * FROM users&#39;;
$key = md5($sql); //memcached 对象标识符
{
 // 在 memcached 中未获取到缓存数据,则使用数据库查询获取记录集。
 echo "n".str_pad(&#39;Read datas from MySQL.&#39;, 60, &#39;_&#39;)."n";
 $conn = mysql_connect(&#39;localhost&#39;, &#39;test&#39;, &#39;test&#39;);
 mysql_select_db(&#39;test&#39;);
 $result = mysql_query($sql);
 while ($row = mysql_fetch_object($result))
  $datas[] = $row;
 // 将数据库中获取到的结果集数据保存到 memcached 中,以供下次访问时使用。
 $mc->add($key, $datas);
{
 echo "n".str_pad(&#39;Read datas from memcached.&#39;, 60, &#39;_&#39;)."n";
}
var_dump($datas);
?>

可以看出,使用 memcached 之后,可以减少数据库连接、查询操作,数据库负载下来了,脚本的运行速度也提高了。

之前我曾经写过一篇名为《PHP 实现多服务器共享 SESSION 数据》文章,文中的 SESSION 是使用数据库保存的,在并发访问量大的时候,服务器的负载会很大,经常会超出 MySQL 最大连接数,利用 memcached,我们可以很好地解决这个问题,工作原理如下:

用户访问网页时,查看 memcached 中是否有当前用户的 SESSION 数据,使用 session_id() 作为唯一标识符;如果数据存在,则直接返回,如果不存在,再进行数据库连接,获取 SESSION 数据,并将此数据保存到 memcached 中,供下次使用;

当前的 PHP 运行结束(或使用了 session_write_close())时,会调用 My_Sess::write() 方法,将数据写入数据库,这样的话,每次仍然会有数据库操作,对于这个方法,也需要进行优化。使用一个全局变量,记录用户进入页面时的 SESSION 数据,然后在 write() 方法内比较此数据与想要写入的 SESSION 数据是否相同,不同才进行数据库连接、写入数据库,同时将 memcached 中对应的对象删除,如果相同的话,则表示 SESSION 数据未改变,那么就可以不做任何操作,直接返回了;

那么用户 SESSION 过期时间怎么解决呢?记得 memcached 的 add() 方法有个过期时间参数 $exp 吗?把这个参数值设置成小于 SESSION 最大存活时间即可。另外别忘了给那些一直在线的用户延续 SESSION 时长,这个可以在 write() 方法中解决,通过判断时间,符合条件则更新数据库数据。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持PHP中文网。

更多PHP内存缓存功能memcached示例相关文章请关注PHP中文网!

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