


How to save session to memcached in php? How to save php session distributedly
session_set_save_handler has nothing to do with memcached's method of saving session
On the memcached server
1) Download memcached
#wget http://memcached.googlecode.com/files/memcached-1.4.15.tar.gz
2) Since memcached depends on libevent, you need to install the libevent library first. Here is the direct yum installation
#yum install *libevent*
3) Install memcached
#./configure --prefix=/usr/local/memcached
#make
# make install
4) Start memcached
#/usr/local/memcached/bin/memcached -d -m 4096 -p 11211 -u root
-d daemon ?-p port -u ?user -m memory
in On the web server server
5) Install the php memcache module on the web server
#/usr/local/php/bin/pecl install memcache
Enable memcache session handler support? [yes] : yes (select yes here)
6) Add the following content to php.ini:
extension=/usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/memcache.so
7) Modify php. The session.save_handler and session.save_path in ini are as follows:
session.save_handler = memcache
session.save_path = "tcp://memcached server ip:11211"
It can also be used in PHP programs
ini_set(' session.save_handler', 'memcache');
ini_set('session.save_path', 'tcp://memcached server ip:11211');
Note: This way of using memcached to save the session has nothing to do with session_set_save_handler
After installing memcached
modify session.save_handler to memcache in php.ini, and modify save_path to point to the address and port of memcached
session.save_handler = memcache
session.save_path = tcp://127.0 .0.1:11211
memcache’s PECL extension is very powerful and can support failover and distributed storage.
The method of use is very simple, just use commas to separate each memcached server in the parameter list of session.save_path, such as:
session.save_path = "tcp://172.16.8.81:11211,tcp://172.16. 8.82:11211,tcp://172.16.8.83:11211"
The saved session will be hashed and then saved to each memcached server. Memcache supports two hash algorithms, crc32 and fnv:
memcache.hash_function= {crc32,fnv}
The fnv algorithm is rarely mentioned in the document. It is said that its hashing is better than crc32. However, after I experimented with the following small program, I found that the hashing algorithm of crc32 is still more distributed. average.
<?php ini_set("memcache.hash_function", "crc32"); $memcache = new Memcache; $memcache1 = new Memcache; $memcache2 = new Memcache; $memcache->addServer('localhost', 11211); $memcache->addServer('localhost', 11212); $memcache->flush(); $memcache1->connect('localhost', 11211); $memcache2->connect('localhost', 11212); $fp1 = fopen("mem1.txt", "w"); $fp2 = fopen("mem2.txt", "w"); for ($i = 0; $i < 1000; $i++) { $memcache->set($i, $i, 0, 1000); fwrite($fp1, $memcache1->get($i) . " "); fwrite($fp2, $memcache2->get($i) . " "); } fclose($fp1); fclose($fp2);
Then I tested the session saving
I opened 3 memcached processes for testing
<?php ini_set("memcache.hash_function", "fnv"); ini_set("error_reporting", "E_CORE_ERROR"); $memcache1 = new Memcache; $memcache1->connect('localhost', 11211); $memcache1->flush(); $memcache2 = new Memcache; $memcache2->connect('localhost', 11212); $memcache2->flush(); $memcache3 = new Memcache; $memcache3->connect('localhost', 11213); $memcache3->flush(); $fp1 = fopen('mem1.txt', 'w'); $fp2 = fopen('mem2.txt', 'w'); $fp3 = fopen('mem3.txt', 'w'); for ($i = 0; $i < 1000; $i++) { session_start(); $ssid = session_id(); echo $ssid; session_register("id"); $_SESSION["id"] = $ssid; session_write_close(); fwrite($fp1, $memcache1->get($ssid) . ' '); fwrite($fp2, $memcache2->get($ssid) . ' '); fwrite($fp3, $memcache3->get($ssid) . ' '); //session_destroy(); } fclose($fp1); fclose($fp2); fclose($fp3);
The strange thing is that memcached2 is usually not selected,
and the contents of 1 and 3 are consistent. It may be for failover,
And when I turn off 1 and 3, content will appear in 2, indicating that memcached2 is working normally.
This phenomenon exists regardless of whether my hashing algorithm uses crc32 or fnv.
Finally I found out: there is a problem with this test program.
Because after session_write_close, the session of the entire program is unique.
That is, although the loop has been looped so many times, including the session_destroy call, the session id returned is the same.
This results in the content in the two files being consistent but the other file having no content.
Based on this,
I can only call the script in batches. The script is modified as follows:
<?php ini_set("memcache.hash_strategy", "consistent"); ini_set("memcache.hash_function", "crc32"); ini_set("error_reporting", "E_CORE_ERROR"); ini_set("memcache.allow_failover", "0"); $memcache1 = new Memcache; $memcache1->connect('localhost', 10001); $memcache1->flush(); $memcache2 = new Memcache; $memcache2->connect('localhost', 10002); $memcache2->flush(); $memcache3 = new Memcache; $memcache3->connect('localhost', 10003); $memcache3->flush(); $fp1 = fopen("mem1.txt", "a+"); $fp2 = fopen("mem2.txt", "a+"); $fp3 = fopen("mem3.txt", "a+"); session_start(); $ssid = session_id(); echo $ssid . "\n"; session_register("id"); $_SESSION["id"] = $ssid; //session_destroy(); session_write_close(); fwrite($fp1, $memcache1->get($ssid) . " "); fwrite($fp2, $memcache2->get($ssid) . " "); fwrite($fp3, $memcache3->get($ssid) . " "); session_destroy(); fclose($fp1); fclose($fp2); fclose($fp3);
Then run it repeatedly in the shell. Multiple times, the returned ID is different.
Open the mem*.txt file again to view,
found that among the 3 files, each session will be saved in two of the files, and then the distribution is different.
This proves that memcache is used to save sessions. One is to achieve failover, and the second is to do hash distribution and save according to session id.

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

If you are an experienced PHP developer, you might have the feeling that you’ve been there and done that already.You have developed a significant number of applications, debugged millions of lines of code, and tweaked a bunch of scripts to achieve op

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.

What are the magic methods of PHP? PHP's magic methods include: 1.\_\_construct, used to initialize objects; 2.\_\_destruct, used to clean up resources; 3.\_\_call, handle non-existent method calls; 4.\_\_get, implement dynamic attribute access; 5.\_\_set, implement dynamic attribute settings. These methods are automatically called in certain situations, improving code flexibility and efficiency.
