沉淀、分享、成长,专注于原创专题案例,以最易学习编程的方式分享知识,让自己和他人都能有所收获。目前已完成的专题有;Netty4.x实战专题案例、用Java实现JVM、基于JavaAgent的全链路监控、手写RPC框架、架构设计专题案例、源码分析等。
你用剑 、我用刀 ,好的代码都很烧 ,望你不吝出招 !

前言介绍

繁事都需要一个简单的入门的点,尤其学习程序员行业的知识最快的方式是先运行期helloworld,往往这样一个简单能运行的例子,就能解除你当前遇到的所有疑惑。切记,对于一个初学者,不建议上来就研究理论,实操往往更重要。本章节介绍使用netty端写一个能接收数据的socketServer服务端,通过实现通道适配器ChannelInboundHandlerAdapter.channelRead获取并并解析接收数据。

开发环境

1、jdk1.8【jdk1.7以下只能部分支持netty】
2、Netty4.1.36.Final【netty3.x 4.x 5每次的变化较大,接口类名也随着变化】
3、telnet 测试【可以现在你的win7机器上测试这个命令,用于链接到服务端的测试命令】

代码示例



1itstack-demo-netty-1-02
 2└── src
 3    ├── main
 4    │   └── java
 5    │       └── org.itstack.demo.netty.server
 6    │           ├── MyChannelInitializer.java
 7    │           ├── MyServerHandler.java
 8    │           └── NettyServer.java
 9    └── test
10         └── java
11             └── org.itstack.demo.netty.test
12                 └── ApiTest.java



MyChannelInitializer.java



1/**
 2 * 虫洞栈:https://bugstack.cn
 3 * 公众号:bugstack虫洞栈  {获取学习源码}
 4 * Create by fuzhengwei on 2019
 5 */
 6public class MyChannelInitializer extends ChannelInitializer<SocketChannel> {
 7
 8    @Override
 9    protected void initChannel(SocketChannel channel) {
10
11        System.out.println("链接报告开始");
12        System.out.println("链接报告信息:有一客户端链接到本服务端");
13        System.out.println("链接报告IP:" + channel.localAddress().getHostString());
14        System.out.println("链接报告Port:" + channel.localAddress().getPort());
15        System.out.println("链接报告完毕");
16
17        //在管道中添加我们自己的接收数据实现方法
18        channel.pipeline().addLast(new MyServerHandler());
19
20    }
21
22}



MyServerHandler.java



1/**
 2 * 虫洞栈:https://bugstack.cn
 3 * 公众号:bugstack虫洞栈  {获取学习源码}
 4 * Create by fuzhengwei on 2019
 5 */
 6public class MyServerHandler extends ChannelInboundHandlerAdapter {
 7
 8    @Override
 9    public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {
10        //接收msg消息
11        ByteBuf buf = (ByteBuf) msg;
12        byte[] msgByte = new byte[buf.readableBytes()];
13        buf.readBytes(msgByte);
14        System.out.print(new Date() + "接收到消息:");
15        System.out.println(new String(msgByte, Charset.forName("GBK")));
16    }
17
18}



NettyServer.java



1/**
 2 * 虫洞栈:https://bugstack.cn
 3 * 公众号:bugstack虫洞栈  {获取学习源码}
 4 * Create by fuzhengwei on 2019
 5 */
 6public class NettyServer {
 7
 8    public static void main(String[] args) {
 9        new NettyServer().bing(7397);
10    }
11
12    private void bing(int port) {
13        //配置服务端NIO线程组
14        EventLoopGroup parentGroup = new NioEventLoopGroup(); //NioEventLoopGroup extends MultithreadEventLoopGroup Math.max(1, SystemPropertyUtil.getInt("io.netty.eventLoopThreads", NettyRuntime.availableProcessors() * 2));
15        EventLoopGroup childGroup = new NioEventLoopGroup();
16        try {
17            ServerBootstrap b = new ServerBootstrap();
18            b.group(parentGroup, childGroup)
19                    .channel(NioServerSocketChannel.class)    //非阻塞模式
20                    .option(ChannelOption.SO_BACKLOG, 128)
21                    .childHandler(new MyChannelInitializer());
22            ChannelFuture f = b.bind(port).sync();
23            System.out.println("itstack-demo-netty server start done. {关注公众号:bugstack虫洞栈,获取源码}");
24            f.channel().closeFuture().sync();
25        } catch (InterruptedException e) {
26            e.printStackTrace();
27        } finally {
28            childGroup.shutdownGracefully();
29            parentGroup.shutdownGracefully();
30        }
31
32    }
33
34}



测试结果

启动服务端NettyServer




java NettyServer 发送消息 netty客户端发送数据_服务端


启动模拟器NetAssist


java NettyServer 发送消息 netty客户端发送数据_公众号_02


执行结果


1itstack-demo-netty server start done. {关注公众号:bugstack虫洞栈,获取源码}
 2链接报告开始
 3链接报告信息:有一客户端链接到本服务端
 4链接报告IP:127.0.0.1
 5链接报告Port:7397
 6链接报告完毕
 7Mon Aug 05 14:15:32 CST 2019接收到消息:你好,服务端。我是<bugstack虫洞栈>公众号,关注我获取源码。“点发送数据,不需要回车换行”
 8Mon Aug 05 14:15:34 CST 2019接收到消息:你好,服务端。我是<bugstack虫洞栈>公众号,关注我获取源码。“点发送数据,不需要回车换行”
 9Mon Aug 05 14:15:34 CST 2019接收到消息:你好,服务端。我是<bugstack虫洞栈>公众号,关注我获取源码。“点发送数据,不需要回车换行”
10Mon Aug 05 14:15:35 CST 2019接收到消息:你好,服务端。我是<bugstack虫洞栈>公众号,关注我获取源码。“点发送数据,不需要回车换行”
11
12Process finished with exit code -1