技术标签: nginx session共享 均衡负载 linux命令
查了一些资料,看了一些别人写的文档,总结如下,实现nginx session的共享
PHP服务器有多台,用nginx做负载均衡,这样同一个IP访问同一个页面会被分配到不同的服务器上,如果session不同步的话,就会出现很多问题,比如说最常见的登录状态,下面提供了几种方式来解决session共享的问题:
1、不使用session,换用cookie
session是存放在服务器端的,cookie是存放在客户端的,我们可以把用户访问页面产生的session放到cookie里面,就是以cookie为中转站。你访问web服务器A,产生了session然后把它放到cookie里面,当你的请求被分配到B服务器时,服务器B先判断服务器有没有这个session,如果没有,再去看看客户端的cookie里面有没有这个session,如果也没有,说明session真的不存,如果cookie里面有,就把cookie里面的sessoin同步到服务器B,这样就可以实现session的同步了。
说明:这种方法实现起来简单,方便,也不会加大数据库的负担,但是如果客户端把cookie禁掉了的话,那么session就无从同步了,这样会给网站带来损失;cookie的安全性不高,虽然它已经加了密,但是还是可以伪造的。
2、session存在数据库(MySQL等)中
PHP可以配置将session保存在数据库中,这种方法是把存放session的表和其他数据库表放在一起,如果mysql也做了集群了话,每个mysql节点都要有这张表,并且这张session表的数据表要实时同步。
说明:用数据库来同步session,会加大数据库的IO,增加数据库的负担。而且数据库读写速度较慢,不利于session的适时同步。
3、session存在memcache或者redis中
memcache可以做分布式,php配置文件中设置存储方式为memcache,这样php自己会建立一个session集群,将session数据存储在memcache中。
说明:以这种方式来同步session,不会加大数据库的负担,并且安全性比用cookie大大的提高,把session放到内存里面,比从文件中读取要快很多。但是memcache把内存分成很多种规格的存储块,有块就有大小,这种方式也就决定了,memcache不能完全利用内存,会产生内存碎片,如果存储块不足,还会产生内存溢出。
4、nginx中的ip_hash技术能够将某个ip的请求定向到同一台后端,这样一来这个ip下的某个客户端和某个后端就能建立起稳固的session,ip_hash是在upstream配置中定义的:
upstream nginx.example.com
{
server 192.168.74.235:80;
server 192.168.74.236:80;
ip_hash;
}
server
{
listen 80;
location /
{
proxy_pass
http://nginx.example.com;
}
}
ip_hash是容易理解的,但是因为仅仅能用ip这个因子来分配后端,因此ip_hash是有缺陷的,不能在一些情况下使用:
1.nginx不是最前端的服务器。
ip_hash要求nginx一定是最前端的服务器,否则nginx得不到正确ip,就不能根据ip作hash。譬如使用的是squid为最前端,那么nginx取ip时只能得到squid的服务器ip地址,用这个地址来作分流是肯定错乱的。
2.nginx的后端还有其它方式的负载均衡。
假如nginx后端又有其它负载均衡,将请求又通过另外的方式分流了,那么某个客户端的请求肯定不能定位到同一台session应用服务器上。这么算起来,nginx后端只能直接指向应用服务器,或者再搭一个squid,然后指向应用服务器。最好的办法是用 location作一次分流,将需要session的部分请求通过ip_hash分流,剩下的走其它后端去。
5、upstream_hash
为了解决ip_hash的一些问题,可以使用upstream_hash这个第三方模块,这个模块多数情况下是用作url_hash的,但是并不妨碍将它用来做session共享。没试过真心的不明白
补充:memcached简单的介绍
一、概念
Memcached是danga.com(运营LiveJournal的技术团队)开发的一套分布式内存对象缓存系统,用于在动态系统中减少数据库负载,提升性能。
二、适用场合
1. 分布式应用。由于memcached本身基于分布式的系统,所以尤其适合大型的分布式系统。
2. 数据库前段缓存。数据库常常是网站系统的瓶颈。数据库的大并发量访问,常常造成网站内存溢出。当然我们也可以使用Hibernate的缓存机制。但memcached是基于分布式的,并可独立于网站应用本身,所以更适合大型网站进行应用的拆分。
3. 服务器间数据共享。举例来讲,我们将网站的登录系统、查询系统拆分为两个应用,放在不同的服务器上,并进行集群,那这个时候用户登录后,登录信息如何从登录系统服务器同步到查询系统服务器呢?这时候,我们便可以使用memcached,登录系统将登录信息缓存起来,查询系统便可以获得登录信息,就像获取本地信息一样。
三、不适用场合
那些不需要“分布”的,不需要共享的,或者干脆规模小到只有一台服务器的应用,memcached不会带来任何好处,相反还会拖慢系统效率,因为网络连接同样需要资源
解决方案,使用memcached做为session的存储,memcached服务器设置在和nginx同一台linux主机上。
解决过程,
两台apache的主机IP分别是 192.168.74.235192.168.74.236
Nginx主机IP是192.168.74.131
Memcached主机的IP是192.168.74.131
在192.168.74.131 安装memcached,并且启动
以一台为例192.168.74.236,安装php及php对memcached的依赖库yuminstall memcached-devel.i686 libmemcached-devel.i686 php-pecl-memcache.i686
配置php.ini
session.save_handler= memcache
session.save_path= "tcp://192.168.74.131:11211"
或者(以下两个没有尝试)
1.某个目录下的 .htaccess :
php_value session.save_handler "memcache"
php_value session.save_path "tcp://IP:11211"
2.在某个一个应用中:
ini_set("session.save_handler", "memcache");
ini_set("session.save_path", "tcp://IP:11211");
同时一定要把下面的;session.save_path= "/var/lib/php/session" 注释掉
同时把extension=memcache.so 打开
重启一下 apache,查看 phpinfo 中的 "Registered save handlers" 会有 "files usermemcache" 这3个可用,如果有就证明装好了
Memcached服务器执行及结果
[root@Git ~]# memcached-tool127.0.0.1:11211
# Item_Size Max_age Pages Count Full? Evicted Evict_Time OOM
在236机器上添加下面的php文件
<?php
session_start();
if (!isset($_SESSION['TEST'])) {
$_SESSION['TEST'] = time();
}
$_SESSION['TEST3'] = time();
print $_SESSION['TEST'];
print "<br><br>";
print $_SESSION['TEST3'];
print "<br><br>";
print session_id();
?>
然后去memcached服务器上执行
[root@Git ~]# memcached-tool127.0.0.1:11211
# Item_Size Max_age Pages Count Full? Evicted Evict_Time OOM
1 80B 0s 1 0 no 0 0 0
这样应该就算可以把session写到memcached服务器上了。
总结下:
1. 防火墙问题,很多连接局域网服务器失败都是防火墙引起的
2. 依赖没有安装完毕,一开始使用memcached总失败,因为我没有安装php-memcached这样的扩展库
文章浏览阅读133次。phper 都知道 php-extension 采用 C/C++ 编写.由于 C/C++ 开发效率问题我们来采用 golang 编写 php-extension充分利用 golang 的开发效率和生态给 PHP 添砖加瓦.环境准备wsl ubuntugolang 1.13php 7.3新建项目php7.3 里面的 ext_skel 和以前版本参数不一样,请查看 help 操作php:./ext..._封装一个go的扩展给php程序调用
文章浏览阅读2.6k次,点赞2次,收藏3次。python 删除print()两个输出语句之间的空格。回文诗:静思伊久阻归期忆别离时闻漏转。_print中间有空格
文章浏览阅读335次,点赞6次,收藏7次。(2)如果n <> k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步。System.out.print( "请键入一个正整数: ");(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。
文章浏览阅读1k次。Caktus AI是一个AI写作助手。它会将您的文本输入变成一个完整的家庭作业答案。您可以使用 Caktus 撰写论文解决数学问题和编写代码。该工具有免费试用版和负担得起的计划,供学生无限制使用。简而言之,该工具在几秒钟内生成了大部分原创和独特的内容。它易于使用,但它在令人信服的语气中也犯了一些错误。Caktus 非常适合学生作为 AI 辅助工具,以帮助进行锻炼并提高生产力。该工具可以从头到尾完成练习,但会犯一些错误,有时会生成非原始文本。_caktus ai
文章浏览阅读2.9k次,点赞2次,收藏3次。jquery中的$(“#id”)与document.getElementById(“id”)的区别以前一直认为jquery中的$(“#id”)和document.getElementByIdx_x(“id”)得到的效果是一样的,今天做特效的时候才发现并不是这么一回事,通过测试得到:1、alert($(“#div”))得到的是[object Object]2、alert(document_js对象中使用jq
文章浏览阅读995次。原文_unity100题
文章浏览阅读5.2k次,点赞9次,收藏48次。修炼一途,乃窃阴阳,夺造化,转涅槃,握生死,掌轮回。武之极,破苍穹,动乾坤!! ——《武动乾坤》_cv任务
文章浏览阅读3k次,点赞9次,收藏43次。matlab实现读取图片头文件信息,图片三等分及灰度图绘制医学图像处理教材示例一此文章是医学图像处理与分析第二版教材示例一代码1 解读下面图像的文件头和位图信息数据程序如下clearfid=fopen('示例一.bmp','r');fileinfo=(fread(fid,54)); %此处54为读取行数读取结果为一个列矩阵每行对应结果如图。15行之后还有其他数据,..._医学图像处理与分析课本示例代码答案
文章浏览阅读5.5k次。索尼BRAVIA一直以来坚持优秀的音画体验得以成为行业发展的风向标,在进入智能时代之后,丰富有趣的功能体验也倍受关注。今年的索尼BRAVIA高端新品都搭载了Android TV 8.0,在内容丰富性和操作上都有了更出色的体验。图1.jpg (98.61 KB)2020-7-18 09:38 上传索尼BRAVIA智能电视除了能够提供优质丰富的在线流媒体资源,还能将智能手机上的内容通过第三方应用投屏到..._mac连接索尼电视 声音断续
文章浏览阅读5.1k次,点赞9次,收藏41次。Python结构化数据分析工具Pandas之Pandas概览_python中只能表示结构化算法的算法描述工具
文章浏览阅读4.4k次。这个错误是由于 PostgreSQL 不支持直接将 varchar 类型转换为 double precision 类型,需要先将该字段的 varchar 类型转换为 numeric 类型,再将 numeric 类型转换为 double precision 类型。注意:这两个语句执行后,原来表中的数据类型会被修改为 FLOAT 类型,如果原来的数据不是有效的浮点数,转换过程中可能会出现错误。请注意,这里的转换可能会因为数据类型不匹配而失败,需要先备份好数据再进行操作。_pgsql 修改字段类型
文章浏览阅读228次。Ottawa公共汽车公交车模型3D图纸 Solidworks设计 附STEP。倒骑驴三轮车简易模型3D图纸 Solidworks设计 附STEP。荷兰铁路欧洲快车模型3D图纸 Solidworks设计 附工程图。仓库托盘运输小车3D图纸 Solidworks设计 附STEP。摩托车前悬架3D数模图纸 Solidworks设计 附IGS。蒸汽机车模型3D图纸 Solidworks设计 附平面图。简易宝马X5汽车3D模型图纸 Solidworks设计。拖车结构3D图纸 Solidworks设计 附STEP。_agv机器人3d模型