反向代理/负载均衡/session/cookie

2021-12-10 10:02:36
摘要:正向代理:客户端将流量重定向到burpsuite等软件或连接到VPN再访问服务器而不是直接访问服务器的场景。流量流动方向是真正机器--代理服务器。正向代理又称代理、普通代理。

正向代理:客户端将流量重定向到burpsuite等软件或连接到VPN再访问服务器而不是直接访问服务器的场景。流量流动方向是真正机器--代理服务器。正向代理又称代理、普通代理。


反向代理:服务器端使用反向代理服务器统一接收客户端访问,然后再按即定规则将数据包重定向到真正的服务器的场景。流量流动方向是代理服务器--真正机器,与正向代理正好相反所以称反向代理(其实我觉得这此名词应是先有代理再有反向代理再有正向代理)。


相互关系:除了名词相反外,由于代理是客户端行为反向代理是服务端行为所以可以随意使用,在技术上两不相干。



假设客户端代理访问了有反向代理的服务器:


C--客户端;PC--客户端代理服务器;PS--服务端代理服务器;S--服务器


发出数据包机器(方向从左向右) C PC PS

所发出数据包中的源IP和端口 C PC PS

所发出数据包中的目的IP和端口 PC PS S

发出数据包机器(方向从左向右) S PS PC

发出数据包的源IP和端口 S PS PC

发出数据包的目的IP和端口 PS PC C



这个例子要再次声明这样的原则:对于网络中的一跳,其从上一跳接收的数据包中的目的地址一定是它,其发往下一跳的数据包中的源地址一定是它;这不会因为包括其本身用途在内的任何原因而改变。


所以以PS为例,其收到的数据包目的地址一定是PS然后再由其重新封装数据包将目的地址改为S,而不可能PS收到的数据包的目的地址直接是S;即便它只是纯粹向S转发数据包的代理服务器。


PS要和外网交流又要和内网交流,所以其需要一张外网网卡和一张内网网卡。



负载均衡:以一设备统一接收客户端请求再按即定规则从多台相同服务器从选出一台将数据包重定向到这台服务器上的场景。


负载均衡可以理解为反向代理的子集,其在反向代理中加入了“多台相同服务器”的限定;当然你要说“不同服务器”(如一台JSP服务器和一台PHP服务器使用NGINX做反向代理)的反理也可以叫负载均衡那我也觉没什么问题。



软负载和硬负载:


软负载:就是通过软件来实现负载均衡功能;Nginx和httpd等http服务器都能实现软负载功能。


硬负载:又叫硬件负载,就是把实现负载均衡功能的软件搬到一台专门的计算机上;比如F5等设备。


软负载与硬负载的区别和软件防火墙与硬件防火墙的区别是一样的。



负载均衡与会话同步:


在负载均衡中可以将来自同一个IP的访问通过IP_HASH等方式全定向到一台机器上。这样一来所有会话(session)就全在一台机器上,就不必使用会话同步了。


但IP_HASH的问题是如果某台服务器故障而请求一样被发送过去,那么这些访问请求被发送到故障机的IP将无法得到服务,我的服务器分明还有多台正常而我的用户却只因一台故障即不能访问,这并不能最大化多台服务器的效益。


会话中保存着用户的登录状态,而如果请求是按即定算法被分配到不确定的服务器上那么就得保证会话同步,以确保在S1上登录过的用户其请求被重定向到S2时其状态也是登录的(而不是又让用户再次登录这样的网站没人愿意用)。


会话同步实现的思路是无论哪台服务器的session都存放到一台服务器上,请求无论被分配到S1还是S2都是到那台服务器上取session。


而在session服务器的存储又有两种方案,一是使用oracle等传统数据库存储,二是使 用memcache等内存数据库存储;后者方案是更加推荐的。



session比cookie更安全吗?


所谓的cookie不安全主要是指用户名/密码/登录状态等会话信息全部存在了cookie中,一是cookie被盗那么信息泄漏得多,二是如果以登录状态值标识用户登录状态从而决定是否有操作权限那么完全可能是伪造cookie实现越权。


