沉淀、分享、成长,专注于原创专题案例,以最易学习编程的方式分享知识,让自己和他人都能有所收获。目前已完成的专题有;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
启动模拟器NetAssist
执行结果
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