最近了解了些 Java NIO、Socket 网络编程部分的东西,也看了 Netty 的部分源码和博客讲解,遂写了个残疾版的基于 Reactor 模式的 Java socket 服务器,觉得还可以,分享一哈 🤣
TCP 层的架构按双线程来,一个 Acceptor 和一个 Worker,中间用一个并发 Channel 队列连接,信息流的处理参考了 Netty 的 Pipeline 模式(其实原先并不是这样的,但写着写着就往这边靠了),虽然在设计细节上跟 Netty 相距甚远。
目前已经实现了 TCP 层跟 HTTP 层,可以通过构建自己的 handler 实现对 HTTPRequest 的处理和 HTTPResponse 的构造,或者自己基于 TCP 层写一个 RPC 协议、Socks 协议什么的...
整体架构大概是这样子
提前元旦快落,球球大家给个 star 🥳
1
takemeh 2019-12-28 14:44:14 +08:00 via Android
很高深的东西啊
|
6
monkeyWie 2019-12-31 09:39:19 +08:00
可以把 websocket 也实现下🤓
|
7
dongcidaci 2021-11-29 20:53:30 +08:00 via Android
图是用啥画的啊大佬,挺清晰的
|
8
aneureka OP @dongcidaci #7 draw.io 🤣
|