session一般是生成一个sessionID存放到cookie中,如果cookie被盗那么攻击者一样是可以使用该sessionID登录的,只是说没泄漏用户名等信息伪造sessionID也不能伪造其登录状态(这两点安全性就提高好多了)。



禁用cookie后session就不能用了吗?


session的根本原理是以一个sessionID标识用户,客户端无论从哪把sessionID传到服务器都是可以的不一定要通过cookie,这是严谨但不负责任的回答。


在一般的session实现中我们生成sessionID并将其put到cookie中,由于是cookie是自动提交的所以,我们在设计客户端请求时完全不用考虑sessionID的上传。


如果我们不将sessionID放到cookie,那么再没第二个和cookie这样自动下传又自动上传的字段,这意味着如果不通过cookie那么在服务端下传后在客户端请求时需要手动将sessionID附到某个字段中。


轻则要附到URL中作为参数,重则要js将sessionID附到http头的其他字段中或post的body中;一两个页面还没什么,要是全站使用和考滤网站扩展性,这工作量并不是可以轻描淡写。


所心结论是禁用cookie后session还是有方法可以实现的,但这比较麻烦。


你觉得这篇文章怎么样?

65 0

我们立足于合肥面向安徽乃至全国全球市场,我们拥有一支经验丰富、创意独到、团结协作的专业技术团队。我们立志把最好的技术通过最有效、最简单的方式提供给客户,为客户提供最佳的解决方案,我们将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,帮助客户在新经济时代下,把握商机和发展空间,并获得绝对的竞争力!我们专注于高端网站定制、系统开发、商城开发、外贸网站建设、公众号开发、小程序开发、网站优化推广、安全运维等技术领域。是高端定制网站领域著名服务商!

扫描二维码与小二CMS创始人沟通

7*24小时为您服务

小二CMS专注于高端网站定制、系统开发、商城开发、外贸网站建设、公众号开发、小程序开发、网站优化推广、安全运维等技术领域。是高端定制网站领域著名服务商!

本文标题:反向代理/负载均衡/session/cookie
免责声明:文章《反向代理/负载均衡/session/cookie》来至网络,文章表达观点不代表本站观点,文章版权属于原作者所有,若有侵权,请联系本站站长处理!
关于我们

建站190专注于高端网站建设服务及定制,拥有丰富的企业网站建站经验。 近年来制作并完成了许多网站建设案例,企业品牌官网、营销型网站的建设、B2C网上商城系统开发、行业门户网站等平台开发,我们还提供了网站的策划、设计、开发、布署、安全等一站式专业的网站建设解决方案。建站190致力于研发国内最专业、功能最强大,扩展性能最自由灵活的高端行业通用的网站系统。我们做的不仅仅是网站系统,更多的是成就您的成功!

我们的优势

十三年建站服务经验
服务3000家企业
资深行业分析策划
前沿视觉设计、研发能力
前端代码深度符合SEO优化
千家成功案例

独家源码出售
具有完备的项目管理
完善的售后服务体系
深厚的网络运营经验
时刻新技术领先研发能力
方便二次开发

我们的不同

我们是一个年轻且富有激情的团队,我们沉迷于代码并陶醉在设计之中。我们非设计,不生活;无兄弟,不编程!可年轻并不意味着没有经验。团队成员均来自各顶尖设计公司及软件公司,我们对网站设计及开发驾轻就熟,有着数百个成功案例。我们坚信用心服务,用实力说话!我们的使命:通过我们的努力,让技术改变命运!我们的宗旨:客户第一,品质至上!我们的信念:唯有客户的成功,才是我们的成功!

不忘初心,方得始终
中高端网站定制开发服务商
与我们取得联系

好作品自己会说话,

我们敬畏您给予的点滴信任 !

期待携手合作,请立即咨询我们:
QQ咨询
微信咨询
我们用心,期待您成为我们的客户
联系QQ客服

QQ扫码联系客服

联系微信客服

微信扫码联系客服

微信号:
添加微信好友, 详细咨询相关信息。

复制并跳转微信
19810950281