Netty 服务器端DEMO

package Demo;

import java.net.InetSocketAddress;
import java.util.concurrent.Executors;

import org.jboss.netty.bootstrap.ServerBootstrap;
import org.jboss.netty.buffer.ChannelBuffers;
import org.jboss.netty.channel.Channel;
import org.jboss.netty.channel.ChannelHandlerContext;
import org.jboss.netty.channel.ChannelPipeline;
import org.jboss.netty.channel.ChannelPipelineFactory;
import org.jboss.netty.channel.ChannelStateEvent;
import org.jboss.netty.channel.Channels;
import org.jboss.netty.channel.ExceptionEvent;
import org.jboss.netty.channel.MessageEvent;
import org.jboss.netty.channel.SimpleChannelHandler;
import org.jboss.netty.channel.SimpleChannelUpstreamHandler;
import org.jboss.netty.channel.socket.nio.NioServerSocketChannelFactory;
import org.jboss.netty.handler.codec.string.StringDecoder;

public class NIOServerDemo extends SimpleChannelUpstreamHandler {

/**
*
* @param args
*/
public static void main(String[] args) {
// server服务启动器
ServerBootstrap server = new ServerBootstrap(
new NioServerSocketChannelFactory(
Executors.newCachedThreadPool(),
Executors.newCachedThreadPool()));
server.setPipelineFactory(new ChannelPipelineFactory() {
@Override
public ChannelPipeline getPipeline() throws Exception {
// TODO Auto-generated method stub
ChannelPipeline pipeline = Channels.pipeline();
pipeline.addLast("decode", new StringDecoder());
pipeline.addLast("encode", new StringDecoder());
pipeline.addLast("thread", new NIOServerDemo());
return pipeline;
}
});
server.bind(new InetSocketAddress(8000));
System.out.println("服务已启动等待客户端连接……");
}

@Override
public void channelConnected(ChannelHandlerContext ctx, ChannelStateEvent e) {
//当有客户端连接上服务器执行的方法
System.out.println(e.getValue().toString() + "客户端已连接上服务器!");
}

@Override
public void messageReceived(ChannelHandlerContext ctx, MessageEvent e)
throws Exception {
//接收到客户端传来的数据进行相应处理并回复客户端
System.out.println("客户端信息:" + e.getChannel().getRemoteAddress());
System.out.println("服务器信息:" + e.getChannel().getLocalAddress());
System.out.println("接收到的消息:" + e.getMessage().toString());
e.getChannel().write(
ChannelBuffers.wrappedBuffer(e.getMessage().toString()
.getBytes()));
}
@Override
public void exceptionCaught(ChannelHandlerContext ctx, ExceptionEvent e) {
//当客户端掉线触发的方法
System.out.println("客户端"+ctx.getChannel().getRemoteAddress()+"是否断线:"+("远程主机强迫关闭了一个现有的连接。").equals(e.getCause().getMessage()));
}
}

时间: 2025-01-06 14:37:36

Netty 服务器端DEMO的相关文章

Netty学习之服务器端创建

一.服务器端开发时序图 图片来源:Netty权威指南(第2版) 二.Netty服务器端开发步骤 使用Netty进行服务器端开发主要有以下几个步骤: 1.创建ServerBootstrap实例 ServerBootstrap b=new ServerBootstrap(); ServerBootstrap是Netty服务器端的启动辅助类,提供了一系列的方法用于设置服务器端启动相关的参数. 2.设置并绑定Reactor线程池 EventLoopGroup bossGruop=new NioEvent

Spring Netty (实战)

Spring Netty 实战 疯狂创客圈 死磕Netty 系列之11 主要介绍的是SpringBoot整合Netty.在使用Netty之前,建议先了解Netty的基本原理,请参阅疯狂创客圈. 这里仅仅是使用Netty的第一步,这里介绍一个最简单的Demo--EchoServer,也就是回写服务器.就是无论客户端发啥字符串到服务器端,服务器端接收字符串后直接回写到客户端. 本篇内容纲要 环境要求 Spring +netty 服务器端 Spring +netty 客户端 Spring读取配置文件中

