getty 又双叒叕更新啦,一个长得有点像netty的网络框架
getty 又双叒叕更新啦!!!
本次更新主要是添加了UDP的支持。。。
getty是基于java nio(俗称nio1)封装了UDP,借助getty本身的架构设计,getty udp的性能表现也非常不错
基于getty良好的设计模式,getty udp的使用方式与tcp差别不大。
唯一的区别就是需要指定socketChannel为UDP。默认不指定是TCP
需要指定UDP的消息编解码器
//对于UDP而言,只有DatagramPacketEncoder、DatagramPacketDecoder两个处理器是有效的
//原因在于UDP本身不存在连接,因而其他处理器即使配置了也是没有效果的
defaultChannelPipeline.addLast(new DatagramPacketEncoder());
defaultChannelPipeline.addLast(new DatagramPacketDecoder());
//服务器端
AioServerStarter server = new AioServerStarter(8888);
//唯一的区别就是需要指定socketChannel为UDP。默认不指定是TCP
server.socketChannel(SocketChannel.UDP).channelInitializer(new ChannelInitializer() {
@Override
public void initChannel(AioChannel channel) throws Exception {
//获取责任链对象
DefaultChannelPipeline defaultChannelPipeline = channel.getDefaultChannelPipeline();
//对于UDP而言,只有DatagramPacketEncoder、DatagramPacketDecoder两个处理器是有效的
//原因在于UDP本身不存在连接,因而其他处理器即使配置了也是没有效果的
defaultChannelPipeline.addLast(new DatagramPacketEncoder());
defaultChannelPipeline.addLast(new DatagramPacketDecoder());
//添加自定义的简单消息处理器
defaultChannelPipeline.addLast(new SimpleHandler());
}
}).start();
------------------------------------------------------------------
//客户端
AioClientConfig aioConfig = new AioClientConfig();
//Host与port无需指定也没有关系,指定了也没有效果
aioConfig.setHost("127.0.0.1");
aioConfig.setPort(port);
aioConfig.setClientChunkSize(512 * 1024 * 1024);
aioConfig.setBufferWriterQueueSize(2 * 1024 * 1024);
AioClientStarter client = new AioClientStarter(aioConfig);
client.socketChannel(SocketChannel.UDP).channelInitializer(new ChannelInitializer() {
@Override
public void initChannel(AioChannel channel) throws Exception {
//责任链
DefaultChannelPipeline defaultChannelPipeline = channel.getDefaultChannelPipeline();
defaultChannelPipeline.addLast(new DatagramPacketEncoder());
defaultChannelPipeline.addLast(new DatagramPacketDecoder());
//定义消息解码器
defaultChannelPipeline.addLast(new SimpleHandler());
}
});
try {
client.start();
} catch (Exception e) {
e.printStackTrace();
}
//发送个消息给服务器
Thread.sleep(2000);
AioChannel aioChannel = client.getAioChannel();
String s = "hello getty";
byte[] msgBody = s.getBytes("utf-8");
//UDP消息发送的是DatagramPacket 发送的目标服务器在DatagramPacket 中指定
DatagramPacket datagramPacket = new DatagramPacket(msgBody, msgBody.length, new InetSocketAddress("127.0.0.1", 8888));
aioChannel.writeAndFlush(datagramPacket);
SimpleHandler的类型指定为 > DatagramPacket
public class SimpleHandler extends SimpleChannelInboundHandler<DatagramPacket> {
@Override
public void channelAdded(AioChannel aioChannel) {
System.out.println("连接成功");
}
@Override
public void channelClosed(AioChannel aioChannel) {
System.out.println("连接关闭了");
}
@Override
public void channelRead0(AioChannel aioChannel, DatagramPacket datagramPacket) {
System.out.println("读取消息了:" + new String(datagramPacket.getData()));
System.out.println("客户端地址:" + datagramPacket.getAddress().getHostName() + ":" + datagramPacket.getPort());
}
@Override
public void exceptionCaught(AioChannel aioChannel, Throwable cause, PipelineDirection pipelineDirection) {
System.out.println("出错了");
}
}
getty的特点
1、完全基于java nio2封装,整体代码代码结构很轻量,也非常简单易用。
2、借鉴了netty和其他框架的部分优秀设计思想,如责任链、内存池化、零拷贝等优秀的设计模式。拥有媲美netty的高效性能(有自卖自夸嫌疑 )。
3、提供了常用的多个插件(String处理器,protobuf消息处理器,心跳超时处理器、ip过滤等)满足大部分开发场景。
4、getty可直接在安卓环境中使用(api 26+ 或 android 8.0+)
5、getty同时提供了TCP和UDP的支持,并且使用方式几乎一致,大大提高了易用性。
5、handler处理器支持使用过程中的热拔插设计,各处理器可以灵活组合,。
6、框架拥有非常好的拓展性,处理器拓展非常简单,大大降低了开发成本
7、高效的性能和靠谱的稳定性,在使用过程中得到了很好的验证
8、与netty结合使用。使用过程与netty非常类似,只要有netty是使用经验,使用getty几乎不需要额外学习。
谢谢。。。。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
-
上一篇
阿里云智能基础产品技术月刊2019年7月——永不停机的计算服务
一、 商用产品技术 TOP1 面向 I/O 密集型关键业务场景,全球首款百万级 IOPS 的企业级云盘(ESSD云盘)正式商业化 为满足企业级客户全站上云场景下对存储性能需求,阿里云于2018年正式推出了全球首款百万级IOPS的企业级ESSD云盘,搭配ECS企业级云服务器使用。ESSD可提供单盘高达100万IOPS的随机读写能力,相比SSD云盘分别提升了40 倍性能上限和降低了 70% 读写时延,为客户提供更高的性价比体验。在实际的业务场景测试下,以 MySQL 和PostgreSQL 为例,采用 ESSD 云盘可获得 3-4 倍的 TPS 性能提升。此外,ESSD云盘支持不停机扩展容量、不停机提高IO读写性能上限、数据加密等高级数据服务功能,给客户在弹性、安全等方面带来了更多的技术红利。同时,ESSD云盘作为IaaS层平台型产品,也广泛服务于内部客户,包括阿里巴巴经济体上云业务、RDS、NAS等多个业务方。ESSD云盘已经于2019年6月28日正式商业化,目前服务于内外部客户超过2600个,数量高达5万+块,总容量超过22PB+。ESSD云盘商业化也得到了基础产品事业部、基础设施事业...
-
下一篇
JavaEE基础(05):过滤器、监听器、拦截器,应用详解
本文源码:GitHub·点这里 || GitEE·点这里 一、Listener监听器 1、概念简介 JavaWeb三大组件:Servlet,Listener,Filter。监听器就是指在应用程序中监听相关对象状态变化的组件。 2、事件源对象 指被监听对象。 ServletContext ServletContextListener生命周期监听,它有两个方法,出生时调用contextInitialized(),销毁时调用contextDestroyed(); ServletContextAttributeListener属性监听,它有三个方法,添加属性attributeAdded(),替换属性attributeReplaced(),移除属性时attributeRemoved()。 HttpSession HttpSessionListener生命周期监听:它有两个方法,出生时调用sessionCreated(),销毁时调用sessionDestroyed(); HttpSessioniAttributeListener属性监听:它有三个方法,添加属性attributeAdded(),替换...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS8编译安装MySQL8.0.19
- MySQL数据库在高并发下的优化方案
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- Dcoker安装(在线仓库),最新的服务器搭配容器使用
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Docker快速安装Oracle11G,搭建oracle11g学习环境