为什么需要Netty?
-
假如你的系统要支撑高并发的用户场景,你可能会进行搜索如何搭建高性能的Java网络编程,你可能会看到Netty是一款异步的事件驱动的网络应用程序框架,支持快速地开发可维护的高性能的面向协议的服务器和客户端
-
接着你的下一步多半是阅读一些博客,看一些例子,然后写点代码试试,如果掌握了网络通信编程的技术,遇到的问题可能会少点,否则你可能看不懂在说些什么
-
高性能系统不仅要求超一流的编程技巧,还需要几个复杂领域(网络编程、多线程处理和并发)的专业知识,Netty优雅地处理了这些领域的知识,使得我们可以将精力放在业务处理上,而不是关注网络编程方便的非业务逻辑
-
Netty的架构方法和设计原则是:每个小点都和它的技术性内容一样重要,穷其精妙。
1.关注点分离——业务和网络逻辑解耦
2.模块化和可复用性
3.可测试性作为首要的要求 -
早期的网络编程中,需要花费大量的事件取学习复杂的C语言套接字库,去兼容不同的操作系统。尽管Java引入了足够多的Socket Facade(门面)来隐藏一些棘手的细节问题,但是创建一个复杂的客户端/服务端协议仍然需要大量的样板代码(以及相当多的底层研究才能使它整个流畅地运行起来)
package esay;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;