什么是代理和反向代理?(手把手教你做一个简单的代理服务器)
三石哥 2022-07-18 16:04:44 235
简介
爱因斯坦说过:所有的伟大,都产生于简单的细节中。netty为我们提供了如此强大的eventloop、channel通过对这些简单东西的有效利用,可以得到非常强大的应用程序,比如今天要讲的代理。
代理和反向代理
相信只要是程序员应该都听过nginx服务器了,这个超级优秀nginx一个很重要的功能就是做反向代理。那么有小伙伴要问了,有反向代理肯定就有正向代理,那么他们两个有什么区别呢?
先讲一下正向代理,举个例子,最近流量明星备受打击,虽然被打压,但是明星就是明星,一般人是见不到的,如果有人需要跟明星对话的话,需要首先经过明星的经纪人,有经纪人将话转达给明星。这个经纪人就是正向代理。我们通过正向代理来访问要访问的对象。
那么什么是反向代理呢?比如现在出现了很多人工智能,假如我们跟智能机器人A对话,然后A把我们之间的对话转给了后面的藏着的人,这个人用他的智慧,回答了我们的对话,交由智能机器人A输出,最终实现了人工智能。这个过程就叫做反向代理。
netty实现代理的原理
那么在netty中怎么实现这个代理服务器呢?
首选我们首先代理服务器是一个服务器,所以我们需要在netty中使用ServerBootstrap创建一个服务器:
EventLoopGroup bossGroup = newNioEventLoopGroup(1); EventLoopGroup workerGroup = newNioEventLoopGroup(); try{ ServerBootstrap b = newServerBootstrap(); b.group(bossGroup, workerGroup) .channel(NioServerSocketChannel.class).handler(newLoggingHandler(LogLevel.INFO)) .childHandler(newSimpleDumpProxyInitializer(REMOTE_HOST, REMOTE_PORT)) .childOption(ChannelOption.AUTO_READ, false) .bind(LOCAL_PORT).sync().channel().closeFuture().sync();
在这个local服务器中,我们传入ProxyInitializer。在这个handler初始化器中,我们传入自定义的handler:
publicvoidinitChannel(SocketChannel ch){ ch.pipeline().addLast( newLoggingHandler(LogLevel.INFO), newSimpleDumpProxyInboundHandler(remoteHost, remotePort)); }
在自定义的handler中,我们使用Bootstrap创建一个client,用来连接远程要代理的服务器,我们将这个client端的创建放在channelActive方法中:
// 开启outbound连接Bootstrap b = newBootstrap(); b.group(inboundChannel.eventLoop()) .channel(ctx.channel().getClass()) .handler(newSimpleDumpProxyOutboundHandler(inboundChannel)) .option(ChannelOption.AUTO_READ, false); ChannelFuture f = b.connect(remoteHost, remotePort);
然后在client建立好连接之后,就可以从inboundChannel中读取数据了:
outboundChannel = f.channel(); f.addListener(future-> { if(future.isSuccess()) { // 连接建立完毕,读取inbound数据inboundChannel.read(); } else{ // 关闭inbound channelinboundChannel.close(); } });
因为是代理服务,所以需要将inboundChannel读取的数据,转发给outboundChannel,所以在channelRead中我们需要这样写:
publicvoidchannelRead(finalChannelHandlerContext ctx, Object msg){ // 将inboundChannel中的消息读取,并写入到outboundChannelif(outboundChannel.isActive()) { outboundChannel.writeAndFlush(msg).addListener((ChannelFutureListener) future-> { if(future.isSuccess()) { // flush成功,读取下一个消息ctx.channel().read(); } else{ future.channel().close(); } }); } }
当outboundChannel写成功之后,再继续inboundChannel的读取工作。
同样对于client的outboundChannel来说,也有一个handler,在这个handler中,我们需要将outboundChannel读取到的数据反写会inboundChannel中:
publicvoidchannelRead(finalChannelHandlerContext ctx, Object msg){ // 将outboundChannel中的消息读取,并写入到inboundChannel中inboundChannel.writeAndFlush(msg).addListener((ChannelFutureListener) future-> { if(future.isSuccess()) { ctx.channel().read(); } else{ future.channel().close(); } }); }
当inboundChannel写成功之后,再继续outboundChannel的读取工作。
如此一个简单的代理服务器就完成了。
实战
如果我们将本地的8000端口,代理到www.163.com的80端口,会发生什么情况呢?运行我们的程序,访问http://localhost:8000, 我们会看到下面的页面:
为什么没有如我们想象的那样展示正常的页面呢?那是因为我们代理过去之后的域名是localhost,而不是正常的www.163.com, 所以服务器端不认识我们的请求,从而报错。
总结
本文的代理服务器之间简单的转发请求,并不能够处理上述的场景,那么该怎么解决上面的问题呢? 敬请期待我的后续文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 3561739510@qq.com 举报,一经查实,本站将立刻删除。
转载请注明来自专注SEO技术,教程,推广 - 8848SEO,本文标题:《什么是代理和反向代理?(手把手教你做一个简单的代理服务器)》
标签:代理服务器
- 搜索
- 最新文章
- 热门文章
-
- 快手新人开直播十大技巧是什么?快手新人直播技巧有哪些?
- SEO关键词优化如何提高网站排名?SEO关键词排名提升方法是什么?
- 搜索关键词如何让排名靠前?揭秘关键词排名提升方法
- 网站关键词确定方法:精准定位,提高搜索排名
- 抖音视频上热门标准是什么?抖音视频上热门条件有哪些?
- 网站标题优化技巧:提升搜索排名,吸引更多流量
- 快手点赞对主播有什么好处?快手点赞主播收益是什么?
- 抖音标题如何写?抖音标题写作技巧是什么?
- 快手播放量1000代表什么?快手播放量1000意义是什么?
- 如何优化网站排名以提升流量?揭秘网站排名提升的五大策略
- 抖音直播带货佣金如何计算?抖音直播带货佣金模式是什么?
- SEO作弊和惩罚分析是什么?SEO作弊惩罚机制是什么?
- SEO引流如何做效果更好?SEO引流技巧有哪些?
- 抖音与快手流量对比分析:谁更胜一筹?
- 国内抖音视频可以搬运到tiktok上发布吗?抖音tiktok视频搬运规则是什么?
- 抖音抖币兑换人民币的比例是多少?如何计算?
- 快手评论如何发图片?快手评论图片发布方法详解
- 抖音在线状态不显示问题解决方法(探究在线状态显示时间)
- 快手粉丝团升级攻略:快速提升等级,解锁更多权益
- 如何成功推行网站搜索引擎优化的方案(提升公司品牌知名度和业务转化率的关键)
- 热门tag