NettyTheSniper

导航

基于Netty5.0入门案例一之NettyServer

前言介绍:

    凡是新知识都需要有个入门的案例,一个简单的输入输出就能解除你当前遇到的所有疑惑。不要总想着先学理论后学实战,新东方还135学理论,246学实战呢【800个床位不锈钢】。

  欢迎加入:itstack | Netty The Sniper 5360692


环境需求:

1、jdk1.7以上【jdk1.7以下只能部分支持netty】

2、Netty-all-5.0【netty3.x 4.x 5每次的变化较大,接口类名也随着变化】

3、telnet 测试【可以现在你的win7机器上测试这个命令,用于链接到服务端的测试命令】


代码部分:

======================

TestNettyServerBaseDemo

    src

        com.itstack

            ChildChannelHandler.java

            NettyServer.java

======================


ChildChannelHandler.java

  1. package com.itstack;
  2.  
  3. import io.netty.channel.ChannelInitializer;
  4. import io.netty.channel.socket.SocketChannel;
  5.  
  6. public class ChildChannelHandler extends ChannelInitializer<SocketChannel>{
  7.  
  8. @Override
  9. protected void initChannel(SocketChannel e) throws Exception {
  10.  
  11. System.out.println("报告");
  12. System.out.println("信息:有一客户端链接到本服务端");
  13. System.out.println("IP:"+e.localAddress().getHostName());
  14. System.out.println("Port:"+e.localAddress().getPort());
  15. System.out.println("报告完毕");
  16. }
  17.  
  18. }


NettyServer.java


  1. package com.itstack;
  2.  
  3. import io.netty.bootstrap.ServerBootstrap;
  4. import io.netty.channel.ChannelFuture;
  5. import io.netty.channel.ChannelOption;
  6. import io.netty.channel.EventLoopGroup;
  7. import io.netty.channel.nio.NioEventLoopGroup;
  8. import io.netty.channel.socket.nio.NioServerSocketChannel;
  9.  
  10. public class NettyServer {
  11.  
  12. public static void main(String[] args) {
  13. try {
  14. System.out.println("服务端开启等待客户端链接");
  15. new NettyServer().bing(7397);
  16. } catch (Exception e) {
  17. e.printStackTrace();
  18. }
  19. }
  20. public void bing(int port) throws Exception{
  21. EventLoopGroup bossGroup = new NioEventLoopGroup();
  22. EventLoopGroup workGroup = new NioEventLoopGroup();
  23. try {
  24. ServerBootstrap b = new ServerBootstrap();
  25. b.group(bossGroup, workGroup);
  26. b.channel(NioServerSocketChannel.class);
  27. b.option(ChannelOption.SO_BACKLOG, 1024);
  28. b.childHandler(new ChildChannelHandler());
  29. // 绑定端口
  30. ChannelFuture f = b.bind(port).sync();
  31. // 等待服务端监听端口关闭
  32. f.channel().closeFuture().sync();
  33. } finally {
  34. // 优雅的退出
  35. bossGroup.shutdownGracefully();
  36. workGroup.shutdownGracefully();
  37. }
  38. }
  39. }


测试运行:


1、启动NettyServer

2、控制台输出:

----------------------------------------------

服务端开启等待客户端链接

----------------------------------------------

3、开启DOS

4、输入telnet localhost 7397

5、控制台输出:

----------------------------------------------

报告
信息:有一客户端链接到本服务端
IP:localhost.localdomain
Port:7397
报告完毕

----------------------------------------------

posted on 2015-01-12 16:57  bugstack虫洞栈  阅读(252)  评论(0)    收藏  举报