0%

EasyProxy之golang初步学习

最近工作中遇到了golang的项目,稍稍对其产生了点兴趣,打算认真学习下,正巧在搭建mysql主备环境的时候发现如果用一个代理程序的话自己测试会方便很多(主要还是为了造轮子),于是这个基于golang的tcp proxy项目就产生了

需求

  1. 由于是为了学习golang,所以要在实现代理基础功能的前提下尽可能的用到golang的各种基础知识
  2. 不可能真单纯的为了玩,学一个东西除了为充实大脑,更为了能有实际用途,所以有必要工程化
  3. 程序不要太繁杂,毕竟这是我的第一个golang工程,来日方长

设计

结构图如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
+----------+                                           +------------+
| client |<--------+ | |
+----------+ +-------->+-----+<--------------->| server |
| | | |
+----------+ | | +------------+
| client |<----------------->| |
+----------+ | |
| | +------------+
+----------+ | L | | |
| client |<----------------->| B |<--------------->| server |
+----------+ | S | | |
| | +------------+
+----------+ | |
| client |<----------------->| |
+----------+ | | +------------+
| | | |
+----------+ +--------->+-----+<--------------->| server |
| client |<-------+ | |
+----------+ +------------+

最常见的负载均衡模式,但有几个点需要支持:

  1. 支持不同的调度策略,如:轮训,随机等
  2. 要有心跳检查机制,及时将有问题的后端server剔除,但也要在server恢复的时候恢复过来
  3. 有简单的监控,便于查看后端server的代理情况及客户端的连接情况
  4. 有简单的配置文件,便于修改
  5. …后续再加…

实现

github:EasyProxy
欢迎交流~

总结

在这个工程第一版结束后,较为深入的学习了slice,map,channel,struct,interface等结构,还玩了下golang的协程反射多态等特性,顺带掌握了下其工程化应当注意的包循环引入,debug,打包发布等问题
总之现在对golang的熟悉程度就不像看书那么虚了~

其他

如还有其他问题,欢迎喜欢golang的小伙伴联系我:xsank#foxmmail.com

  • 本文作者: Xsank
  • 本文链接: xsank.com/posts/3aeff3cd/
  • 版权声明: 本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!