`
zhanghaj00
  • 浏览: 64345 次
社区版块
存档分类
最新评论

Netty4.0 简单学习

 
阅读更多
/**
 * 这是server的基本格式。基本server都是这样,分四步
 * 1.创建boss和work 线程 这个可以选。我选的是netty标志的支持nio异步的
 * 2.ServerBootstrap group ,创建channel 这里可以选不同的协议的,我选的是tcp/ip协议的,这个可以选
 * 3.加入ServerInitializer 这个是第二部分
 * 4.最后监听 就行了 后面那一长串就是监听监听
 */
public class HelloServer {
	public static void main(String[] args) {

                //epoll 是linux上支持的selector
		//EpollEventLoopGroup boss1 = new EpollEventLoopGroup();
		EventLoopGroup boss = new NioEventLoopGroup();

		EventLoopGroup work = new NioEventLoopGroup(5);

		ServerBootstrap bootstrap = new ServerBootstrap();
		try {	
			bootstrap.group(boss1, work);

			bootstrap.channel(NioServerSocketChannel.class);

			bootstrap.childHandler(new HelloServerInitializer());

			ChannelFuture f = bootstrap.bind(7894).sync().channel().closeFuture().sync();
			
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
			
		}finally{
			boss.shutdownGracefully();
			work.shutdownGracefully();	
		}
	}
}

 

 

2.HelloServerInitializer

 

**
 *  这是一个中间量,可以相当于一个pipe  一个socket 过来 需要经过各种各种的handler 来编码解码
 *  这就是定义那一个pipeline 然后随便加 后面的socketChannel 是一个TCP/IP socket。
 */
public class HelloServerInitializer extends ChannelInitializer<SocketChannel>{

	@Override
	public void initChannel(SocketChannel ch) throws Exception {
		ChannelPipeline pipeline = ch.pipeline();

		//pipeline.addLast("Sdecoder", new StringDecoder());
		//pipeline.addLast("Sencoder",new StringEncoder());
        //pipeline 这个方法可以加入很多编码,解码的的类,非常多,这里是对string 和对象的
		pipeline.addLast(new StringEncoder());
		pipeline.addLast(new StringDecoder());
		pipeline.addLast(new ObjectDecoder(ClassResolvers.cacheDisabled(null)));
		pipeline.addLast(new ObjectEncoder());

		//最后加入自己定义的handler 可以加很多
		pipeline.addLast("myHander",new HelloServerHandler());
	}

}

 

3.HelloServerHandler

public class HelloServerHandler extends ChannelInboundHandlerAdapter{

	@Override
	public void channelActive(ChannelHandlerContext ctx) throws Exception {
		System.out.println("channel up");
	}

	@Override
	public void channelRead(ChannelHandlerContext ctx, Object msg)
			throws Exception {
		// TODO Auto-generated method stub
		//读入一个msg
		System.out.println(msg);
		//写出去一个msg
		ctx.write(msg);
	}

	@Override
	public void channelReadComplete(ChannelHandlerContext ctx) throws Exception {
		// TODO Auto-generated method stub
		ctx.flush();
	}

 

客户端代码:

public class Client {
	
	public static void main(String[] args) {

		EventLoopGroup work = new NioEventLoopGroup();
		Bootstrap bootstrap = new Bootstrap();
		try {
		bootstrap.group(work).channel(NioSocketChannel.class).handler(new ChannelInitializer<SocketChannel>() {

			@Override
			protected void initChannel(SocketChannel ch) throws Exception {
				// TODO Auto-generated method stub
				ch.pipeline().addLast(new ObjectEncoder(),new ObjectDecoder(ClassResolvers.cacheDisabled(null)),new HelloClientHandler());
			}
		});
			bootstrap.connect("127.0.0.1", 7894).sync().channel().closeFuture().sync();
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}

 

这是客户端的client

public class HelloClientHandler extends ChannelInboundHandlerAdapter{

	public final List<String> list = new ArrayList<String>();
	
	@Override
	public void channelActive(ChannelHandlerContext ctx) throws Exception {
		// TODO Auto-generated method stub
		System.out.println("client channel up");
		
		for(int i=0;i<10;i++){
			list.add(String.valueOf(i)+",");			
		}
		
		ctx.writeAndFlush(list);
	}

	@Override
	public void channelRead(ChannelHandlerContext ctx, Object msg)
			throws Exception {
		System.out.println(msg);
		ctx.write(msg);
	}

	

 

 

分享到:
评论

相关推荐

    Netty4.0 jar包 及 源代码 和 例子

    Netty4.0全部jar包.开发时候只需要倒入总的哪一个netty4.0.jar就行了 后缀为resources.jar的全部是源码。 简单的代码例子在netty-example-resources.jar里面。

    Netty4.0学习笔记系列之四:混合使用coder和handler

    在本篇Netty4.0学习笔记中,我们将聚焦于如何在实际应用中混合使用`coder`和`handler`,这是Netty框架中非常关键的一部分,对于构建高性能、低延迟的网络应用程序至关重要。Netty是一个用Java编写的异步事件驱动的...

    netty4.0文件分片上传+断点续传+权限校验

    Netty 4.0 提供了强大的网络编程能力,使得实现文件分片上传、断点续传和权限校验变得相对简单。通过自定义处理器和策略,我们可以构建高效且安全的文件上传系统。rrkd-file-client和rrkd-file-server这两个文件可能...

    Netty4.0 官网例子(免费)

    通过 Netty 的官网例子,你可以深入学习这些概念并了解如何在实际项目中运用。官方示例通常覆盖了基础到高级的各种用法,是理解和掌握 Netty4.0 的良好起点。你可以从 netty-4.0 压缩包中的源代码开始,逐步分析和...

    netty4.0工具包

    NIO socket开发,netty4.0工具包。

    Springboot 2.0 整合 Netty 4.0 实现IO异步通讯架构

    Springboot2.0.8集成 netty4 ,使用protobuf作为ping的数据交换,比json更加的小巧,占用数据量更小,可用于任何第三方应用做心跳监控。 已完成功能: - 客户端授权验证(基于protoBuff) - 心跳检测(基于protoBuff) ...

    Netty4.0 http案例

    在这个“Netty4.0 http案例”中,我们将深入探讨如何利用Netty 4.0 实现HTTP服务,以及客户端如何通过HTTP请求与服务器进行交互,特别是在处理JSON格式的数据时。 首先,让我们了解HTTP协议。HTTP(超文本传输协议...

    Netty4.0学习笔记系列之六:多种通讯协议支持

    在本篇Netty4.0学习笔记系列之六中,我们将深入探讨Netty框架如何支持多种通讯协议,以及它在实现高效、灵活的网络通信中的关键特性。Netty是一个高性能、异步事件驱动的网络应用框架,适用于开发服务器和客户端的...

    Netty4.0学习笔记系列之五:自定义通讯协议

    在本篇“Netty4.0学习笔记系列之五:自定义通讯协议”中,我们将深入探讨如何在Netty框架下构建和实现自己的通信协议。Netty是一个高性能、异步事件驱动的网络应用框架,广泛应用于Java领域的服务器开发,如网络游戏...

    Netty4.0学习笔记系列之三:构建简单的http服务

    Netty4.0学习笔记系列之三是关于构建简单的HTTP服务的教程,这主要涉及网络编程、服务器开发以及Java NIO(非阻塞I/O)的相关知识。Netty是一个高性能、异步事件驱动的网络应用程序框架,它使得开发可伸缩且稳定的...

    netty4.0.45jar包socket和http工具包

    Netty 4.0.45提供了高度优化的NIO(非阻塞I/O)和EPOLL(用于Linux系统的高效I/O)实现,确保了在处理大量并发连接时的性能。 在Socket开发中,Netty的ChannelHandlerContext和EventLoopGroup等概念非常关键。...

    Netty4.0学习笔记系列之二:Handler的执行顺序

    在本篇“Netty4.0学习笔记系列之二:Handler的执行顺序”中,我们将深入探讨Netty中的Handler处理链以及它们的执行流程。 首先,Netty 中的 ChannelHandler 是处理 I/O 事件或拦截 I/O 操作的核心组件。每个 ...

    Netty4.0学习笔记系列之一:Server与Client的通讯

    在本文中,我们将深入探讨Netty 4.0的学习笔记,特别是关于Server与Client之间的通信机制。 首先,我们要理解Netty的核心概念——NIO(非阻塞I/O)。Netty基于Java NIO库构建,它提供了更高级别的API,简化了多路...

    netty4.0中的新变化和注意点鸟窝.pdf

    Netty 是一个高性能、异步事件驱动的...总的来说,Netty 4.0 的这些变化提升了框架的性能,简化了 API,降低了学习曲线,并提供了更强大的功能。对于开发者来说,理解这些变化是成功迁移和利用 Netty 4.0 功能的关键。

    Netty4.0.54英文版API文档

    Netty4.0.54英文版API文档,与官网中文档内容一致,方便用户在离线环境下,开发Netty

    netty4.0源码,netty例子,netty api文档

    这个压缩包包含的是Netty 4.0.0.CR3版本的相关资源,包括源码、示例以及API文档,对于学习和理解Netty的工作原理以及如何在实际项目中应用Netty非常有帮助。 首先,让我们来详细探讨一下Netty的核心特性: 1. **...

    netty4.0 demo

    这个"Netty4.0 demo"压缩包包含了一些Netty 4.0版本的应用示例代码,可以帮助我们更好地理解和学习Netty的工作原理以及如何在实际项目中运用它。 1. **Netty简介** Netty 是由JBOSS组织开发的一个开源项目,最初...

    netty-4.0.28.Final

    Netty是由JBOSS提供的一个java开源框架。Netty提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序dsf。...netty, 4.0.28, Final, jar包, 含源码

    netty-4.0.42.Final.zip

    Netty官方4.0.42版jar包

    netty4.0.56稳定版本

    Netty是一个异步事件驱动的网络应用程序框架,主要用于快速开发可维护的高性能协议服务器和客户端。它基于Java NIO进行设计,因此提供了高层次的抽象和简化的API,使得开发者可以更加方便地构建网络应用。 Netty在...

Global site tag (gtag.js) - Google Analytics