nginx 之负载均衡 :PHP session 跨多台服务器配置

公司一个项目单点压力越来越大,考虑到稳定性和降压,使用nginx做负载均衡,将请求分发到多个docker上去,这里记录下PHP多服务器间的会话session共享问题,解决方案是把session单独存在一台redis上面。

LB nginx配置:

upstream allserver{
        server 127.0.0.1:8081 weight=1;
        server 127.0.0.1:8082 weight=1;
        server 127.0.0.1:8083 weight=1;
}
server
    {
        listen 80;
        #listen [::]:80;
        server_name www.sessiontest.com ;

        #error_page   404   /404.html;
error_log  /data/logs/nginx/www.sessiontest.com_error.log ;
access_log /data/logs/nginx/www.sessiontest.com.log ;   
    #设定查看Nginx状态的地址
    location /nginxstatus{
         stub_status on;
         access_log on;
         auth_basic "nginxstatus";
         auth_basic_user_file htpasswd;
    }
    #匹配以jsp结尾的,tomcat的网页文件是以jsp结尾
    location / {
        index index.php;
        proxy_pass   http://allserver;    #在这里设置一个代理,和upstream的名字一样
        #以下是一些反向代理的配置可删除
        proxy_redirect             off; 
        #后端的Web服务器可以通过X-Forwarded-For获取用户真实IP
        proxy_set_header           Host $host; 
        proxy_set_header           X-Real-IP $remote_addr; 
        proxy_set_header           X-Forwarded-For $proxy_add_x_forwarded_for; 
        client_max_body_size       10m; #允许客户端请求的最大单文件字节数
        client_body_buffer_size    128k; #缓冲区代理缓冲用户端请求的最大字节数
        proxy_connect_timeout      300; #nginx跟后端服务器连接超时时间(代理连接超时)
        proxy_send_timeout         300; #后端服务器数据回传时间(代理发送超时)
        proxy_read_timeout         300; #连接成功后,后端服务器响应时间(代理接收超时)
        proxy_buffer_size          4k; #设置代理服务器(nginx)保存用户头信息的缓冲区大小
        proxy_buffers              4 32k; #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
        proxy_busy_buffers_size    64k; #高负荷下缓冲大小(proxy_buffers*2)
        proxy_temp_file_write_size 64k; #设定缓存文件夹大小,大于这个值,将从upstream服务器传
    }

}

docker 是使用docker-compose编排的

version: '2'

services:
  phpserver1:
    image: webdevops/php-nginx:latest
    ports:
      - "8081:80"#
    links:
      - redis
    depends_on:
      - redis
    volumes:
      - /data/docker/app1:/app

  phpserver2:
    image: webdevops/php-nginx:latest
    ports:
      - "8082:80"#
    links:
      - redis
    depends_on:
      - redis
    volumes:
      - /data/docker/app2:/app

  phpserver3:
    image: webdevops/php-nginx:latest
    ports:
      - "8083:80"#
    links:
      - redis
    depends_on:
      - redis
    volumes:
      - /data/docker/app3:/app

  redis:
    image: redis
    ports:
      - 6379:6379

使用docker-compose up 启动

data目录结构

不使用redis时的PHP文件

我们先只开启server1的session赋值

请求前端域名可以发现

只有server1的session id 打印了,session不共享

接下来在每个PHP脚本都设置使用redis保存session

同样只打开server1的session id 写入

再次请求前端url

可以看到server1设置过session id值后,负载到其他server时同样可以使用同一个会话session

PHP session 配置还可以写在php.ini中

session.save_handler = redis
session.save_path = "tcp://redis:6379?auth=passwd"

  

注意如果redis配置了密码的话后面要加auth 验证

除了redis,还支持memcache,mysql

具体可以参考这篇博客

https://www.jianshu.com/p/43a061a4c997

 

原文地址:https://www.cnblogs.com/timseng/p/11003274.html