EasyProxy 之 golang 初步学习
最近工作中遇到了golang的项目,稍稍对其产生了点兴趣,打算认真学习下,正巧在搭建mysql主备环境的时候发现如果用一个代理程序的话自己测试会方便很多(主要还是为了造轮子),于是这个基于 golang 的tcp proxy项目就产生了
需求
- 由于是为了学习 golang ,所以要在实现代理基础功能的前提下尽可能的用到 golang 的各种基础知识
- 不可能真单纯的为了玩,学一个东西除了为充实大脑,更为了能有实际用途,所以有必要工程化
- 程序不要太繁杂,毕竟这是我的第一个
golang工程,来日方长
设计
结构图如下:
+----------+ +------------+
| client |<----+ | |
+----------+ +--->+-----+<-------->| server |
| | | |
+----------+ | | +------------+
| client |<-------->| |
+----------+ | |
| | +------------+
+----------+ | L | | |
| client |<-------->| B |<-------->| server |
+----------+ | S | | |
| | +------------+
+----------+ | |
| client |<-------->| |
+----------+ | | +------------+
| | | |
+----------+ +--->+-----+<-------->| server |
| client |<----+ | |
+----------+ +------------+
最常见的负载均衡模式,但有几个点需要支持:
- 支持不同的调度策略,如:轮训,随机等
- 要有心跳检查机制,及时将有问题的后端 server 剔除,但也要在 server 恢复的时候恢复过来
- 有简单的监控,便于查看后端 server 的代理情况及客户端的连接情况
- 有简单的配置文件,便于修改
- ...后续再加...
实现
github:EasyProxy
其他
如有问题,欢迎其他喜欢golang的小伙伴联系:xsank#foxmmail.com