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
PHP realizes multi-server SESSION sharing
Why session sharing is required
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.
PHP session principle
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
- ##3 ##4
要实现这点,就必须把session内容存储到让所有服务器都能访问到的地方,php的session内容是默认存储到本服务器的文件中的,一般的解决方案是存入数据库,memcache或者redis这种缓存服务器,当然用默认的文件存储方式也可以,用NFS统一存储。
如何修改session存储引擎,参考这篇文章:http://blog.csdn.net/yagas/article/details/7593415
- 1
- 2
- 3
- 4
- Default 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.
- Database storage: Storing the session in the database can prevent the session data from being deleted by the garbage collector, and can solidify and store the session data. However, using a database to synchronize sessions will increase the IO of the database and increase the burden on the database. Moreover, the database reading and writing speed is slow, which is not conducive to timely synchronization of sessions.
- memcache storage:
- But memcache divides the memory into storage blocks of many specifications. Each block has a size. This method also determines that memcache cannot fully utilize the memory and will produce memory fragmentation. If Insufficient storage blocks may cause memory overflow
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
- # 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.
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!

TooptimizePHPcodeforreducedmemoryusageandexecutiontime,followthesesteps:1)Usereferencesinsteadofcopyinglargedatastructurestoreducememoryconsumption.2)LeveragePHP'sbuilt-infunctionslikearray_mapforfasterexecution.3)Implementcachingmechanisms,suchasAPC

PHPisusedforsendingemailsduetoitsintegrationwithservermailservicesandexternalSMTPproviders,automatingnotificationsandmarketingcampaigns.1)SetupyourPHPenvironmentwithawebserverandPHP,ensuringthemailfunctionisenabled.2)UseabasicscriptwithPHP'smailfunct

The best way to send emails is to use the PHPMailer library. 1) Using the mail() function is simple but unreliable, which may cause emails to enter spam or cannot be delivered. 2) PHPMailer provides better control and reliability, and supports HTML mail, attachments and SMTP authentication. 3) Make sure SMTP settings are configured correctly and encryption (such as STARTTLS or SSL/TLS) is used to enhance security. 4) For large amounts of emails, consider using a mail queue system to optimize performance.

CustomheadersandadvancedfeaturesinPHPemailenhancefunctionalityandreliability.1)Customheadersaddmetadatafortrackingandcategorization.2)HTMLemailsallowformattingandinteractivity.3)AttachmentscanbesentusinglibrarieslikePHPMailer.4)SMTPauthenticationimpr

Sending mail using PHP and SMTP can be achieved through the PHPMailer library. 1) Install and configure PHPMailer, 2) Set SMTP server details, 3) Define the email content, 4) Send emails and handle errors. Use this method to ensure the reliability and security of emails.

ThebestapproachforsendingemailsinPHPisusingthePHPMailerlibraryduetoitsreliability,featurerichness,andeaseofuse.PHPMailersupportsSMTP,providesdetailederrorhandling,allowssendingHTMLandplaintextemails,supportsattachments,andenhancessecurity.Foroptimalu

The reason for using Dependency Injection (DI) is that it promotes loose coupling, testability, and maintainability of the code. 1) Use constructor to inject dependencies, 2) Avoid using service locators, 3) Use dependency injection containers to manage dependencies, 4) Improve testability through injecting dependencies, 5) Avoid over-injection dependencies, 6) Consider the impact of DI on performance.

PHPperformancetuningiscrucialbecauseitenhancesspeedandefficiency,whicharevitalforwebapplications.1)CachingwithAPCureducesdatabaseloadandimprovesresponsetimes.2)Optimizingdatabasequeriesbyselectingnecessarycolumnsandusingindexingspeedsupdataretrieval.


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

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

Zend Studio 13.0.1
Powerful PHP integrated development environment

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software
