Netty 4 多客户端

编程入门 行业动态 更新时间:2024-10-09 20:25:59
本文介绍了Netty 4 多客户端的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧! 问题描述

我需要让客户端能够建立许多连接.我使用 Netty 4.0.不幸的是,所有现有示例都没有显示如何创建大量连接.

I need to make the client is able to make many connections. I use Netty 4.0. Unfortunately all existing examples do not show how to create a lot of connections.

public class TelnetClient { private Bootstrap b; public TelnetClient() { b = new Bootstrap(); } public void connect(String host, int port) throws Exception { try { b.group(new NioEventLoopGroup()).channel(NioSocketChannel.class).remoteAddress(host, port).handler(new TelnetClientInitializer()); Channel ch = b.connect().sync().channel(); ChannelFuture lastWriteFuture = null; BufferedReader in = new BufferedReader(new InputStreamReader(System.in)); for (;;) { String line = in.readLine(); if (line == null) break; lastWriteFuture = ch.write(line + " "); if (line.toLowerCase().equals("bye")) { ch.closeFuture().sync(); break; } } if (lastWriteFuture != null) lastWriteFuture.sync(); } finally { b.shutdown(); } } public static void main(String[] args) throws Exception { TelnetClient tc = new TelnetClient(); tc.connect("127.0.0.1", 1048); tc.connect("192.168.1.123", 1050); //... } }

这是正确的决定吗?还是会更好?

Is this the correct decision? or could it be better?

推荐答案

是的,它几乎是正确的.你唯一必须改变的是在每次连接时创建 NioEventLoopGroup.

Yes its almost correct.. The only thing you MUST change is the creation of NioEventLoopGroup on every connect.

NioEventLoopGroup 实例很昂贵,因此应该共享它们.创建一个实例并共享它,每次都将相同的实例传递给 Bootstrap.group(...)..

NioEventLoopGroup instances are expensive so they should be shared. Create one instance and share it, by pass the same instance to the Bootstrap.group(...) everytime..

更多推荐

Netty 4 多客户端

本文发布于:2023-11-30 22:34:08,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1651675.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:客户端   Netty

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!