2

我查看了 Netty 文档,并在示例源类中发现了一些评论: org.jboss.netty.example.factorial.FactorialServerHandler ,在这个 src 中,一些评论:

    //##in org.jboss.netty.example.factorial.FactorialServerPipelineFactory
    ......
    // and then business logic.
    // Please note we create a handler for every new channel
    // because it has stateful properties.
    pipeline.addLast("handler", new FactorialServerHandler());

但是,我重新检查了其他示例,例如 TelnetServerPipelineFactory,似乎没有什么区别,句柄是由以下人员创建的:

    // and then business logic. 
    pipeline.addLast("handler", new TelnetServerHandler());

所有处理程序都是由带有“新”的管道创建的?Netty 中的所有示例都是有状态的?显然 Echo/Telnet 不需要保持 stateful prop。

在我的旧项目中,我使用 Netty 创建一个 Http Server 作为 RESTful 服务器,我的处理程序代码是:

    public class HttpServerPipelineFactory  implements ChannelPipelineFactory {
        private final HttpServerHandler handler;
        public ChannelPipeline getPipeline() throws Exception {
            ChannelPipeline pipeline = pipeline();
            pipeline.addLast("decoder", new HttpRequestDecoder());
            pipeline.addLast("aggregator", new HttpChunkAggregator(1048576));
            pipeline.addLast("encoder", new HttpResponseEncoder());
            pipeline.addLast("handler", handler); //singleton
            return pipeline;
        }
    }

我的 RESTful 服务器是无状态的(这是一种REST含义),所以我使用了单例句柄。我是对的吗?

4

2 回答 2

3

当文档说“有状态”时,这意味着状态信息作为字段存储在 ChannelHandler 中,因此不可能在不同 Channel 之间共享 ChannelHandler。如果您没有将状态信息存储为字段,则可以将其用作 Singelton。

于 2012-04-23T05:52:11.457 回答
1

如果它们是无状态的,您没有理由实例化新的处理程序。但在 Http 示例中,这些处理程序有状态的。他们从网络逐帧接收并将它们解析为标头和其他内容。然后如果请求被分块,聚合器将块组合成单个有效负载等。简而言之,除非您正在构建一个回显服务器,否则较低级别的处理程序可能必须是有状态的,但较高级别不需要。

于 2012-04-23T08:37:45.600 回答