`

异步的、事件驱动的网络应用程序框架和工具Netty

 
阅读更多

Hello World in Netty


    1、HelloWorldServer


     ServerBootstrap bootstrap = new ServerBootstrap(new
        NioServerSocketChannelFactory(
        Executors.newCachedThreadPool(),
        Executors.newCachedThreadPool()));

     bootstrap.setPipelineFactory(new ChannelPipelineFactory() {
        public ChannelPipeline getPipeline()       {
          ChannelPipeline pipeline = Channels.pipeline();
          pipeline.addLast("decoder", new StringDecoder());
          pipeline.addLast("encoder", new StringEncoder());
          pipeline.addLast("handler", new HelloWorldServerHandler());
          return pipeline;
        }
     });

     bootstrap.bind(new InetSocketAddress(8080));

 

 

 

    HelloWorldServerHandler


     public void channelConnected(ChannelHandlerContext ctx,
       ChannelStateEvent e) throws Exception {
       e.getChannel().write("Hello, World");
     }

     public void exceptionCaught(ChannelHandlerContext ctx,
       ExceptionEvent e) {
       logger.log(Level.WARNING, "Unexpected exception from
       downstream.", e.getCause());
       e.getChannel().close();
     } 
    

 2、HelloWorldClient
       ClientBootstrap bootstrap = new ClientBootstrap(new NioClientSocketChannelFactory(
       Executors.newCachedThreadPool(), Executors.newCachedThreadPool()));

       bootstrap.setPipelineFactory(new ChannelPipelineFactory() {
            public ChannelPipeline getPipeline() {
              ChannelPipeline pipeline = pipeline();
              pipeline.addLast("decoder", new StringDecoder());
              pipeline.addLast("encoder", new StringEncoder());
              pipeline.addLast("handler", new HelloWorldClientHandler());
              return pipeline;
            }
       });

       ChannelFuture future = bootstrap.connect(new InetSocketAddress("localhost", 8080));

       future.getChannel().getCloseFuture().awaitUninterruptibly();

       bootstrap.releaseExternalResources();

 

 

    HelloWorldClientHandler


     public void messageReceived(ChannelHandlerContext ctx,
        MessageEvent e) {
         String message = (String) e.getMessage();
         System.out.println(message);
         e.getChannel().close();

     }
     public void exceptionCaught(ChannelHandlerContext ctx,
        ExceptionEvent e) {
         logger.log(Level.WARNING, "Unexpected exception from
            downstream.", e.getCause());
         e.getChannel().close();

     }

分享到:
评论

相关推荐

    Netty5异步事件驱动的网络应用框架

    换句话说,Netty是一个NIO框架,使用它可以简单快速地开发网络应用程序,比如客户端和服务端的协议。Netty大大简化了网络程序的开发过程比如TCP和UDP的 Socket的开发。 “快速和简单”并不意味着应用程序会有难维护...

    Java Netty技术研究

    提供异步的、事件驱动网络应用程序框架和工具 优点:提供异步的、事件驱动网络应用程序框架和工具 优点:提供异步的、事件驱动网络应用程序框架和工具 优点:提供异步的、事件驱动网络应用程序框架和工具 优点:提供...

    netty(Java网络应用框架)v4.1.9官方免费版

    Netty是一套由JBOSS提供的用于快速开发可维护的高性能协议服务器和客户端的异步事件驱动的Java网络通讯程序框架。它的本质是为了简化高性能网络应用程序的开发,它可以快速轻松地开发诸如协议服务器和客户端之类的...

    高性能网络应用框架 Netty.zip

    Netty提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序。也就是说,Netty 是一个基于NIO的客户、服务器端编程框架,使用Netty 可以确保你快速和简单的开发出一...

    Catty:受Netty启发的C#异步事件驱动的网络应用程序框架

    斤受Netty启发的C#异步事件驱动的网络应用程序框架Catty是Ansync I / O服务器/客户端框架,可快速轻松地开发网络应用程序,例如协议服务器和客户端。 它极大地简化和简化了诸如TCP套接字服务器之类的网络编程。 ###...

    netty 2019最新源码与示例

    Netty提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序。 也就是说,Netty 是一个基于NIO的客户、服务器端编程框架,使用Netty 可以确保你快速和简单的开发出...

    Netty 快速入门系列-源码

    Netty提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序。 Netty是一个NIO客户端、服务端框架。允许快速简单的开发网络应用程序。例如:服务端和客户端之间的...

    27 Netty高级网络编程框架

    教程视频:Netty是由JBOSS提供的一个java开源框架。Netty提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序

    netty关联jars

    Netty是由JBOSS提供的一个java开源框架,提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序。 也就是说,Netty 是一个基于NIO的客户,服务器端编程框架,使用...

    Netty(Java 网络服务框架) v4.0.44.zip

    Netty提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序。 也就是说,Netty 是一个基于NIO的客户、服务器端编程框架,使用Netty 可以确保你快速和简单的开发出...

    netty in action (meap)

    Netty提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序dsf。 也就是说,Netty 是一个基于NIO的客户,服务器端编程框架,使用Netty 可以确保你快速和简单的开发...

    netty:Netty项目-事件驱动的异步网络应用程序框架

    Netty是一个异步事件驱动的网络应用程序框架,用于快速开发可维护的高性能协议服务器和客户端。 链接 如何建造 有关构建和开发Netty的详细信息,请访问。 该页面仅提供非常基本的信息。 您需要以下内容来构建Netty...

    netty-demo实例

    Netty提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序dsf。 也就是说,Netty 是一个基于NIO的客户,服务器端编程框架,使用Netty 可以确保你快速和简单的开发...

    netty电子书

    Netty提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序。 也就是说,Netty 是一个基于NIO的客户,服务器端编程框架,使用Netty 可以确保你快速和简单的开发出...

    netty4官方包

    Netty提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序。 也就是说,Netty 是一个基于NIO的客户,服务器端编程框架,使用Netty 可以确保你快速和简单的开发出...

    netty框架 jar包

    Netty提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序。

    netty-demo

    Netty提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序dsf。 也就是说,Netty 是一个基于NIO的客户,服务器端编程框架,使用Netty 可以确保你快速和简单的开发...

    Netty(Java 网络服务框架)v4.1.53.zip

    Netty提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序。 也就是说,Netty 是一个基于NIO的客户、服务器端编程框架,使用Netty 可以确保你快速和简单的开发出...

    深入浅出Netty_netty5.0_

    Netty 提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序.

Global site tag (gtag.js) - Google Analytics