The content of this article is about PHP realizing multi-server SESSION sharing, which has certain reference value. Now I share it with everyone. Friends in need can refer to it
Nowadays, slightly larger websites basically have several subdomains, such as www.feiniu.com, search.feiniu.com, member.feiniu.com, if these websites need to share user login information, they need to share sessions. Of course, the premise is that they have the same main domain.
The client accesses the php page, executes session_start, and generates the session_id. Generally, we store the session_id on the cookie, and the session content is saved on the server. The client access is different. All pages will pass the session_id to the server, and obtain the session content through the session_id.
The process is like this, but different servers will generate different session_ids for the same client, so different servers cannot get the same session content. Moreover, PHP's default SESSION data is stored separately in the file system of this server.
So if we want to solve session sharing, we must solve two problems:
1. Multiple servers use the same session_id
这个比较容易解决,只要在php中设置存session_id的cookie域名为网站主域就可以了 打开PHP.ini, 设置session.cookie_domain = .feiniu.com, 当然也可以在php代码当中设置ini_set("session.cookie_domain","feiniu.com");
1
2
Memcached will not bring any benefits to those applications that do not need to be "distributed", do not need to be shared, or are simply small enough to have only one server. On the contrary, it will slow down the system efficiency. Because network connections also require resources. redis storage: Compared with memcache, redis access is slightly slower. The benefits are: redis supports many data structures and can store arrays or objects, while memcache can only store strings In the case of restarting the session machine, all users of memcache must regain the session , and redis will not When a large number of users suddenly come in and generate a lot of data, which fills up the memory of the machine storing the session, memcache will go on strike and all keys will not expire. It will continuously overwrite the last written data, and redis will only slow down and will not affect the logic of the program Related recommendations: PHP implementation Method of NFS sharing for multi-server session sharing_PHP tutorial The above is the detailed content of PHP implements multi-server SESSION sharing. For more information, please follow other related articles on the PHP Chinese website!要实现这点,就必须把session内容存储到让所有服务器都能访问到的地方,php的session内容是默认存储到本服务器的文件中的,一般的解决方案是存入数据库,memcache或者redis这种缓存服务器,当然用默认的文件存储方式也可以,用NFS统一存储。
如何修改session存储引擎,参考这篇文章:http://blog.csdn.net/yagas/article/details/7593415
1
3. How to choose a storage engineDefault file storage: This method of session destruction relies on the PHP garbage collector, in the case of high concurrency or long destruction time , a large number of files are generated in the SESSION directory. Of course, you can set up a hierarchical directory to save SESSION files. This will cause two problems: first, it is slow to find files; second, the number of files that can be accommodated in each directory is limited, which may cause the new SESSION to fail to be stored.
# Synchronizing sessions in this way will not increase the burden on the database, and The security is relatively high. Putting the session in the memory is much faster than reading from the file.