什么是Echo服务?
就是回写应答服务,客户端发送什么数据,服务端就响应什么数据
什么作用呢?
检测调试对应的服务 压测网络编程模型
Step1:项目创建
选择Maven
Step2:外层pom引入依赖
线程组 启动类 处理器的类名都是有相对意义的 你去看Netty源码也是一样的
Step1:Server服务端
import io.netty.bootstrap.ServerBootstrap;
import io.netty.channel.ChannelFuture;
import io.netty.channel.ChannelInitializer;
import io.netty.channel.EventLoopGroup;
import io.netty.channel.nio.NioEventLoopGroup;
import io.netty.channel.socket.SocketChannel;
import io.netty.channel.socket.nio.NioServerSocketChannel;
/**
* 启动类
*/
public class EchoServer {
/**
* 端口号
*/
private int port;
private EchoServer(int port){
this.port = port;
}
public static void main(String [] args) throws InterruptedException {
int port = 8080;
//判断传入参数是否有端口号
if (args.length > 0){
port = Integer.parseInt(args[0]);
}
new EchoServer(port).run();
}
/**
* 启动流程
* 使用Netty线程模型中的Reactor主从线程模型
*/
public void run() throws InterruptedException {
//Netty封装好的主从线程模型 配置服务端线程组
EventLoopGroup bossGroup = new NioEventLoopGroup();