火车抢票系统的实现(四)页面级高并发秒杀优化

本文介绍了优化高并发秒杀系统的方法,包括页面缓存、URL缓存、对象缓存的实现,如利用Redis缓存商品列表和详情页;页面静态化,将页面缓存到客户端,改造秒杀接口和减少库存的SQL;以及静态资源优化和CDN的使用,以提升系统性能和QPS。
摘要由CSDN通过智能技术生成

优化思路

  1. 页面缓存+ URL缓存+对象缓存
  2. 页面静态化,前后端分离
  3. 静态资源优化
  4. CDN优化

(一)页面缓存+ URL缓存+对象缓存

redis缓存详情页

(1)页面缓存:商品列表

  1. 取缓存
  2. 手动渲染模版
  3. 结果输出

访问一个页面的时候不是直接系统渲染,而是从缓存里面取,缓存里面没有才去渲染(同时缓存到redis当中)

以goods_list为例:

因为要把goodsList存到redis当中,所以在redis包中new一个class:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-29TFn51l-1581767254371)(/Users/dylan/Library/Application Support/typora-user-images/image-20200211213815473.png)]

/* GoodsController */

//原本是这样的
@RequestMapping("to_list")
	public String list(Model model,MiaoshaUser user){
   
		model.addAttribute("user",user);
		List<GoodsVo> listGoodsVo = goodsService.listGoodsVo();
		model.addAttribute("goodsList",listGoodsVo);
		return "goods_list";
}

//变成这样
@Autowired
ThymeleadViewResolver thymeleadViewResolver;

@Autowired
ApplicationContext applicationContext;

@RequestMapping(value="to_list",produces="text/html")
@ResponseBody
	public String list(Model model,MiaoshaUser user){
   
		model.addAttribute("user",user);
    //从缓存里面先取出来
	    String html = redisService.get(GoodsKey.getGoodsList, "", String.class);
	    //如果不为空就直接返回
			if(!StringUtils.isEmpty(html)){
   
					return html;
	    }
		List<GoodsVo> listGoodsVo = goodsService.listGoodsVo();
		model.addAttribute("goodsList",listGoodsVo);
		//return "goods_list";
    
    
	    //否则需要手动渲染
		WebContext ctx = new WebContext( request, response, request.getServletContext(), request.getLocale(),model.asMap()); 
		html = thymeleafViewResolver.getTemplateEngine().process("goods_list",ctx);
	    if(StringUtils.isEmpty(html)){
   
	      redisService.set(GoodsKey.getGoodsList,"",html);
	    }
	    return html;
}

手动渲染的时候,我们需要利用

thymeleafViewResolver.getTemplateEngine().process(String templates, webContext ctx)

这个方法

首先要生成WebContext

WebContext ctx = new WebContext( request, response, request.getServletContext(), request.getLocale(),model.asMap()); 

再传入到上面那个方法里面就可以了

注意点

  1. 页面有效期比较短,所以需要修改KeyPrefix中的expireSeconds

    package com.pro.miaosha.redis;
    
    public class GoodsKey extends BasePrefix{
         
    	private GoodsKey(int expireSeconds,String prefix) {
         
    		super(expireSeconds,prefix);
    	}
    	public static GoodsKey getGoodsList = new GoodsKey(60,"gl");//这里设置时间为60s
    }
    
  2. 验证:访问完http://localhost:8080/goods/to_list之后查看redis发现已经被缓存了

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6ETZzAVH-1581767254372)(/Users/dylan/Library/Application Support/typora-user-images/image-20200211223427098.png)]

(2) URL缓存:商品详情

商品详情页面:

//原本是这样的
@RequestMapping("/to_detail/{goodsId}")
	public String detail(
			Model model , 
			MiaoshaUser user,
			@PathVariable("goodsId")long goodsId
			) {
   
		model.addAttribute("user",user);
		
		GoodsVo goods = goodsService.getGoodsVoByGoodsId(goodsId);
		model.addAttribute("goods",goods);
		
		long startAt = goods.getStartDate().getTime();
		long endAt = goods.getEndDate().getTime();
		long now = System.currentTimeMillis();
		
		int miaoshaStatus = 0;
		int remainSeconds = 0;
		
		if(now < startAt) {
   
			miaoshaStatus = 0;
			remainSeconds = (int)((startAt-now)/1000);
		}
		else if(now > endAt) {
   
			miaoshaStatus = 2;
			remainSeconds = -1;
		}
		else {
   
			miaoshaStatus = 1;
			remainSeconds = 0;
		}
		model.addAttribute("miaoshaStatus",miaoshaStatus);
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值