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);
	}

	

 

 

### 回答1: Netty 4.0Netty 3.0 的区别有以下几点: 1. 支持的 Java 版本:Netty 4.0 支持的 Java 版本是 Java 7 及以上,而 Netty 3.0 只支持 Java 6 及以上。 2. 架构改变:Netty 4.0 在架构上做了很大的改变,使用了与 3.0 不同的组件和 API。 3. 性能提升:Netty 4.0 在性能上有了很大的提升,比 3.0 快得多。 4. 异步改进:Netty 4.0 对异步操作进行了改进,使用了更加高效的方式来处理异步任务。 5. 新的编解码器:Netty 4.0 新增了一些编解码器,支持更多的协议。 6. 更多的优化:Netty 4.0 还进行了更多的优化,比如支持堆外内存、增强的零拷贝等。 ### 回答2: Netty 4.0Netty 3.0是Java网络编程框架Netty的两个版本。它们之间存在以下区别: 1. 性能提升:Netty 4.0相较于Netty 3.0在性能方面有显著提升。Netty 4.0经过了全面的优化和重构,引入了许多新的特性和改进,使其在处理网络通信时更加高效。 2. API的变化:Netty 4.0对API进行了重构和简化,使得编程接口更加易用和灵活。比如,Netty 4.0引入了ChannelPipelineHandler的概念,可以更加方便地添加和管理多个处理器。 3. 事件处理模型:Netty 4.0采用了新的事件处理模型,即Reactor模型,使得在高并发场景下的事件处理更加高效。而Netty 3.0采用的是NIO Selector模型。 4. 内存管理:Netty 4.0引入了更高级的内存管理机制,即ByteBuf和Recycler。ByteBuf提供了更加灵活的内存分配和回收方式,减少了内存的创建和销毁开销。Recycler可以对对象进行重用,减少了频繁的对象创建和垃圾回收开销。 5. 异常处理:Netty 4.0对异常处理进行了优化,提供了更加丰富的异常类型和处理方式。Netty 3.0在异常处理方面相对简单。 总的来说,Netty 4.0相较于Netty 3.0在性能、API设计、事件处理模型、内存管理和异常处理方面都有较大的改进和优化。因此,Netty 4.0更加适合开发高性能、高并发的网络应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值