给需要排序的字段,加索引
但是,对索引列做任何运算,(concat + - * /)等操作,都会导致索引失效,仍会出现性能问题。
但是因为必须要用到的算法,所以必须要做运算。如何解决?如何优化?
不实时! 排行榜不是实时更新,比如半个小时更新一次。
把实时查询的数据,变成不实时的数据。
半个小时查询一次后,将数据放到另外一张表,或者放到redis。
优化方案:将原本实时查询的数据,变成每10分钟统计一次,将统计后的数据放到一张更新的表中,之后查询排行榜信息时,直接查询新的表即可。
新的表如何设计?
id,dest_id,dest_name,strategy_id,strategy_title,num,type,status_time
统计数量 统计时间
如何实现每10分钟去做一个事情?
定时任务。
定时统计方案:
1. TimerTask | ScheduledThreadPoolExecutor:JDK自带的定时任务类 不支持分布式
2. Spring Scheduled:任务调度组件,quartz
3. 分布式任务调度组卷:xxl-job,elastic-job 需要引入额外的服务
如何抉择?
Spring的定时任务。
Spring定时任务示例代码:每个两秒打印一次时间
每隔一段时间。
需要新创建一个服务。为什么?
如果在文章服务开启定时任务,会导致占用一定的cpu,对性能有一定的影响。
故新创建一个数据服务(travel-data-server)。新建一个定时任务类,@Component交给Spring容器管理。
启动类加@EnableScheduling
定时任务类方法加@Scheduled()注解。
corn表达式,是linux里面的一个机制。秒,分钟,小时,月中某日,月,周中某日
corn表达式口诀: “秒分时日月周”
Cron表达式用于指定计划任务(如在Unix、Linux和Spring框架中的定时任务)的执行时间。
要创建一个在每个工作日(星期一到星期五)凌晨两点执行的Cron表达式,你可以使用以下格式:
0 2 * * 1-5
这个表达式的各部分意义如下:
- `0` 分钟:表示在小时的开始时刻(即每小时的第0分钟)。
- `2` 小时:表示凌晨2点。
- `*` 日:表示每天。
- `*` 月:表示每个月。
- `1-5` 星期:表示星期一到星期五。
所以,这个Cron表达式代表着“在每个月的每天,
如果是星期一到星期五,那么在凌晨2点执行任务”。这正符合你的要求。
示例:
不一定非要去琢磨透corn表达式,工具是为我们提高效率而服务的,可借助corn表达式生成工具去生成。
实现:
改写为函数式编程:
如何排序?