既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
预扣库存实现方案:
- 先扣库存, 然后创建订单, 支付
- 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, 短信提醒等
- 瞬间高并发下, 可起到削峰, 如: 双十一零点并发创建订单
- 延时队列, 时间维度任务触发, 如: 发货提醒
分而治之
Nginx负载均衡
算法
- Round-robin (轮询)
- Weight-round-robin (带权轮询), 推荐
- IP-hash (IP哈希)
链路实现漏斗型流量
读优化
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
涵盖了95%以上Go语言开发知识点,真正体系化!**
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新