learning_tools 源码地址
go-kit (go-kit微服务)
1: v1 go-kit 微服务 基础使用 (HTTP)
2: v2 go-kit 微服务 添加日志(user/zap ,并为每个请求添加UUID)
3: v3 go-kit 微服务 身份认证 (JWT)
4: v4 go-kit 微服务 限流 (uber/ratelimit 和 golang/rate 实现)
5: v5 go-kit 微服务 使用GRPC(并为每个请求添加UUID)
6: v6 go-kit 微服务 服务注册与发现(etcd实现)
7: v7 go-kit 微服务 服务监控(prometheus 实现)
8: v8 go-kit 微服务 服务熔断(hystrix-go 实现)
9: v9 go-kit 微服务 服务链路追踪(jaeger 实现)(1)
10: v9 go-kit 微服务 服务链路追踪(jaeger 实现)(2)
11: v11 go-kit 微服务 添加一个简单网关
go_push (推送服务)
```base
├── gateway // 长连接网关服务器
│ ├── push_job.go // 分发任务
│ ├── room.go // 房间,可作为某一类型的推送管理中心
│ ├── room_manage.go // 房间管理
│ ├── ws_conn.go // 简单封装的websocket方法
│ ├── ws_handle.go // 处理websocket协议方法
│ └── ws_server.go // websocket服务
├── logic //逻辑服务器
│ ├── http_handle.go // 推送,房间相关
│ └── http_server.go // http服务
└── main.go
```
micro_agent (micro微服务)
1: base 基础方法
2: conf 配置文件
3:handler 对外处理方法
4:model 数据格式
5:proto protobuf 文件
project_layout (项目结构)
```base
详细介绍查看文件夹内README.me内容
├─api
├─build
├─cmd
├─configs
├─internal
│ ├─app
│ │ ├─common
│ │ ├─controller
│ │ ├─entity
│ │ ├─repository
│ │ ├─router
│ │ │ └─middleware
│ │ └─service
│ └─pkg
└─tool
```
all_packaged_library 里面封装了一些常用的库,有详细的介绍,持续更新
1: base 里面封装mysql,redis,mgo,minio文件储存库S3协议,雪花算法,退出程序方法,redis全局锁,日志库等(插件形式可单独引用)
2: logtool uber_zap日志库封装,可自动切分日志文件,压缩文件
3: perf ppoof小插件
4: push 集成苹果推送,google推送,华为推送
5: quit 优雅的退出程序
6: registrySelector 基于etcd实现的服务注册,发现,负载均衡
nsq (为你的服务插上docker_compose翅膀)
1: docker 为你的服务插上docker_compose翅膀
kafka (分布式消息发布订阅系统)
1: main 消息队列
NATS_streaming(分布式消息发布订阅系统--是由NATS驱动的数据流系统)
1: main 消息队列
nsq (分布式实时消息平台)
1: main 消息队列
grpc (grpc学习)
1: bidirectional_streaming_rpc 双向流grpc
2: server_side_streaming_rpc 服务端流grpc,也可以写成客户端流grpc
3: simple_rpc 简单grpc
rpc (rpc学习)
1: main rpc学习
prometheus (监控报警系统)
1: server Prometheus监控报警系统
jaeger (jaeger分布式链路追踪)
1: main jaeger分布式链路追踪
service_load_balancing (负载均衡)
1: fisher_yates_test 添加fisher-yates算法 负载均衡节点
service_registration_discovery (服务注册与发现)
1: etcdv3 通过etcd实现服务注册与发现
service_req_hystrix (熔断)
1: hystrix 学习并使用熔断(Hystrix)
service_req_limit (限流)
1: main 使用带缓存的channel实现限流
2: uber_ratelimit 使用uber_ratelimit实现限流
ini (配置文件库)
1: main 配置文件ini的读取,以及自动匹配到结构体里面
minio (对象存储服务)
1: minio 对象存储服务使用
mysql (mysql服务器)
1: main 简单的mysql使用
redis (redis相关)
1: bloom_filter redis 实现BloomFilter过滤器
2: lock redis实现全局锁
3: pipeline redis事务
4: subscription redis发布订阅
mongodb (mongodb服务器)
1: mgo.v2 mgo.v2库的基础使用学习
2: mongo-go-driver 官方库的demo,以及事务提交(不能是单节点)
gin (web框架gin学习)
1: mvc 模式,swagger文档 可作为基础学习gin
jwt (JSON WEB TOKEN)
1: jwt 学习使用
zaplog (uber zap日志封装)
1: zap 日志封装
snow_flake (雪花算法)
1: main 雪花算法
encryption_algorithm (双棘轮算法, KDF链,迪菲-赫尔曼棘轮,x3dh)
1: aes ase-(cfb,cbc,ecb)-(128,192,256)加解密方法
2: curve25519 椭圆曲线算法
3: 3curve25519 双棘轮算法,KDF链
LRU(缓存淘汰算法)
1: list lru 缓存淘汰算法
tcp (tcp协议实现)
1: 实现网络库,封包,解包 len+tag+data 模式
websocket (websocket协议实现)
1: 实现网络库
binary_conversion (进制转换)
1: 10to36 10进制转36进制
2: 10to62 10进制转62进制
3: 10to76 10进制转76进制
4: binary 用一个int64来描述开关(用户设置很多建议使用)
job_worker_mode (job_worker模式)
1: worker job_worker模式,可提高系统吞吐量
filewatch (监控文件变化)
1: main 监控文件变化 可实现自动构建
push (一个简单的推送服务)
1: main 推送服务
goquery (网页解析工具)
1: main 可以作为爬虫解析网页使用
active_object(并发设计模式)
1: active_object Go并发设计模式之Active Object
heap (优先级队列)
1: heap 利用heap创建一个优先级队列
cli (go命令行交互)
1: main go命令行交互
context (context包学习)
1: main context包学习
err (error 相关)
1: main golang 1.13 error 相关
interface (interface包学习)
1: main interface包学习
2: middleware Golang 基于interface 实现中间件
syncPool (syncPool包学习)
1: main syncPool包学习
reflect (reflect包学习)
1: main reflect包学习