go语言在网络服务模块有着得天独厚的优势;传送门详细介绍了涉及到的分布式相关技术。
分布式id生成器
Snowflake(雪花算法),由Twitter提出并开源,可在分布式环境下用于生成唯一ID的算法。
生成的Id是64位(int64)数值类型,包含4部分:
- 41bit的时间戳(毫秒):一般是相对系统上线时间的毫秒数(可用69年);
- 5bit的数据中心id+5bit的机器id:表示工作的计算机;实际使用时可根据情况调整两者间的比例;
- 12bit序列号:区分同一个计算机在相同毫秒时间内的生产的ID(支持1毫秒4096条);
github.com/bwmarrin/snowflake
分布式锁
setnx
- 设定成功时,为上锁;
- 释放锁时,删除对应的键;
也可通过zookeeper或etcd来模拟;
负载均衡
从n个服务节点中,挑选一个的思路了:
- 按顺序挑
- 随机挑一个
- 根据某种权重,对节点进行排序,选择权重最大/小的那一个