recherche
Maisondéveloppement back-endtutoriel php关于memcache的使用(入门级问题),memcache已经配置好,如何才能通过使用它来加快访问速度?

如题

网上看了很多资料 大都是关于memcache配置安装  还有函数列表的

现在已经配置好  用echo $memcache->getVersion();也可以打印出版本了


该如何进行进一步的操作  来使响应速度增加

比如我现在我已经知道一条很复杂的sql语句执行时间很久 

如何针对这条sql语句进行操作?


如果描述不够清楚请说一下我尽量描述...   

谢谢~~


回复讨论(解决方案)

估计你是把应用场景想错了...

sql的问题首先是优化语句

当然你可以考虑将表放到临时内存表里处理

如题

网上看了很多资料 大都是关于memcache配置安装  还有函数列表的

现在已经配置好  用echo $memcache->getVersion();也可以打印出版本了


该如何进行进一步的操作  来使响应速度增加

比如我现在我已经知道一条很复杂的sql语句执行时间很久 

如何针对这条sql语句进行操作?


如果描述不够清楚请说一下我尽量描述...   

谢谢~~



memcache可以分担mysql的压力。
比如你有select的读语句要执行,每次读数据库前先从memcache缓存读,若是读不到再从mysql读,并将内容写到缓存,以便下次从缓存读。
memcache说白了可以降低数据库服务的读压力,而且是缓存,读快且压力小。

而“比如我现在我已经知道一条很复杂的sql语句执行时间很久”,要是想让它快你只能优化sql语句。

若是这句是个读操作,那么你可以写缓存,以后读的话就非常快了。

另外,缓存要注意一点,数据库update和delete的时候,缓存也要更新。~~~

当然,尽可能的优化是要先考虑做的

然后现在要做缓存希望能更快一些

那么 是要在每一个查询处来set or(and) get吗?

那岂不是非常的繁琐.

memcache 不可以缓解数据库的压力
如果那打算将查询结果放在 memcache 中供下次使用,那么下次你得到的不就总是旧的数据吗?
如果还要去检查库中数据是否更新的话,那要缓存做什么?

那么 memcache 适合由于什么样的场景呢?
当你的程序已经在使用文件或数据库缓存中间结果时,那么使用 memcache 可以提升缓存的性能

memcache 不可以缓解数据库的压力
如果那打算将查询结果放在 memcache 中供下次使用,那么下次你得到的不就总是旧的数据吗?
如果还要去检查库中数据是否更新的话,那要缓存做什么?

那么 memcache 适合由于什么样的场景呢?
当你的程序已经在使用文件或数据库缓存中间结果时,那么使用 memcache 可以提升缓存的性能



能否举个稍微具体的例子来说明下memcache的应用呢?  

===========
我现在要查询一个用户关注的各类信息.要分别去查各种条件的汇总起来然后去信息总表内查询.   这种情况下适合使用memcache吗(缓存各种条件的汇总结果,设置个过期时间)?

缓存主要应用于某个时间段不会更新而且经常连接数据库的页面或者程序,比如天气预报,商城的每日促销页面等等,这些访问量会比较大,而且不长更新使用缓存时限,比如每天的8时更新或者分几个时间段,看自己的需求了


如题

网上看了很多资料 大都是关于memcache配置安装  还有函数列表的

现在已经配置好  用echo $memcache->getVersion();也可以打印出版本了


该如何进行进一步的操作  来使响应速度增加


比如我现在我已经知道一条很复杂的sql语句执行时间很久 

如何针对这条sql语句进行操作?


如果描述不够清楚请说一下我尽量描述...   

谢谢~~



memcache可以分担mysql的压力。
比如你有select的读语句要执行,每次读数据库前先从memcache缓存读,若是读不到再从mysql读,并将内容写到缓存,以便下次从缓存读。
memcache说白了可以降低数据库服务的读压力,而且是缓存,读快且压力小。

