Maison php教程 php手册 php memcache和php memcached比较以及问题

php memcache和php memcached比较以及问题

May 23, 2016 am 08:33 AM
memcache

php memcache和php memcached是php的memcache分布式的高速缓存系统的两个客户端,php memcache是老客户端,php memcached是功能更加完善的新的代替php memcached的.

php memcache独立用php实现,是老客户端,从我们实践中已发现有多个问题,而且功能少,属性也可设置的少;

php memcached是基于原生的c的libmemcached的扩展,更加完善,建议替换为php memcached.

1.Php memcache的问题

1.1 分布式问题

php memcache默认会自动切换实例,所以有时取到老数据,并且value飘忽不定.

网友分享的问题:

这几天做某个产品的时候遇到一个小问题,现象比较诡异,产品用了两台分布式的memcached服务器,某一个计数器取回来的数偶尔会不对,最后定位在php memcache client的failover机制上面.

我们知道,在memcached分布式环境下,某一个key是通过hash计算,分配到某一个memcached上面的.

如果php.ini里面 memcache.allow_failover = 1的时候,在分布式环境下,某一台memcached出问题的话,会自动到其他的memcached尝试,就会出现上面的问题,所以要设置 allow_failover = 0 那么取不到时就直接返回失败而不会从其它mc上取,这样以避免网络异常或server端异常时,经常切换实例,会取到老数据.

1.2 高并发下稳定性问题

新浪微博提到的教训:

php memcache换成php memcached,在高并发下稳定下极大提高;

另外功能更多,出错码更精确。

Twitter的缓存经验

多层次Cache,减轻某些cache节点宕掉后的影响,读写都cache;将memcached api统一换为libmemcached(方便多语言访问memcached,让分布式等各种规则都一致).

1.3 1秒超时间隔没法修改问题

php memcache客户端有个1秒超时间隔没法修改问题:

bool Memcache::connect(string $host [,int $port [,int $timeout ]])

第三个参数本来可设置timeout,单位秒,但无法修改.

测试了以下三种修改timeout的方法都无效:

1.3.1. 用memcache api Memcache::setServerParams不能修改;

1.3.2. 改memcache 源代码vi php_memcache.h宏定义不能修改;

1.3.3. php.ini内这个配置:default_socket_timeout = 60对本timeout无效。

2.memcache和memcached对比

Php memcache这个老客户端在属性设置方面可设置的很少,出错码粒度很粗,出错后难以定位,而且功能欠缺一些:

There are primarily two clients used with PHP. One is the older, more widespread pecl/memcache and the other is the newer, less used, more feature rich pecl/memcached. 
	Both support the basics such as multiple servers, setting vaules, getting values, increment, decrement and getting stats. 
	 
	Here are some more advanced features and information. 
	项目              pecl/memcache       pecl/memcached 
	First Release Date      2004-06-08      2009-01-29 (beta) 
	Actively Developed      Yes             Yes 
	External Dependency     None            libmemcached 
	Automatic Key Fixup1    Yes             No 
	Append/Prepend          No              Yes 
	Automatic Serialzation2 Yes             Yes 
	Binary Protocol         No              Optional 
	CAS                     No              Yes 
	Compression             Yes             Yes 
	Communication Timeout   Connect Only    Various Options 
	Consistent Hashing      Yes             Yes 
	Delayed Get             No              Yes 
	Multi-Get               Yes             Yes 
	Session Support         Yes             Yes 
	Set/Get to a specific server    No          Yes 
	Stores Numerics         Converted to Strings    Yes 
	 
	//注释: 
	 
	1 pecl/memcache will convert an invalid key into a valid key for you. pecl/memcached will return false when trying to set/get a key that is not valid. 
	2 You do not have to serialize your objects or arrays before sending them to the set commands. Both clients will do
Copier après la connexion

本文地址:

转载随意,但请附上文章地址:-)

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment utiliser Memcache dans le développement PHP ? Comment utiliser Memcache dans le développement PHP ? Nov 07, 2023 pm 12:49 PM

Dans le développement Web, nous devons souvent utiliser une technologie de mise en cache pour améliorer les performances du site Web et la vitesse de réponse. Memcache est une technologie de mise en cache populaire qui peut mettre en cache n'importe quel type de données et prend en charge une simultanéité élevée et une haute disponibilité. Cet article explique comment utiliser Memcache dans le développement PHP et fournit des exemples de code spécifiques. 1. Installer Memcache Pour utiliser Memcache, nous devons d'abord installer l'extension Memcache sur le serveur. Dans le système d'exploitation CentOS, vous pouvez utiliser la commande suivante

Comment utiliser Memcache pour des opérations efficaces de lecture et d'écriture de données dans le développement PHP ? Comment utiliser Memcache pour des opérations efficaces de lecture et d'écriture de données dans le développement PHP ? Nov 07, 2023 pm 03:48 PM

Dans le développement PHP, l'utilisation du système de mise en cache Memcache peut considérablement améliorer l'efficacité de la lecture et de l'écriture des données. Memcache est un système de mise en cache basé sur la mémoire qui peut mettre en cache les données en mémoire pour éviter les lectures et écritures fréquentes de la base de données. Cet article expliquera comment utiliser Memcache en PHP pour des opérations efficaces de lecture et d'écriture de données, et fournira des exemples de code spécifiques. 1. Installer et configurer Memcache Vous devez d'abord installer l'extension Memcache sur le serveur. peut passer

