getty

    1、getty是完全基于java nio封装的高性能网络框架。

    2、getty可在项目中使用,也可以用于帮助你更好的学习java aio

    3、getty完全开源,基于 Apache License 2.0 开源协议。

    4、getty的目的是为了降低对java socket nio的使用成本,帮助提高工作效率。

    5、欢迎大家提供建议或者提交代码分支帮助getty更好的完善提高,如果觉得getty对你有帮助,希望给一个start鼓励一下

    getty名称的由来

    取名getty主要是作者过去使用netty比较多,对netty表示尊敬,以及getty本身借鉴了netty的设计思想。

    然后作者本人姓氏的拼音首字符是“G”,因而取名getty。

    1、作者本人是一名码农,平时比较喜欢研究代码,特别是网络通讯方面。

    2、JDK1.7升级了NIO类库,升级后的NIO类库被称为NIO 2.0。正式提供了异步文件I/O操作,同时提供了与UNIX网络编程事件驱动I/O对应的AIO。AIO的发布使得实现一套网络通讯框架变得相对简单。

    4、有了netty为何还要自己造轮子?这里有两个原因,其一是本人就喜欢造轮子,这是病,改不了。其二,netty经过多年的发展,其生态体系已经比较庞大,导致其代码比较臃肿,再者其高深的设计哲学我等凡夫俗子很难悟其精髓。因而索性造一个。

    5、netty毕竟是老外的东西。并且国内也有许多优秀的开源框架,例如t-io、smark-socket也是非常优秀的网络框架。想想,为何不能直接搞一个呢,于是抽业余时间写了getty。

    getty的特点:

    1、完全基于java nio2封装,整体代码代码结构很轻量,也非常简单易用。

    2、借鉴了netty和其他框架的部分优秀设计思想,如责任链、内存池化、零拷贝等优秀的设计模式。拥有媲美netty的高效性能(有自卖自夸嫌疑 :joy: )。

    3、提供了常用的多个插件(String处理器,protobuf消息处理器,心跳超时处理器、ip过滤等)满足大部分开发场景。

    4、getty可直接在安卓环境中使用(api 26+ 或 android 8.0+)

    5、getty同时提供了TCP和UDP的支持,并且使用方式几乎一致,大大提高了易用性。

    5、handler处理器支持使用过程中的热拔插设计,各处理器可以灵活组合,。

    6、框架拥有非常好的拓展性,处理器拓展非常简单,大大降低了开发成本

    8、与netty结合使用。使用过程与netty非常类似,只要有netty是使用经验,使用getty几乎不需要额外学习。

    Maven

    在项目的pom.xml的dependencies中加入以下内容:

    Gradle

    非Maven项目

    可直接到中央仓库下载jar包导入到工程中

    链接:https://mvnrepository.com/artifact/com.gettyio/getty-core

    更多详情与文档

    更多详情,请点击 wiki文档

    create by

    gogym