而“比如我现在我已经知道一条很复杂的sql语句执行时间很久”,要是想让它快你只能优化sql语句。

若是这句是个读操作,那么你可以写缓存,以后读的话就非常快了。

另外,缓存要注意一点,数据库update和delete的时候,缓存也要更新。~~~






大姐是做PHP吗?

当然,尽可能的优化是要先考虑做的

然后现在要做缓存希望能更快一些

那么 是要在每一个查询处来set or(and) get吗?

那岂不是非常的繁琐.


当你的程序已经在使用文件或数据库缓存中间结果时,那么使用 memcache 可以提升缓存的性能这句话没有看懂

memcache 不可以缓解数据库的压力
如果那打算将查询结果放在 memcache 中供下次使用,那么下次你得到的不就总是旧的数据吗?
如果还要去检查库中数据是否更新的话,那要缓存做什么?

那么 memcache 适合由于什么样的场景呢?
当你的程序已经在使用文件或数据库缓存中间结果时,那么使用 memcache 可以提升缓存的性能


当你的程序已经在使用文件或数据库缓存中间结果时,那么使用 memcache 可以提升缓存的性能
 这句话没有看懂

说白了Memcache是一种内存缓存技术,是一种缓存手段,要看情况来使用。

对于频繁读取,每次读取重复率高,数据更新频度低的数据,用Memcache可以优化你的系统响应速度。

一般来说,Memcache的使用分为几个步骤:

1、在代码中,实例化Memcache对象
$mem = new Memcache;
$mem->addserver('127.0.0.1',11211);

2、在获取数据后,将数据缓存到Memcache,下面例子中$data就是需要缓存的数据,$key可以认为是Memcache缓存数据的唯一性标识
$mem->add($key,$data,MEMCACHE_COMPRESSED,60);

3、在需要数据时,从Memcache里面根据$key取数据
$val = $mem->get($key);

你这表述,memcache不是用来优化sql语句的,

它是用来临时 存储访问数据库后得到的数据,第一次获得数据后存储起来,下次访问的时候就不需要查询数据库,而是直接从内存中拿,从而达到减轻数据库访问压力.

而memcache相当于是面向对象的访问接口(内存缓存的过程式程序)

code中类似这样的逻辑
if($mem->get('key')){ // 判断是否已经存储
    // 已存储 从内存中获取
    
}else{
    $mem->set('key','value')  // 还没有存入缓存 存入
}

只是简单的调用这个,还是很简单的,自己试一下吧..

配置好了感觉效果不明显

Déclaration
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
Au-delà du battage médiatique: évaluer le rôle de PHP aujourd'huiAu-delà du battage médiatique: évaluer le rôle de PHP aujourd'huiApr 12, 2025 am 12:17 AM

PHP reste un outil puissant et largement utilisé dans la programmation moderne, en particulier dans le domaine du développement Web. 1) PHP est facile à utiliser et intégré de manière transparente aux bases de données, et est le premier choix pour de nombreux développeurs. 2) Il prend en charge la génération de contenu dynamique et la programmation orientée objet, adaptée à la création et à la maintenance des sites Web rapidement. 3) Les performances de PHP peuvent être améliorées en mettant en cache et en optimisant les requêtes de base de données, et sa vaste communauté et son écosystème riche le rendent toujours important dans la pile technologique d'aujourd'hui.

Quelles sont les références faibles en PHP et quand sont-elles utiles?Quelles sont les références faibles en PHP et quand sont-elles utiles?Apr 12, 2025 am 12:13 AM

En PHP, les références faibles sont mises en œuvre via la classe FaibleRreference et n'empêcheront pas le collecteur des ordures de récupérer des objets. Les références faibles conviennent aux scénarios tels que les systèmes de mise en cache et les auditeurs d'événements. Il convient de noter qu'il ne peut garantir la survie des objets et que la collecte des ordures peut être retardée.

