博客
关于我
memcache实现php会话保持
阅读量:799 次
发布时间:2023-02-08

本文共 2389 字,大约阅读时间需要 7 分钟。

Haproxy RR轮询调度与PHP会话管理优化配置实践

实验目标

通过配置Haproxy实现RR轮询调度,将用户会话ID保持不变,实现两台lamp服务器的负载均衡。

版本信息

  • Haproxy版本:haproxy-1.5.4-3.el6.x86_64(yum安装)
  • memcached版本:memcache-1.4.15-9.el7_2.1.x86_64(yum安装)
  • LAMP环境:httpd-2.4.9、mariadb-5.5.36、php-5.4.26(编译安装)
  • PHP memcache扩展:memcache-2.2.7(编译安装)

环境搭建

PHP安装(其他安装步骤可略)

  • 编译配置:
  • ./configure --prefix=/usr/local/php-5.2.26 --with-mysql=/usr/local/mysql --with-openssl --with-mysqli=/usr/local/mysql/bin/mysql_config --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --enable-sockets --enable-fpm --with-mcrypt --with-config-file-path=/etc --with-config-file-scan-dir=/etc/php-5.2.26 --with-bz2
    1. memcache扩展安装:
    2. tar xf memcache-2.2.7.tgzcd memcache-2.2.7./configure --with-php-config=/usr/local/php/bin/php-config --enable-memcache --make install
      1. 修改php.ini:
      2. extension=/usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/memcache.so

        LAMP虚拟机配置

      3. httpd配置:
      4. VirtualHost 192.168.1.30:80  DocumentRoot "/www/test1.com"  ErrorLog "logs/dummy-test1.com-error_log"  CustomLog "logs/dummy-test1.com-access_log" common  
        Require all granted ProxyRequests Off ProxyPassMatch ^/(.*\.php)$ fcgi://192.168.1.30:9000/www/test1.com/$1
        1. 启用模块:
        2. LoadModule proxy_module modules/mod_proxy.soLoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so
          1. 修改配置:
          2. DirectoryIndex index.php index.htmlInclude /etc/httpd-2.4.9/extra/httpd-vhosts.confAddType application/x-httpd-php-source .phpsAddType application/x-httpd-php .php

            PHP与Memcache连接测试

          3. 测试脚本:
          4. connect("192.168.1.25", 11211) or die("Could not connect");$version = $mem->getVersion();echo "Server's version: " . $version . "\n";$mem->set('hellokey', 'Hello World', 0, 600) or die("Failed to save data at the memcached server");echo "Store data in the cache (data will expire in 600 seconds)\n";$get_result = $mem->get('hellokey');echo "$get_result is from memcached server.";?>

            访问01.php,若显示“Hello World is from memcached server”则连接成功。

            会话存储到Memcache

            修改php.ini:

            session.save_handler = memcachesession.save_path="tcp://192.168.1.25:11211"

            Haproxy配置

          5. Main frontend配置:
          6. frontend main *:80  default_backend app  backend app    balance roundrobin    server app1 192.168.1.13:80 check    server app2 192.168.1.30:80 check

            测试与验证

          7. 测试脚本:
          8. " . "192.168.1.13 web server";?>

            访问02.php,观察输出结果区分两台lamp服务器IP地址。

            通过以上配置和测试,验证haproxy RR轮询调度与PHP会话管理的正确性,确保用户会话ID保持不变。

    转载地址:http://qqyfk.baihongyu.com/

    你可能感兴趣的文章
    mysql 常用
    查看>>
    MySQL 常用列类型
    查看>>
    mysql 常用命令
    查看>>
    Mysql 常见ALTER TABLE操作
    查看>>
    MySQL 常见的 9 种优化方法
    查看>>
    MySQL 常见的开放性问题
    查看>>
    Mysql 常见错误
    查看>>
    mysql 常见问题
    查看>>
    MYSQL 幻读(Phantom Problem)不可重复读
    查看>>
    mysql 往字段后面加字符串
    查看>>
    mysql 快照读 幻读_innodb当前读 与 快照读 and rr级别是否真正避免了幻读
    查看>>
    MySQL 快速创建千万级测试数据
    查看>>
    mysql 快速自增假数据, 新增假数据,mysql自增假数据
    查看>>
    MySql 手动执行主从备份
    查看>>
    Mysql 批量修改四种方式效率对比(一)
    查看>>
    Mysql 报错 Field 'id' doesn't have a default value
    查看>>
    MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
    查看>>
    Mysql 拼接多个字段作为查询条件查询方法
    查看>>
    mysql 排序id_mysql如何按特定id排序
    查看>>
    Mysql 提示:Communication link failure
    查看>>