Java教程:Netty知识点详解(五)

开课吧开课吧锤锤2021-02-23 14:35

近年来,随着云计算、大数据等热门技术的发展和普及,Java在企业中越来越受到重视,公司对于Java人才需求也是每年都在增长,对于这样热门的行业,很多人都是心动的,那么对于如何学习,怎么提高Java的技术,那就来看看本篇文章吧。

Netty 源码阅读

源码阅读,最好可以再 Debug 的情况下进行,这样更容易帮助理解,因此在分析 Netty 前的我准备一个客户端和服务端的代码。

Netty - Server 代码

public class NettyServer {

    public static void main(String[] args) throws InterruptedException {

        EventLoopGroup parentGroup = new NioEventLoopGroup();

        EventLoopGroup childGroup = new NioEventLoopGroup();

        try {

 

            ServerBootstrap bootstrap = new ServerBootstrap();

            bootstrap.group(parentGroup, childGroup)

                     .channel(NioServerSocketChannel.class)

                     .childHandler(new ChannelInitializer<SocketChannel>() {

 

                        @Override

                        protected void initChannel(SocketChannel ch) throws Exception {

 

                            ChannelPipeline pipeline = ch.pipeline();

                            pipeline.addLast(new StringDecoder());

                            pipeline.addLast(new StringEncoder());

                            pipeline.addLast(new SomeSocketServerHandler());

                         }

                    });

            ChannelFuture future = bootstrap.bind(8888).sync();

            System.out.println("服务器已启动。。。");

            future.channel().closeFuture().sync();

        } finally {

            parentGroup.shutdownGracefully();

            childGroup.shutdownGracefully();

        }

    }

}

Server 端 Handler:

public class DemoSocketServerHandler

                       extends ChannelInboundHandlerAdapter {

    @Override

    public void channelRead(ChannelHandlerContext ctx, Object msg)

            throws Exception {

        System.out.println("Client Address ====== " + ctx.channel().remoteAddress());

        ctx.channel().writeAndFlush("from server:" + UUID.randomUUID());

        ctx.fireChannelActive();

        TimeUnit.MILLISECONDS.sleep(500);

    }

    @Override

    public void exceptionCaught(ChannelHandlerContext ctx,

                                Throwable cause) throws Exception {

        cause.printStackTrace();

        ctx.close();

    }

}

Netty - Client 代码

public class NettyClient {

    public static void main(String[] args) throws InterruptedException {

        NioEventLoopGroup eventLoopGroup = new NioEventLoopGroup();

        try {

            Bootstrap bootstrap = new Bootstrap();

            bootstrap.group(eventLoopGroup)

                    .channel(NioSocketChannel.class)

                    .handler(new ChannelInitializer<SocketChannel>() {

                        @Override

                        protected void initChannel(SocketChannel ch) throws Exception {

                            ChannelPipeline pipeline = ch.pipeline();

                            pipeline.addLast(new StringDecoder(CharsetUtil.UTF_8));

                            pipeline.addLast(new StringEncoder(CharsetUtil.UTF_8));

                            pipeline.addLast(new DemoSocketClientHandler());

                        }

                    });

            ChannelFuture future = bootstrap.connect("localhost", 8888).sync();

            future.channel().closeFuture().sync();

        } finally {

            if(eventLoopGroup != null) {

                eventLoopGroup.shutdownGracefully();

            }

        }

    }

}

Client 端 Handler :

public class DemoSocketClientHandler

               extends ChannelInboundHandlerAdapter {

    @Override

    public void channelRead(ChannelHandlerContext ctx, Object msg)

            throws Exception {

        System.out.println(msg);

        ctx.channel().writeAndFlush("from client: " + System.currentTimeMillis());

        TimeUnit.MILLISECONDS.sleep(5000);

    }

    @Override

    public void channelActive(ChannelHandlerContext ctx)

            throws Exception {

        ctx.channel().writeAndFlush("from client:begin talking");

    }

    @Override

    public void exceptionCaught(ChannelHandlerContext ctx,

                                Throwable cause) throws Exception {

        cause.printStackTrace();

        ctx.close();

    }

}

以上内容由开课吧老师敖丙提供,更多Java教程尽在开课吧广场Java教程频道。更多免费课程可以关注公众号码农集散地”

上一篇:Java教程:Netty知识点详解(六)下一篇:Java教程:Netty知识点详解(四)

最新文章

文章图0

如何在大规模 Kubernetes 集群上实现高 SLO?

Pod创建成功率:这是一个非常重要的指标,蚂蚁集团一周的Pod创建量在百万级别,如果成功率波动会造成大量Pod失败,同时Pod成功率下跌也是集群异常的最直观反映;

2021-03-05 16:20:04

文章图1

MySQL不建议delete删除数据的原因是什么?(二)

MySQL内部不会真正删除空间,而且做标记删除,即将delflag:N修改为delflag:Y,commit之后会会被purge进入删除链表,如果下一次insert更大的记录,delete之后的空间不会被重用,如果插入的记录小于等于delete的记录空会被重用,这块内容可以通过知数堂的innbloc

2021-03-05 11:45:44

文章图2

MySQL不建议delete删除数据的原因是什么?(一)

物理上主要由系统用户数据文件,日志文件组成,数据文件主要存储MySQL字典数据和用户数据,日志文件记录的是datapage的变更记录,用于MySQLCrash时的恢复。

2021-03-05 11:36:22

文章图3

Java教程:MySQL如何设计索引更高效?(五)

同时也介绍了如何更好做MySQL索引设计,包括前缀索引,复合索引的顺序问题以及MySQL8.0推出的索引跳跃扫描,我们都知道,索引可以加快数据的检索,减少IO开销,会占用磁盘空间,是一种用空间换时间的优化手段,同时更新操作会导致索引频繁的合并分裂,影响索引性能,在实际的业务开发中,如何根据业务场景去

2021-03-05 11:29:12

文章图4

Java教程:MySQL如何设计索引更高效?(四)

在单列索引不能很好的过滤数据的时候,可以结合where条件中其他字段来创建复合索引,更好的去过滤数据,减少IO的扫描次数,举个例子:业务需要按照时间段来查询交易记录,有如下的SQL:

2021-03-05 11:25:02