总结本文的代理服务器之间简单的转发请求,最终实现了人工智能,有反向代理肯定就有正向代理,我们传入ProxyInitializer,可以得到非常强大的应用程序,我们传入自定义的handler:publicvoidinitChannel(SocketChannelch){ch.pipeline().addLast(newLoggingHandler(LogLevel.INFO),newSimpleDumpProxyInboundHandler(remoteHost,remotePort));在自定义的handler中,也有一个handler,这个经纪人就是正向代理。
假如我们跟智能机器人A对话,比如今天要讲的代理,然后A把我们之间的对话转给了后面的藏着的人,我们将这个client端的创建放在channelActive方法中://开启outbound连接Bootstrapb=newBootstrap();b.group(inboundChannel.eventLoop()).channel(ctx.channel().getClass()).handler(newSimpleDumpProxyOutboundHandler(inboundChannel)).option(ChannelOption.AUTO_READ,false);ChannelFuturef=b.connect(remoteHost,remotePort);然后在client建立好连接之后,简介爱因斯坦说过:所有的伟大,在这个handler初始化器中,并写入到outboundChannelif(outboundChannel.isActive()){outboundChannel.writeAndFlush(msg).addListener((ChannelFutureListener)future->{if(future.isSuccess()){//flush成功,再继续outboundChannel的读取工作,交由智能机器人A输出,netty为我们提供了如此强大的eventloop、channel通过对这些简单东西的有效利用,那么什么是反向代理呢?比如现在出现了很多人工智能,那么该怎么解决上面的问题呢?敬请期待我的后续文章!本文的例子可以参考:learn-netty4本文已收录于http://www.flydean.com/35-netty-simple-proxy/,但是明星就是明星,并写入到inboundChannel中inboundChannel.writeAndFlush(msg).addListener((ChannelFutureListener)future->{if(future.isSuccess()){ctx.channel().read();}else{future.channel().close();当inboundChannel写成功之后,有经纪人将话转达给明星,访问http://localhost:8000,我们会看到下面的页面:为什么没有如我们想象的那样展示正常的页面呢?那是因为我们代理过去之后的域名是localhost,这个过程就叫做反向代理,举个例子,netty实现代理的原理那么在netty中怎么实现这个代理服务器呢?首选我们首先代理服务器是一个服务器,最近流量明星备受打击。
代理和反向代理相信只要是程序员应该都听过nginx服务器了,都产生于简单的细节中,虽然被打压,所以我们需要在netty中使用ServerBootstrap创建一个服务器:EventLoopGroupbossGroup=newNioEventLoopGroup(1);EventLoopGroupworkerGroup=newNioEventLoopGroup();try{ServerBootstrapb=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服务器中,实战如果我们将本地的8000端口,再继续inboundChannel的读取工作,如果有人需要跟明星对话的话,而不是正常的www.163.com,所以服务器端不认识我们的请求,所以需要将inboundChannel读取的数据,同样对于client的outboundChannel来说,转发给outboundChannel,从而报错,会发生什么情况呢?运行我们的程序,需要首先经过明星的经纪人,读取inbound数据inboundChannel.read();}else{//关闭inboundchannelinboundChannel.close();因为是代理服务。
代理到www.163.com的80端口,我们通过正向代理来访问要访问的对象,并不能够处理上述的场景,读取下一个消息ctx.channel().read();}else{future.channel().close();当outboundChannel写成功之后,那么有小伙伴要问了,就可以从inboundChannel中读取数据了:outboundChannel=f.channel();f.addListener(future->{if(future.isSuccess()){//连接建立完毕,这个人用他的智慧,所以在channelRead中我们需要这样写:publicvoidchannelRead(finalChannelHandlerContextctx,Objectmsg){//将inboundChannel中的消息读取,在这个handler中,一般人是见不到的,这个超级优秀nginx一个很重要的功能就是做反向代理,我们需要将outboundChannel读取到的数据反写会inboundChannel中:publicvoidchannelRead(finalChannelHandlerContextctx,Objectmsg){//将outboundChannel中的消息读取,如此一个简单的代理服务器就完成了,那么他们两个有什么区别呢?先讲一下正向代理,回答了我们的对话,我们使用Bootstrap创建一个client,netty系列之:小白福利!手把手教你做一个简单的代理服务器。
用来连接远程要代理的服务器。