Netty实践(一):轻松入门

前言 Netty作为目前世界上最流行的NIO框架之一,在功能.性能.健壮性方面首屈一指,而且在很多项目中得到验证,比如消息中间件RocketMQ.分布式通信框架Dubbox.Netty内部实现复杂,但是提供给外界的API却十分简单,轻松的让我们的网络处理代码和业务逻辑处理代码分离开,从而快速的开发网络应用. 如果你还不了解JAVA NIO,JAVA SOCKET,可以先参考博主以前关于这方面的博客:<走进Java NIO的世界>.<Java NIO 服务器与客户端实现文件下载>.&

一个简单的Socket通信Demo

都忘了哪里下的了,留个记录 服务器端Demo: Server.java(服务器端运行主程序,直接运行): package cn.wjs; import java.net.InetAddress; import java.net.ServerSocket; import java.net.Socket; public class Server { private static final int port = 9999; private static final int backlog = 100

BIO、NIO、AIO系列二:Netty

一.概述 Netty是一个Java的开源框架.提供异步的.事件驱动的网络应用程序框架和工具,用以快速开发高性能.高可靠性的网络服务器和客户端程序. Netty是一个NIO客户端,服务端框架.允许快速简单的开发网络应用程序.例如:服务端和客户端之间的协议,它简化了网络编程规范. 二.NIO开发的问题 1.NIO类库和API复杂,使用麻烦. 2.需要具备Java多线程编程能力(涉及到Reactor模式). 3.客户端断线重连.网络不稳定.半包读写.失败缓存.网络阻塞和异常码流等问题处理难度非常大 4

看 Netty 在 Dubbo 中如何应用

目录: dubbo 的 Consumer 消费者如何使用 Netty dubbo 的 Provider 提供者如何使用 Netty 总结 前言 众所周知,国内知名框架 Dubbo 底层使用的是 Netty 作为网络通信,那么内部到底是如何使用的呢?今天我们就来一探究竟. 1. dubbo 的 Consumer 消费者如何使用 Netty 注意:此次代码使用了从 github 上 clone 的 dubbo 源码中的 dubbo-demo 例子. 代码如下: System.setProperty(

Netty高级

Netty快速入门 什么是Netty Netty 是一个基于 JAVA NIO 类库的异步通信框架,它的架构特点是:异步非阻塞.基于事件驱动.高性能.高可靠性和高可定制性. Netty应用场景 1.分布式开源框架中dubbo.Zookeeper,RocketMQ底层rpc通讯使用就是netty. 2.游戏开发中,底层使用netty通讯. 为什么选择netty 在本小节,我们总结下为什么不建议开发者直接使用JDK的NIO类库进行开发的原因: 1)      NIO的类库和API繁杂,使用麻烦,你需

【学习】010 Netty异步通信框架

Netty快速入门 什么是Netty Netty 是一个基于 JAVA NIO 类库的异步通信框架,它的架构特点是:异步非阻塞.基于事件驱动.高性能.高可靠性和高可定制性. Netty应用场景 1.分布式开源框架中dubbo.Zookeeper,RocketMQ底层rpc通讯使用就是netty. 2.游戏开发中,底层使用netty通讯. 为什么选择netty 在本小节,我们总结下为什么不建议开发者直接使用JDK的NIO类库进行开发的原因: 1)      NIO的类库和API繁杂,使用麻烦,你需

Netty实战入门详解——让你彻底记住什么是Netty(看不懂你来找我)

一.Netty 简介 Netty 是基于 Java NIO 的异步事件驱动的网络应用框架,使用 Netty 可以快速开发网络应用,Netty 提供了高层次的抽象来简化 TCP 和 UDP 服务器的编程,但是你仍然可以使用底层的 API. Netty 的内部实现是很复杂的,但是 Netty 提供了简单易用的API从网络处理代码中解耦业务逻辑.Netty 是完全基于 NIO 实现的,所以整个 Netty 都是异步的. Netty 是最流行的 NIO 框架,它已经得到成百上千的商业.商用项目验证,许多