Explication graphique détaillée de la fonction de mise en cache de la mémoire PHP memcached

墨辰丷
Libérer: 2023-03-28 16:56:02
original
1460 Les gens l'ont consulté

Cet article présente principalement l'exemple de la fonction de mise en cache mémoire PHP memcached. Il présente brièvement memcached, qui est une application typique de PHP pour faire fonctionner memcached. Les amis dans le besoin peuvent venir en apprendre davantage.

Ce qui suit. est une brève introduction à Memcached. Les exemples d'application de la classe ont une certaine valeur de référence et les amis intéressés peuvent s'y référer.

1. Introduction à memcached

À de nombreuses reprises, nous entendrons le nom memcached, mais de nombreux étudiants n'en ont entendu parler que et de lui. ne sert à rien. Je ne l'ai jamais vu ni compris, et je sais seulement que c'est une très bonne chose. Voici une brève introduction : memcached est un système de mise en cache d'objets à mémoire distribuée efficace et rapide, principalement utilisé pour accélérer les applications dynamiques WEB.

2. Installation de Memcached

La première étape consiste à télécharger Memcached. La dernière version est la 1.1.12, qui peut être téléchargée directement depuis. le site officiel memcached-1.1.12.tar.gz. De plus, memcached utilise libevent et j'ai téléchargé libevent-1.1a.tar.gz.

L'étape suivante consiste à décompresser, compiler et installer respectivement libevent-1.1a.tar.gz et memcached-1.1.12.tar.gz :

# 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

Une fois l'installation terminée, memcached devrait être dans /usr/bin/memcached.

3. Exécutez le démon memcached

L'exécution du démon memcached est très simple. Elle ne nécessite qu'une ligne de commande et ne nécessite aucune modification. n'importe quel fichier de configuration (vous n'avez aucun fichier de configuration à modifier) :
/usr/bin/memcached -d -m 128 -l 192.168.1.1 -p 11211 -u httpd

Explication du paramètre :

  • -d exécute memcached en mode démon ;

  • -m définit la taille de mémoire que memcached peut utiliser ; utiliser, L'unité est M

  • -l Définir l'adresse IP de surveillance S'il s'agit de la machine locale, vous n'avez généralement pas besoin de définir ce paramètre ;

  • - p définit le port d'écoute, la valeur par défaut est 11211, donc ce paramètre n'a pas besoin d'être défini
  • -u précise l'utilisateur si vous êtes actuellement. root, vous devez utiliser ce paramètre pour spécifier l'utilisateur.

  • Bien sûr, il existe d'autres paramètres qui peuvent être utilisés, vous pouvez le voir dans man memcached.


4. Comment fonctionne Memcached


Tout d'abord, Memcached fonctionne comme un démon sur un ou plusieurs serveurs et accepte les demandes des clients à tout moment. Pour les opérations de connexion, le client peut être écrit dans différents langages. Les API client actuellement connues incluent Perl/PHP/Python/Ruby/Java/C#/C, etc. Une fois que des clients tels que PHP ont établi une connexion avec le service memcached, la prochaine étape consiste à accéder aux objets. Chaque objet accédé possède une clé d'identification unique. Les opérations d'accès sont effectuées via cette clé et enregistrées dans memcached. , non stocké dans les fichiers de cache, c'est pourquoi memcached peut être si efficace et rapide. Notez que ces objets ne sont pas persistants et que les données qu'ils contiennent seront perdues après l'arrêt du service.


5. Comment utiliser PHP comme client memcached


Il existe deux façons d'utiliser PHP comme client memcached pour appeler le service memcached pour les opérations d’accès.


Tout d'abord, PHP a une extension appelée memcache. Lors de la compilation sous Linux, vous devez apporter l'option –enable-memcache[=DIR] Sous Windows, supprimez php_memcache.dll dans php.ini. caractère de commentaire devant pour le rendre disponible.


De plus, il existe un autre moyen d'éviter les problèmes causés par l'expansion et la recompilation, et c'est d'utiliser directement php-memcached-client.


Cet article utilise la deuxième méthode, bien que l'efficacité soit légèrement pire que celle de la bibliothèque d'extensions, ce n'est pas un gros problème.

6. Exemple d'application PHP memcached


Téléchargez d'abord memcached-client.php Après avoir téléchargé memcached-client.php, vous pouvez utiliser ce fichier La classe. "memcached" exploite le service memcached. En fait, l'appel du code est très simple. Les principales méthodes utilisées sont add(), get(), replace() et delete().


Écrivez les objets dans memcached. $key est l'identifiant unique de l'objet. $val est les données de l'objet écrites. $exp est le délai d'expiration en secondes.

add ($key, $val, $exp = 0)
Copier après la connexion


Obtenir les données d'objet de memcached via l'identifiant unique de l'objet $key

get ($key)
Copier après la connexion


Utilisez $value pour remplacer le contenu de l'objet par l'identifiant $key dans memcached Les paramètres sont les mêmes que la méthode add() Cela ne fonctionnera que si l'objet $key existe ;

replace ($key, $value, $exp=0)
Copier après la connexion


delete ($key, $time = 0)
Copier après la connexion
Supprimer l'objet avec l'identifiant $key dans memcached, $time est un paramètre facultatif, indique combien de temps attendre avant de supprimer.

Ce qui suit est un code de test simple qui accède aux données d'objet avec l'identifiant « mykey » :

<?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); 
?>
Copier après la connexion

是不是很简单,在实际应用中,通常会把数据库查询的结果集保存到 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); 
?>
Copier après la connexion

可以看出,使用 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数据库操作mongodb的用法

PHP中in_array隐式转换实现步骤详解

PHP关于堆排序算法详解

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!