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

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文件分片上传+断点续传+权限校验

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

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

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

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

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

    netty-4.0.41-2016-9-29官网下载

    4. **易用性**:Netty提供了简单易用的API,使得编写网络应用变得非常直观。其Channel、Handler、EventLoopGroup等核心概念清晰明了,降低了学习和使用的难度。 5. **强大的异常处理**:Netty提供了强大的异常处理...

    netty中文开发指南

    - **入门指南**:对于初学者来说,可以从Netty的官方文档开始学习,特别是“开始”这一章节。该章节详细介绍了Netty的基本概念和技术栈,并通过简单的示例程序引导读者入门。 - **架构总览**:对于希望深入了解...

    使用netty自定义rpc通信框架

    本项目是基于Netty 4.0实现的自定义RPC通信框架,旨在为Java开发者提供一种高效、灵活的远程服务调用解决方案。 首先,我们来深入理解Netty的基本概念。Netty的核心是其NIO(非阻塞I/O)模型,它使用了Reactor模式...

    Java面试题10道Java高级必备的Netty面试题!.pdf

    如何通过它们构建一个简单的服务器和客户端? 2. **线程模型** - 描述Netty的BossGroup和WorkerGroup的概念,以及它们如何协同工作处理网络事件。 - Netty是如何实现高效的线程模型以提高性能的? 3. **ByteBuf*...

    一款分布式的java游戏服务器框架,具备高性能、可伸缩、分布式、多线程等特点,java 8 +gradle 4.0

    简单的策划配置管理,可实现多条件查询配置 构建环境 java 8 + gradle 4.0+ 第三方引用 Netty 宇宙最强的java网络库,可定义各种网络通信方式,本框架中RPC、http、websocket等都基于netty的封装。 Disruptor 高性能...

    JAVA上百实例源码以及开源项目源代码

    简介 笔者当初为了学习JAVA,收集了很多经典源码,源码难易程度分为初级、中级、高级等,详情看源码列表,需要的可以直接下载! 这些源码反映了那时那景笔者对未来的盲目,对代码的热情、执着,对IT的憧憬、向往!...

Global site tag (gtag.js) - Google Analytics