最近了解了些 Java NIO、Socket 网络编程部分的东西,也看了 Netty 的部分源码和博客讲解,遂写了个残疾版的基于 Reactor 模式的 Java socket 服务器,觉得还可以,分享一哈 🤣
TCP 层的架构按双线程来,一个 Acceptor 和一个 Worker,中间用一个并发 Channel 队列连接,信息流的处理参考了 Netty 的 Pipeline 模式(其实原先并不是这样的,但写着写着就往这边靠了),虽然在设计细节上跟 Netty 相距甚远。
目前已经实现了 TCP 层跟 HTTP 层,可以通过构建自己的 handler 实现对 HTTPRequest 的处理和 HTTPResponse 的构造,或者自己基于 TCP 层写一个 RPC 协议、Socks 协议什么的...
整体架构大概是这样子
提前元旦快落,球球大家给个 star 🥳
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.