Home > Backend Development > PHP Tutorial > Detailed explanation of session sharing cases under load balancing in PHP (with code)

Detailed explanation of session sharing cases under load balancing in PHP (with code)

php中世界最好的语言
Release: 2023-03-26 06:46:01
Original
2412 people have browsed it

This time I will bring you a detailed explanation of session sharing cases under PHP load balancing (with code). What are the precautions for PHP to realize session sharing under load balancing? , the following is a practical case, let’s take a look.

First let’s talk about load balancing. I believe everyone knows that load balancing can effectively solve the problem of large website traffic. Load balancing is to distribute user requests to polymorphic PCs for processing. Since the requests are distributed, then You must consider how to handle the session. Traditionally, PHP will store the session in the local temporary file. However, in this case, the session will be lost after distribution. In fact, the simplest solution is to use memcache to host it separately. Set up a server as a memcache server (it is best to have a larger memory), and leave the next work to PHP code. I don’t want to modify php.ini here, because each It would be too tiring to change them all, and I am lazy. Maybe you will tell me that I can write to memcache by directly modifying the session storage location of

php.ini

. Yes, that’s right. , but this method cannot call gc to release the expired session, and what we want to say today is not only to let it be hosted, but also to let it automatically release the session. Since we have to do it, we have to do it It has to be perfect. Below is my code. If you don’t know how to read the comments yourself:

$_ENV=array(
  'SYS'=>array(
    'Memip'=>'127.0.0.1',      //MEMCACHE的ip
    'Mempt'=>11211,       //MEMCACHE的port
    'Memtim'=>10,          //MEMCACHE的超時時間
  )
);
//托管SESSION到MEMCACHE,如果开启失败,则说明MEMCACHE没有配置正确
final class S{
  public static function open(){
  //禁止session自动开启
    session_write_close();
  ini_set('session.auto_start',0);
  //使用五十分之一的概率启动gc清理会话
  ini_set('session.gc_probability',1);
  ini_set('session.gc_pisor',50);
  ini_set('session.use_cookies',1);
  //session的寿命
  //ini_set('session.gc_maxlifetime',$_ENV['SYS']['Memtim']);
  //ini_set('session.cookie_lifetime',$_ENV['SYS']['Memtim']);
  //ini_set('session.save_handler','files');
  //ini_set('session.save_path',Run.'_tmp');
  //ini_set('session.save_handler','memcache');
  //ini_set('session.save_path','tcp://127.0.0.1:11211');
    //$_ENV['S_tim'] = ini_get('session.gc_maxlifetime');
  //建立memcache对象
  $_ENV['S_mem']=new Memcache;
  $_ENV['S_mem']->connect($_ENV['SYS']['Memip'],$_ENV['SYS']['Mempt']) or die('Memcache連接失敗!');
    return TRUE;
  }
  /**
    读取
    返回:读到的內容
  /**/
  public static function read($id){
    return $_ENV['S_mem']->get('s_'.$id);
  }
  /**
    写入
    返回:bool
  /**/
  public static function write($id,$data){
    return $_ENV['S_mem']->set('s_'.$id,$data,MEMCACHE_COMPRESSED,$_ENV['SYS']['Memtim']);
  }
  /**
    关闭
    返回:bool
  /**/
  public static function close(){
    $_ENV['S_mem']->close();
    unset($_ENV['S_mem'],$_ENV['SYS']['Memtim']);
    return TRUE;
  }
  /**
    刪除
    返回:bool
  /**/
  public static function destroy($id){
    return $_ENV['S_mem']->delete('s_'.$id);
  }
  /**
    清理
    返回:bool
  /**/
  public static function gc(){
    return TRUE;
  }
}
session_set_save_handler('S::open','S::close','S::read','S::write','S::destroy','S::gc');
$_ENV['sessionid']=(isset($_REQUEST['sessionid'])) ? trim($_REQUEST["sessionid"]) : session_id();
if($_ENV['sessionid']!=''){session_id($_ENV['sessionid']);}
session_start();
Copy after login

I believe you have mastered the method after reading the case in this article. For more exciting information, please pay attention to other related articles on the PHP Chinese website!

Recommended reading:

Detailed explanation of steps to use encryption of php-app development interface


php curl with csrf-token verification Detailed explanation of simulated submission examples

The above is the detailed content of Detailed explanation of session sharing cases under load balancing in PHP (with code). For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template