转 memcache保存php的session 解决多服务器的session有关问题
转 memcache保存php的session 解决多服务器的session问题
?
?
PECL :: Package :: memcache 2.1.1 版本的 Changelog 中有一条:
- Added experimental session storage support. You can use memcached as session storage.
也就是可以直接用 memcache 来作 PHP 的 session.save_handler。
1. 安装 memcached,还是那套 ./configure; make; make install,注意 memcached 用 libevent 来作事件驱动,所以要先安装有 libevent。
2. 安装 pecl::memcache,用 pecl 命令行工具安装:
pecl install memcache
或直接从源码安装:
phpize
./configure
make
make install
将 php.ini 中 extension=memcache.so 打开,重启一下 apache,查看 phpinfo 中的 Registered save handlers 会有 files user memcache 这3个可用。
3. 修正配置文件,在 php.ini 中全局设置:
session.save_handler = memcache
session.save_path = tcp://127.0.0.1:11211
或者某个目录下的 .htaccess :
php_value session.save_handler memcache
php_value session.save_path tcp://127.0.0.1:11211
再或者在某个一个应用中:
ini_set(session.save_handler, memcache);
ini_set(session.save_path, tcp://127.0.0.1:11211);?
应用多个 memcached server 时用逗号,隔开,并且和 Memcache::addServer() 文档中阐明的一样,可以带额外的参数persistent、weight、timeout、retry_interval 等等,类似这样的:tcp://host1:port1?persistent=1&weight=2,tcp://host2:port2 。
4. 启动 memcached:
memcached -d -l 127.0.0.1 -p 11212 -m 128
5. 在程序中应用 memcache 来作 session 存储,用例子测试一下:
___FCKpd___6
6. 用 sessionid 去 memcached 里查询一下:
$memcache = memcache_connect(localhost, 11211);
var_dump($memcache->get(19216821213c65cedec65b0883238c278eeb573e077));
SESSION[TEST3] = time();
print
;
print session_id();
?>
会有看到
string(37) TEST|i:1177556731;TEST3|i:1177556881;
这样的输出,证明 session 正常工作。
用 memcache 来存储 session 在读写速度上会比 files 时快很多,而且在多个服务器须要共用 session 时会比较方便,将这些服务器都配置成应用同一组 memcached 服务器就可以,减少了额外的工作量。缺点是 session 数据都保存在 memory 中,持久化方面有所欠缺,但对 session 数据来说也不是很大的问题。

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

L'échec de la session est généralement dû à l'expiration de la durée de vie de la session ou à l'arrêt du serveur. Les solutions : 1. Prolonger la durée de vie de la session ; 2. Utiliser le stockage persistant ; 3. Utiliser les cookies ; 4. Mettre à jour la session de manière asynchrone ; 5. Utiliser un middleware de gestion de session ;

Solution au problème inter-domaines de PHPSession Dans le développement de la séparation front-end et back-end, les requêtes inter-domaines sont devenues la norme. Lorsque nous traitons de problèmes interdomaines, nous impliquons généralement l'utilisation et la gestion de sessions. Cependant, en raison des restrictions de la politique d'origine du navigateur, les sessions ne peuvent pas être partagées par défaut entre les domaines. Afin de résoudre ce problème, nous devons utiliser certaines techniques et méthodes pour réaliser le partage de sessions entre domaines. 1. L'utilisation la plus courante des cookies pour partager des sessions entre domaines

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

Cookies JavaScript L'utilisation de cookies JavaScript constitue le moyen le plus efficace de mémoriser et de suivre les préférences, les achats, les commissions et autres informations. Informations nécessaires pour une meilleure expérience de visiteur ou des statistiques de site Web. PHPCookieCookies sont des fichiers texte stockés sur les ordinateurs clients et conservés à des fins de suivi. PHP prend en charge de manière transparente les cookies HTTP. Comment fonctionnent les cookies JavaScript ? Votre serveur envoie certaines données au navigateur de votre visiteur sous la forme d'un cookie. Les navigateurs peuvent accepter les cookies. S'il est présent, il sera stocké sur le disque dur du visiteur sous forme d'enregistrement en texte brut. Désormais, lorsqu'un visiteur atteint une autre page du site

Optimisation de la communication asynchrone entre PHPSession à travers les domaines et AJAX Avec le développement d'Internet, l'accès entre domaines et la communication asynchrone sont devenus des besoins courants dans le développement d'applications Web modernes. Cet article se concentrera sur la façon d'utiliser PHPSession pour obtenir un accès inter-domaines et fournira quelques méthodes d'optimisation pour améliorer l'efficacité de la communication asynchrone d'AJAX. 1. Le problème de l'accès inter-domaines Dans le développement Web, cela se produit lorsque le navigateur initie une requête HTTP à partir d'une page Web d'un nom de domaine puis renvoie les données de réponse appartenant à un autre nom de domaine.

Amazfit a dévoilé son premier smartphone intelligent, l'Helio, au CES 2024 plus tôt cette année. Près de six mois plus tard, il est désormais également vendu en Europe. Selon le fabricant, le nouvel Amazfit Helio Ring est actuellement disponible et peut être commandé directement.

Les raisons de l'échec de la session incluent le délai d'expiration de la session, la limite du nombre de sessions, la vérification de l'intégrité de la session, le redémarrage du serveur, les problèmes de navigateur ou de périphérique, etc. Introduction détaillée : 1. Délai d'expiration de la session : le serveur définit un délai d'expiration par défaut pour la session. Lorsque l'utilisateur n'interagit pas avec le serveur pendant un certain temps, la session expire automatiquement. 2. Limite du nombre de sessions : le serveur a un numéro. de sessions pour chaque utilisateur. Une limite est définie lorsque le nombre de sessions créées par un utilisateur dépasse cette limite, la dernière écrasera la plus ancienne et ainsi de suite.

Maîtrisez le mécanisme d'authentification de session et l'optimisation de la sécurité en PHP. Le mécanisme d'authentification de session est une méthode d'authentification couramment utilisée dans le développement Web. En PHP, les sessions sont utilisées pour implémenter l'authentification de l'identité des utilisateurs et le contrôle des autorisations afin de protéger les informations sensibles des utilisateurs contre les fuites. Cet article explique comment utiliser correctement les sessions en PHP et améliorer la sécurité des sessions. Ouverture de session En PHP, nous devons d'abord ouvrir une session pour utiliser ses fonctions. utiliser
