美文网首页
Spring Boot 检索&定时任务

Spring Boot 检索&定时任务

作者: 分布式与微服务 | 来源:发表于2022-11-25 09:06 被阅读0次

    概述

    应用经常需要添加检索功能,开源的 ElasticSearch 是目前全文搜索引擎的首选。他可以快速的存储、搜索和分析海量数据。Spring Boot通过整合Spring Data ElasticSearch为我们提供了非常便捷的检索功能支持。

    Elasticsearch是一个分布式搜索服务,提供Restful API,底层基于Lucene,采用多shard(分片)的方式保证数据安全,并且提供自动resharding的功能,github等大型的站点也是采用了ElasticSearch作为其搜索服务。

    概念

    以 员工文档 的形式存储为例:一个文档代表一个员工数据。存储数据到 ElasticSearch 的行为叫做 索引 ,但在索引一个文档之前,需要确定将文档存储在哪里。

    一个 ElasticSearch 集群可以 包含多个 索引 ,相应的每个索引可以包含多个 类型 。 这些不同的类型存储着多个 文档 ,每个文档又有 多个 属性 。

    类似关系:

    • 索引-数据库

    • 类型-表

    • 文档-表中的记录

    • 属性-列


    整合ElasticSearch测试

    • 引入spring-boot-starter-data-elasticsearch

    • 安装Spring Data 对应版本的ElasticSearch

    • application.yml配置

    • Spring Boot自动配置的

      ElasticsearchRepository、ElasticsearchTemplate、Jest

    • 测试ElasticSearch

    异步任务

    在Java应用中,绝大多数情况下都是通过同步的方式来实现交互处理的;但是在处理与第三方系统交互的时候,容易造成响应迟缓的情况,之前大部分都是使用多线程来完成此类任务,其实,在Spring 3.x之后,就已经内置了@Async来完美解决这个问题。

    两个注解: @EnableAysnc、@Aysnc

    定时任务

    项目开发中经常需要执行一些定时任务,比如需要在每天凌晨时候,分析一次前一天的日志信息。Spring为我们提供了异步执行任务调度的方式,提供TaskExecutor 、TaskScheduler 接口。

    两个注解:@EnableScheduling、@Scheduled。

    cron表达式:



    邮件任务

    • 邮件发送需要引入spring-boot-starter-mail

    • Spring Boot 自动配置MailSenderAutoConfiguration

    • 定义MailProperties内容,配置在application.yml中

    • 自动装配JavaMailSender

    • 测试邮件发送


    相关文章

      网友评论

          本文标题:Spring Boot 检索&定时任务

          本文链接:https://www.haomeiwen.com/subject/vhrlnrtx.html