适用于Java开发人员的Elasticsearch教程

课程大纲

Elasticsearch是基于Lucene的搜索引擎。 它提供了具有HTTP Web界面和无模式JSON文档的分布式多租户全文搜索引擎。 Elasticsearch是用Java开发的,并根据Apache许可的条款作为开源发布。 Elasticsearch是最受欢迎的企业搜索引擎,紧随其后的也是基于Lucene的Apache Solr。

Elasticsearch可用于搜索各种文档。 它提供可扩展的搜索,具有近实时搜索,并支持多租户。 Elasticsearch是分布式的,这意味着索引可以分为多个碎片,每个碎片可以具有零个或多个副本。 每个节点承载一个或多个分片,并充当协调器,以将操作委派给正确的分片。 重新平衡和路由是自动完成的。 相关数据通常存储在同一索引中,该索引由一个或多个主碎片以及零个或多个副本碎片组成。 创建索引后,无法更改主分片的数量。 (来源: 维基百科

在本课程中,我们提供了一系列教程,以便您可以开发自己的基于Elasticsearch的应用程序。 我们涵盖了从安装和操作到Java API集成和报告的广泛主题。 通过我们简单易懂的教程,您将能够在最短的时间内启动并运行自己的项目。

作者概述

Andriy在乌克兰的日托米尔工程技术学院获得了计算机科学硕士学位。 在过去的十五年中,他一直担任顾问/软件开发人员/高级软件开发人员/团队负责人的工作,成功完成了许多成功的项目,其中包括为北美和欧洲的客户提供的多个大型软件系统。

在他的职业生涯中,Andriy在企业体系结构,Web开发(ASP.NET,Java Server Faces,Play框架),软件开发实践(测试驱动的开发,持续集成)和软件平台(Sun JEE,Microsoft .NET)方面积累了丰富的经验。 ),面向对象的分析和设计,丰富的用户界面(MFC,Swing,Windows Forms / WPF),关系数据库管理系统(MySQL,SQL Server,PostgreSQL,Oracle),NoSQL解决方案(MongoDB,Redis)的开发和运行系统(Linux / Windows)。

Andriy在分布式(多层)软件系统,多线程应用程序,桌面应用程序,面向服务的体系结构和富Internet应用程序的开发方面具有丰富的经验。 自2006年以来,他主要在JEE / JSE平台上积极工作。

作为专业人士,他始终乐于不断学习和自我完善,以提高他真正热爱的工作的生产力。

经验教训

有效,快速和准确的搜索功能是绝大多数现代应用程序和软件平台的组成部分。 您正在运行的是小型电子商务网站,需要为客户提供产品目录搜索,或者您是服务提供商,需要公开API以使开发人员可以过滤用户和公司,或者您正在构建任何一种消息传递应用程序,从第一天开始,就必须在历史记录中查找对话

通过本教程的前一部分,我们对Elasticsearch是什么,它的基本概念以及它可以带给我们应用程序的搜索功能的功能有了很好的了解。 在本节中,我们将直接进入战斗,并在实践中运用我们的知识。 在本节中, curl和/或http将是我们将用来与Elasticsearch交朋友的唯一工具。

在本教程上半部分,我们仅通过命令行工具通过利用其大量RESTful API来掌握与Elasticsearch建立有意义的对话的技能。 这是非常少的知识,但是,当您开发Java / JVM应用程序时,您将需要比命令行更好的选择。 幸运的是, Elasticsearch在这一领域提供了多种产品。

在本教程的最后一部分中,我们将环顾四周,学习Elasticsearch如何完美地融入Java生态系统并激发许多有趣的项目。 说明这一点的最好方法之一是看一下ElasticsearchHibernate框架的结合,这是Java开发人员中管理持久层的一种极受欢迎的选择。

请确保转发此消息,让您的社交粉丝知道!

翻译自: https://www.javacodegeeks.com/2017/04/elasticsearch-tutorial-java-developers.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java开发必备知识框架包括Java语言基础、Java集合框架、Java设计模式、Java多线程、Java IO/NIO、Spring、Mybatis、Hibernate、Java Web编程、Java持久层技术、Java中间件等等。 ### 回答2: 当前Java开发必备的知识框架有很多,以下是一些常见的框架: 1. Spring框架:Spring是一个轻量级的框架,提供了IoC(控制反转)和AOP(面向切面编程)等功能,可以帮助开发者构建松耦合、可维护和可测试的应用程序。 2. Spring Boot框架:Spring Boot是Spring框架的增强版,通过提供默认配置和快速启动能力,简化了Spring应用程序的开发和部署过程。 3. Hibernate框架:Hibernate是一个ORM(对象关系映射)框架,可以简化Java开发者与数据库之间的交互。它提供了面向对象的API,使得开发者可以使用Java对象进行数据库操作。 4. MyBatis框架:MyBatis是一个持久化框架,通过使用XML或注解配置SQL语句,将Java对象映射到数据库操作上。它提供了灵活性和高度可定制化的特点。 5. Spring MVC框架:Spring MVC是Spring框架的一部分,用于构建基于模型-视图-控制器(MVC)架构的Web应用程序。它提供了简单易用的API和强大的处理请求和响应的能力。 6. Apache Struts框架:Struts是一个基于MVC架构的Web应用程序框架。它通过将请求、响应和业务逻辑分离,可以使开发者更加关注业务实现。 7. Spring Cloud框架:Spring Cloud是一套开发微服务架构的工具集合,包括服务注册与发现、负载均衡、熔断器等组件,可以简化开发分布式系统的复杂性。 以上框架都是当前Java开发必备的知识,根据项目需求和个人偏好,可以选择适合的框架来提升开发效率和项目质量。 ### 回答3: 当前Java开发必备的知识框架有很多,以下是一些重要的框架: 1. Spring框架:Spring是目前最流行的Java开发框架之一,它提供了一个全面的解决方案,包括依赖注入、面向切面编程和以及集成其他框架的能力。 2. Hibernate框架:Hibernate是一个Java持久化框架,用于简化和优化与数据库的交互。它提供了一个面向对象的数据访问层,让开发人员能够使用面向对象的方式来操作关系型数据库。 3. Spring Boot框架:Spring Boot是一个简化了Spring应用开发的框架,它提供了自动化配置和默认配置,减少了开发人员的配置工作,同时还提供了快速的应用部署和开发体验。 4. MyBatis框架:MyBatis是一个基于Java的持久层框架,它通过XML或注解的方式将Java对象和SQL语句进行映射,提供了一种轻量级的数据库访问解决方案。 5. Spring MVC框架:Spring MVC是一种基于Java的Web应用开发框架,它遵循MVC(模型-视图-控制器)的架构模式,提供了路由、参数绑定、数据验证等功能,使得开发Web应用更加简单和高效。 6. Apache Kafka框架:Apache Kafka是一个分布式流处理平台,它提供了高性能、可扩展的消息传递系统,用于处理实时数据流,适用于构建大规模的实时数据处理和分析应用。 除了以上提到的框架外,还有很多其他的框架,如Spring Cloud、Netty、Elasticsearch、Dubbo等,根据具体的开发需求和项目情况,选择合适的框架对于提高开发效率和产品质量非常重要。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值