一分钟了解四层/七层反向代理

开发 开发工具
上一篇文章《session一致性架构设计实践》,对于其中的第三种“反向代理hash法”,不少同学有留言,本文主要介绍四层/七层反向代理的场景和路径。

上一篇文章《session一致性架构设计实践》,对于其中的第三种“反向代理hash法”,不少同学留言问:

  • 什么是四层反向代理hash
  • 什么是七层反向代理hash
  • 中间还有三层那里去了
  • ...

今天花几分钟简单和大家解释一下。

  • 场景:访问用户通过proxy请求被访问的真实服务器
  • 路径:用户 -> proxy -> real-server

什么是代理?

回答:[proxy]代表[访问用户],此时proxy是代理。

例如:

在家访问xxoo网站,不希望xxoo网站trace到我们的真实ip,于是就找一个proxy,通过proxy来访问,此时proxy代表用户,网站以为proxy的ip就是用户的ip。

什么是反向代理?

回答:[proxy]代表[被访问的服务器],此时proxy是反向代理。

例如:

web-server希望对用户屏蔽高可用、屏蔽web-server扩展、web-server内网ip等细节,于是就找了一个proxy隔在中间,此时proxy代表web-server集群,用户以为proxy的ip就是被访问web-server的ip(web-server是集群,具体访问了哪个web-server,用户不知道),由于web-server集群有多台,此时反向代理服务器要具备负载均衡的功能。

一般怎么做反向代理,负载均衡?

回答:nginx/apache,lvs,F5

什么是四层(转发/交换),什么是七层(转发/交换)?

回答:这个是来源于OSI七层模型

大学“计算机网络”课程,之前都是用这个七层模型,新版教程用TCP/IP五层模型,这两个模型之间有一个对应关系如下:

四层是指传输层,七层是指应用层

可以看到,四层是指传输层,七层是指应用层。

更具体的,对应到nginx反向代理hash:

  • 四层:根据用户ip+port来做hash
  • 七层:根据http协议中的某些属性来做hash

为什么中间少了几层?

回答:OSI应用层、表示层、会话层合并到TCP/IP的应用层啦。

上面有四层,七层,那有没有二层,三层呢?

回答:有

  • 二层:根据数据链路层MAC地址完成数据交换
  • 三层:根据网络层IP地址完成数据交换

【本文为51CTO专栏作者“58沈剑”原创稿件,转载请联系原作者】

戳这里,看该作者更多好文

责任编辑:赵宁宁 来源: 51CTO专栏
相关推荐

2022-07-18 06:16:07

单点登录系统

2017-07-06 08:12:02

索引查询SQL

2020-07-09 07:37:06

数据库Redis工具

2020-07-17 07:44:25

云计算边缘计算IT

2017-03-30 19:28:26

HBase分布式数据

2022-06-02 08:46:04

网卡网络服务器

2016-09-14 15:57:53

架构分布式系统负载均衡

2019-08-07 07:11:21

OSI七层模型TCPIP五层模型

2018-06-26 05:23:19

线程安全函数代码

2020-05-21 19:46:19

区块链数字货币比特币

2017-02-21 13:00:27

LoadAverage负载Load

2018-07-31 16:10:51

Redo Undo数据库数据

2015-10-10 14:11:00

互联网数据挖掘爬虫

2020-01-30 11:26:17

QinQVLAN协议

2017-12-26 16:24:36

接口代码数据

2018-01-14 23:19:25

静态动态互联网

2011-02-21 17:48:35

vsFTPd

2018-12-12 22:51:24

Java包装语言

2016-09-12 17:28:45

云存储应用软件存储设备

2019-12-24 09:10:43

Ipv6IP址协议
点赞
收藏

51CTO技术栈公众号