Netty进阶之路-客户端池化疑云

8 篇文章 1 订阅

前言

上一篇我们了解了EventExecutorGroup的工作机制,但是依然没有解决我们的1秒执行一次的问题。

FixedChannelPool

我们知道了EventExecutorGroup的工作机制。对于某个客户端连接Channel,只会注册到一个Nio线程中这句话很关键,也点醒了我,那如果客户端和服务端一直是由一个Channel进行交互的那就好发生1秒执行一次的问题。
在这里插入图片描述
果然 我们通过打印发现了除了一开始创建了5个channel之后,一直都是由一个和服务端进行交互的。
猜测原因是由于客户端发起请求速度非常快,之后直接将其放回到线程池中,那么有可能直接后面在用这个线程。(其实也和JMeter有关,ramp-up period 参数调小,就会发现还是会出现不同的ChannelID的。ramp-up period 参数 大概意思就是多长时间执行设置的线程数)

InetSocketAddress addr = new InetSocketAddress(host, port);
    	final SimpleChannelPool pool = RPCRequestNet.poolMap.get(addr);
    	final Future<Channel> f = pool.acquire();
    	f.addListener(new FutureListener<Channel>() {
			@Override
			public void operationComplete(Future<Channel> arg0) throws Exception {
				  if (f.isSuccess()) {
				      Channel ch = f.getNow();
				      ch.writeAndFlush(request);
					  System.out.println("发送请求");
					  pool.release(ch);
				  }
			}
		});

FixedChannelPool 构造参数

通过查看API 我们可以看到有这些参数 其他都不细说了就一个lastRecentUsed。
原文 :true Channel selection will be LIFO, if false FIFO.
翻译一下就是 true就是后进先出,false 就是先进先出。(原来是这个原因)

public FixedChannelPool(Bootstrap bootstrap,
                        ChannelPoolHandler handler,
                        ChannelHealthChecker healthCheck,
                        FixedChannelPool.AcquireTimeoutAction action,
                        long acquireTimeoutMillis,
                        int maxConnections,
                        int maxPendingAcquires,
                        boolean releaseHealthCheck,
                        boolean lastRecentUsed)

FixedChannelPool 改造

我们改造一下,lastRecentUsed参数是默认true,我们将其改成false

return new FixedChannelPool(b.remoteAddress(inetSocketAddress), handler, ChannelHealthChecker.ACTIVE, null, -1L, 5, 2147483647, true, false);

改完发现好了,哈哈 确实是这个原因。(图就不放了)

总结

  1. 1.EventExecutorGroup并不是设置的越大就越好的,显然是NioEventLoopGroup的线程数量限制了上线。
  2. Netty确实是一个高性能通信框架利用FixedChannelPool 就能将并发量为30的一下子就发生完成了,只是全部都堆积在了服务器的队列中等待处理。
  3. .我们将lastRecentUsed改为false,确实是一种解决办法。其实还有一钟解决办法,就是业务线程的第二钟解决办法,我将会在后面介绍。
  4. 其实Netty的提供了许多优化的方法,并不是说一定哪一种就一定是最好的,还是要和业务结合。
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值