栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

实时解答SpringCloud+Nginx秒杀实战,Zuul内部网关实现秒杀限流

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

实时解答SpringCloud+Nginx秒杀实战,Zuul内部网关实现秒杀限流

*/

rateLimitService.cacheSha1();

redisSeckillServiceImpl.cacheSha1();

return RestOut.success(goodDTO).setRespMsg(“秒杀开启成功”);

}

return RestOut.error(“秒杀开启失败”);

}

}

限流器初始化之后,就可以在Zuul内部网关或者Nginx外部网关进行请求拦截时使用分布式限流器进行限流。Zuul内部网关的限流拦截过程如图10- 《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》无偿开源 威信搜索公众号【编程进阶路】 13所示。

图10-13 Zuul内部网关限流拦截示意图

Zuul网关限流过滤器类SeckillRateLimitFilter的代码如下:

package com.crazymaker.springcloud.cloud.center.zuul.filter;

//省略import

@Slf4j

@ConditionalOnBean(RedisRateLimitImpl.class)

@Component

public class SeckillRateLimitFilter extends ZuulFilter

{

@Resource(name = “redisRateLimitImpl”)

RateLimitService redisRateLimitImpl;

@Override

public String filterType()

{

return “pre”; //路由之前

}

@Override

public int filterOrder()

{

return 0;

}

@Override public boolean shouldFilter()

{

RequestContext ctx = RequestContext.getCurrentContext();

HttpServletRequest request = ctx.getRequest();

if (!ctx.sendZuulResponse())

{

return false;

}

if (request.getRequestURI().startsWith

(“/seckill-provider/api/seckill/redis/token/v1”))

{

return true;

}

return false;

}

@Override

public Object run()

{

RequestContext ctx = RequestContext.getCurrentContext();

HttpServletRequest request = ctx.getRequest();

String goodId = request.getParameter(“goodId”);

if (goodId != null)

{

String cacheKey = “seckill:” + goodId;

Boolean limited = redisRateLimitImpl.tryAcquire(cacheKey);

if (limited)

{

String msg = “参与抢购的人太多,请稍后再试一试”;

fallback(ctx, msg);

return null;

}

return null;

} else

{

String msg = “必须输入抢购的商品”;

fallback(ctx, msg);

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/860451.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号