既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
需健康度的检查机制, 整个链路避免单点
准确性难
库存, 抢购成功数, 创建订单数之间的一致性
高性能难
有限成本下需要做到极致的性能
缩短单请求访问路径, 减少IO
减少接口数, 降低吞吐数据量, 请求次数减少
需求
扣库存
预扣库存实现方案:
- 先扣库存, 然后创建订单, 支付
- 10分钟内不支付则取消订单, 避免不支付库存卖不出问题
无IO:
- 拆解, 扣库存与写订单分开
- 用内存
- 用本地内存
读商品信息
排队进度查看
读库存
原理
减而治之
CDN原理
CDN, 内容分发网络 ( Content Delivery Network)
- 缩短访问路径, 减少源站压力, 提高内容响应速度
- 为源站提高安全保护
减少读的压力( 把订单详情页内容通过CDN下发到不同的节点 )
Nginx限流
- 按连接数限速, 即并发数 ( ngx_http_limit_conn_module )
- 按请求速率限速, 根据IP限制单位时间内的请求数 ( ngx_http_limit_req_module )
# 配置
vim /etc/nginx/nginx.conf
# 在http模块里
http {
...
# 创建规则, 名称mylimit, 以用户的IP地址为key来限制请求速率1r/s, 申请空间为10m
limit_req_zone $binary\_remote\_addr\_zone=mylimit:10m rate=1r/s;
...
server {
...
# 应用规则, 在location里
location ~\.php$ {
# burst缓存空间, 若没有该参数, 则会严格按照上面限制来执行, 超过其限制速率就会拒绝访问, 返回503错误, 若有该参数, 即设置了缓存空间, 超过其限制速率不会直接拒绝而是排队等待, 若缓存空间设置的比较大, 后边的请求会一直排队, nodelay参数就是应对突发流量时, 减少后边等待时间, 即1s允许2个请求
limit_req_zone=mylimit burst=1 nodelay;
}
}
}
# 重启 nginx
/usr/sbin/nginx -s reload
# 查看进程
ps aux | grep nginx
# 错误日志
tail -f /var/log/nginx/error.log
限流算法
- 令牌桶算法
- 漏桶算法
- 计数器
单位时间计数器计数即可, 一般在应用程序中写的较多
异步队列
消息队列实际为链表, 头插尾出, 先进先出, 高并发下容易发生堵塞, 为避免消息丢失, 可通过写入实时消息队列进行延时处理
实时队列: 根据数据插入的前后顺序, 依次取出
延时队列: 不根据数据插入的前后顺序来依次取出, 而是根据指定某事件在某时间触发的权重机制来取出, 根据触发时间排序
- 提高请求响应速度, 如: 创建订单后的流程, 发push, 短信提醒等
- 瞬间高并发下, 可起到削峰, 如: 双十一零点并发创建订单
- 延时队列, 时间维度任务触发, 如: 发货提醒
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
的资料的朋友,可以添加戳这里获取](https://bbs.csdn.net/topics/618658159)**
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!