Expliquez la méthode magique __invoke en PHP.Expliquez la méthode magique __invoke en PHP.Apr 12, 2025 am 12:07 AM

La méthode \ _ \ _ Invoke permet aux objets d'être appelés comme des fonctions. 1. Définissez la méthode \ _ \ _ Invoquer afin que l'objet puisse être appelé. 2. Lorsque vous utilisez la syntaxe $ obj (...), PHP exécutera la méthode \ _ \ _ Invoke. 3. Convient pour des scénarios tels que la journalisation et la calculatrice, l'amélioration de la flexibilité et de la lisibilité du code.

Expliquez les fibres dans PHP 8.1 pour la concurrence.Expliquez les fibres dans PHP 8.1 pour la concurrence.Apr 12, 2025 am 12:05 AM

Les fibres ont été introduites dans PHP8.1, améliorant les capacités de traitement simultanées. 1) Les fibres sont un modèle de concurrence léger similaire aux coroutines. 2) Ils permettent aux développeurs de contrôler manuellement le flux d'exécution des tâches et conviennent à la gestion des tâches à forte intensité d'E / O. 3) L'utilisation des fibres peut écrire du code plus efficace et réactif.

La communauté PHP: ressources, soutien et développementLa communauté PHP: ressources, soutien et développementApr 12, 2025 am 12:04 AM

La communauté PHP fournit des ressources et un soutien riches pour aider les développeurs à se développer. 1) Les ressources incluent la documentation officielle, les tutoriels, les blogs et les projets open source tels que Laravel et Symfony. 2) Le support peut être obtenu via les canaux Stackoverflow, Reddit et Slack. 3) Les tendances de développement peuvent être apprises en suivant la RFC. 4) L'intégration dans la communauté peut être réalisée grâce à la participation active, à la contribution au code et au partage d'apprentissage.

PHP vs Python: comprendre les différencesPHP vs Python: comprendre les différencesApr 11, 2025 am 12:15 AM

PHP et Python ont chacun leurs propres avantages, et le choix doit être basé sur les exigences du projet. 1.Php convient au développement Web, avec une syntaxe simple et une efficacité d'exécution élevée. 2. Python convient à la science des données et à l'apprentissage automatique, avec une syntaxe concise et des bibliothèques riches.

PHP: Est-il en train de mourir ou est-ce simplement de s'adapter?PHP: Est-il en train de mourir ou est-ce simplement de s'adapter?Apr 11, 2025 am 12:13 AM

Le PHP n'est pas en train de mourir, mais d'adapter et d'évoluer constamment. 1) PHP a subi plusieurs itérations de version depuis 1994 pour s'adapter aux nouvelles tendances technologiques. 2) Il est actuellement largement utilisé dans le commerce électronique, les systèmes de gestion de contenu et d'autres domaines. 3) PHP8 introduit le compilateur JIT et d'autres fonctions pour améliorer les performances et la modernisation. 4) Utilisez OPCACHE et suivez les normes PSR-12 pour optimiser les performances et la qualité du code.

L'avenir de PHP: adaptations et innovationsL'avenir de PHP: adaptations et innovationsApr 11, 2025 am 12:01 AM

L'avenir de PHP sera réalisé en s'adaptant aux nouvelles tendances technologiques et en introduisant des fonctionnalités innovantes: 1) s'adapter aux architectures de cloud computing, de conteneurisation et de microservice, en prenant en charge Docker et Kubernetes; 2) introduire des compilateurs JIT et des types d'énumération pour améliorer l'efficacité des performances et du traitement des données; 3) Optimiser en continu les performances et promouvoir les meilleures pratiques.

See all articles

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

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

MantisBT

MantisBT

Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

Dreamweaver Mac

Dreamweaver Mac

Outils de développement Web visuel

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Puissant environnement de développement intégré PHP

MinGW - GNU minimaliste pour Windows

MinGW - GNU minimaliste pour Windows

Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser