我有 2 台运行 PHP 和 Nginx 的 Web 服务器……而且我有 1 台 Redis 服务器。我希望 Web 服务器将 Redis 数据库用于用户登录数据。这将允许我扩展 Web 服务器,而无需强制登录用户在他们访问新服务器时重新进行身份验证。
两台 PHP/Nginx 服务器都使用 Redis 进行会话处理,并且它们都指向同一个 Redis 数据库。当我在浏览器中访问任一站点时,它会生成一个会话令牌并将其存储在 Redis 中(总共创建两个 Redis 密钥)......但是我想要的是在访问站点 #1 时创建一个新会话,将会话存储在Redis,并在我访问时让站点 #2 认出我,因为它查询 Redis(因此总共只有一个 Redis 密钥)。
我的所有 3 台服务器都在 AWS 中,在同一个 VPC 中。我使用内部 IP 地址与 Web 服务器和 Redis 进行通信(因此对机器有一定程度的信任)。
我显然在这里遗漏了一些东西,它可能是负载均衡器(我将实现)。但我试图用最少的组件开发一个 Redis 共享设计。此外,我不完全确定负载平衡器有助于解决这个问题。
以下是代码的相关部分:
PHP/Nginx 服务器:(x2)
(1) /etc/php/7.2/fpm/php.ini
session.save_handler = redis
session.save_path = "tcp://10.xxx.xx.xxx:6379" // both web servers point to the same Redis IP address
(2) /var/www/html/test.php
<?php
ini_set('session.save_handler', 'redis'); // redundant; including for completeness
ini_set('session.save_path', 'tcp://10.xxx.xx.xxx:6379'); // redundant; including for completeness
session_name('FOOBAR');
session_start();
echo nl2br(
'<pre>' . session_save_path() . '</pre>' . PHP_EOL
);
echo nl2br(
'Running PHP version: ' . phpversion() . PHP_EOL
);
if (!array_key_exists('visit', $_SESSION)) {
$_SESSION['visit'] = 0;
}
$_SESSION['visit']++;
echo nl2br(
'You have been here ' . $_SESSION['visit'] . ' times.'
);
Redis 服务器:(x1)
(3) /etc/redis/redis.conf
bind 0.0.0.0
当我点击这两个站点的test.php页面时,它们成功地生成了自己的会话并将其存储在 Redis 数据库中。而且他们正确地增加了他们各自的会话令牌......但我希望这些网络服务器与他们共享 Redis 会话数据,所以他们“记住”所有登录的用户(即使这是用户第一次访问给定的网络服务器)。
谢谢!
编辑:我还尝试手动查询 Redis 以获取登录用户数据。这产生了与上面的test.php相似的结果。每个网站最终都创建和管理了自己的会话令牌。
PHP/Nginx 服务器:(x2)
(4) /var/www/html/redis-check.php
<?php
$cookie = "PHPREDIS_SESSION:" . $_COOKIE['FOOBAR'];
// Connecting to Redis server on localhost
$redis = new Redis();
$redis->connect('10.xxx.xx.xxx', 6379);
echo "Connection to server sucessfully";
echo '<br />';
// Check if cookie value exists in Redis
$seenuser = $redis->get($cookie);
if( !empty($seenuser) )
{
echo 'Hello, old friend!<br />';
echo '<br />';
echo 'Cookie Value: ' . $cookie;
echo '<br />';
echo 'Session Value: ' . $seenuser;
}
else
{
// This is a new user, so create a new session
ini_set('session.save_handler', 'redis'); // redundant; including for completeness
ini_set('session.save_path', 'tcp://10.xxx.xx.xxx:6379'); // redundant; including for completeness
session_name('FOOBAR');
session_start();
if (!array_key_exists('visit', $_SESSION))
{
$_SESSION['visit'] = 0;
}
$_SESSION['visit']++;
$cookie = "PHPREDIS_SESSION:" . $_COOKIE['FOOBAR'];
$seenuser = $redis->get($cookie);
echo 'New Login<br />';
echo '<br />';
echo 'Cookie Value: ' . $cookie;
echo '<br />';
echo 'Session Value: ' . $seenuser;
}