Comment utiliser Memcache pour une écriture et des requêtes de données efficaces dans le développement PHP ? Comment utiliser Memcache pour une écriture et des requêtes de données efficaces dans le développement PHP ? Nov 07, 2023 pm 01:36 PM

Comment utiliser Memcache pour une écriture et des requêtes de données efficaces dans le développement PHP ? Avec le développement continu des applications Internet, les exigences en matière de performances du système sont de plus en plus élevées. Dans le développement PHP, afin d'améliorer les performances du système et la vitesse de réponse, nous utilisons souvent diverses technologies de mise en cache. L'une des technologies de mise en cache couramment utilisées est Memcache. Memcache est un système de mise en cache d'objets à mémoire distribuée hautes performances qui peut être utilisé pour mettre en cache les résultats des requêtes de base de données, les fragments de page, les données de session, etc. En stockant les données en mémoire

Utilisation de la technologie de mise en cache Memcache pour améliorer les capacités de traitement simultané des applications PHP Utilisation de la technologie de mise en cache Memcache pour améliorer les capacités de traitement simultané des applications PHP May 18, 2023 am 08:12 AM

Avec le développement rapide d'Internet, de plus en plus d'applications doivent faire face à un grand nombre de requêtes simultanées. Comment améliorer les capacités de traitement simultané des applications est devenu un problème que les développeurs doivent résoudre. Parmi eux, l’utilisation de la technologie de mise en cache Memcache pour l’optimisation de la concurrence est devenue une solution relativement populaire. Memcache est une technologie de mise en cache efficace adaptée aux applications Web, bases de données et systèmes distribués à grande échelle. Sa caractéristique est de stocker des données en mémoire pour réaliser des opérations de lecture et d'écriture à grande vitesse. Pendant le processus d'accès aux données des applications Web,

Comment utiliser Memcache pour la mise en cache distribuée dans le développement PHP ? Comment utiliser Memcache pour la mise en cache distribuée dans le développement PHP ? Nov 07, 2023 pm 03:04 PM

À mesure que les applications Web deviennent de plus en plus complexes, les performances sont devenues un problème crucial. Dans de nombreuses applications, les requêtes de base de données constituent l’une des opérations les plus chronophages. Afin d'éviter de lire fréquemment les données de la base de données, vous pouvez utiliser un système de mise en cache pour stocker les données fréquemment lues en mémoire pour un accès rapide. Dans le développement PHP, l'utilisation de Memcached pour la mise en cache distribuée est une pratique extrêmement courante. Dans cet article, nous présenterons comment utiliser Memcached pour la mise en cache distribuée. Qu'est-ce que Memca

Pratique et réflexion sur l'optimisation de l'interaction des données avec la technologie de mise en cache Memcache en PHP Pratique et réflexion sur l'optimisation de l'interaction des données avec la technologie de mise en cache Memcache en PHP May 17, 2023 pm 09:51 PM

La pratique et la réflexion de la technologie de mise en cache Memcache pour optimiser l'interaction des données en PHP Dans les applications Web modernes, l'interaction des données est un problème très important. Elle n'est pas assez efficace et limitera l'évolutivité et les performances des applications Web. Afin d'accélérer l'interaction des données, notre approche habituelle consiste à optimiser la conception de la base de données, à améliorer les performances du matériel et à augmenter la capacité du serveur. Cependant, ces méthodes ont toutes une limite commune : elles augmentent le coût du système. Ces dernières années, la technologie Memcache a progressé dans la résolution de ce problème.

Application et pratique de la technologie de mise en cache Memcache dans les projets PHP Application et pratique de la technologie de mise en cache Memcache dans les projets PHP May 17, 2023 pm 02:10 PM

Memcache est une technologie de mise en cache distribuée open source. Il améliore considérablement la vitesse d'accès aux données en stockant les données en mémoire, améliorant ainsi les performances et la réactivité du site Web. Dans les projets PHP, la technologie de mise en cache Memcache est également largement utilisée et a obtenu de bons résultats. Cet article explorera en profondeur l'application et la pratique de la technologie de mise en cache Memcache dans les projets PHP. 1. Principes et avantages de Memcache Memcache est une technologie de mise en cache mémoire qui permet de stocker des données

Comment utiliser Memcache pour optimiser les opérations de stockage de données dans votre application PHP ? Comment utiliser Memcache pour optimiser les opérations de stockage de données dans votre application PHP ? Nov 08, 2023 pm 09:06 PM

Comment utiliser Memcache pour optimiser les opérations de stockage de données dans votre application PHP ? Dans le développement d’applications Web, le stockage des données constitue un maillon crucial. Dans les applications PHP, Memcache, en tant que système de cache mémoire, peut améliorer efficacement l'efficacité des opérations de stockage et de lecture des données. Cet article expliquera comment utiliser Memcache pour optimiser les opérations de stockage de données dans les applications PHP et joindra des exemples de code spécifiques. Étape 1 : Installez l'extension Memcache Tout d'abord, vous devez installer Me dans votre environnement PHP

See all articles