Java를 사용하여 Elasticsearch 기반의 전체 텍스트 검색 애플리케이션을 개발하는 방법
Java를 사용하여 Elasticsearch 기반의 전체 텍스트 검색 응용 프로그램을 개발하는 방법
전체 텍스트 검색은 오늘날의 정보화 시대에 많은 양의 사용자가 요구하는 키워드를 빠르고 정확하게 검색할 수 있는 매우 중요한 기술입니다. 텍스트 데이터 또는 관련 정보. 오픈 소스 분산 검색 엔진인 Elasticsearch는 효율적인 전체 텍스트 검색 기능, 실시간 데이터 분석 및 확장성으로 인해 널리 사용되었습니다. 이 기사에서는 Java를 사용하여 Elasticsearch 기반의 전체 텍스트 검색 애플리케이션을 개발하는 방법을 소개하고 구체적인 코드 예제를 제공합니다.
- 준비 작업
개발을 시작하기 전에 다음 작업을 준비해야 합니다. - Java 개발 환경(JDK) 설치
- Elasticsearch 서버 설치 및 서비스 시작
- Elasticsearch Java 클라이언트 라이브러리 가져오기, 예: Maven을 사용하여 다음 종속성을 가져옵니다.
<dependencies> <dependency> <groupId>org.elasticsearch</groupId> <artifactId>elasticsearch</artifactId> <version>7.10.0</version> </dependency> </dependencies>
- Create Elasticsearch 클라이언트
먼저 Elasticsearch 서버에 연결하기 위한 클라이언트를 생성해야 합니다. 클라이언트 인스턴스는 다음 코드를 사용하여 생성할 수 있습니다:
import org.elasticsearch.client.RestClient; import org.elasticsearch.client.RestClientBuilder; import org.elasticsearch.client.RestHighLevelClient; public class ElasticsearchClient { public static RestHighLevelClient createClient() { // 配置Elasticsearch服务器地址 RestClientBuilder builder = RestClient.builder(new HttpHost("localhost", 9200, "http")); // 创建高级客户端实例 RestHighLevelClient client = new RestHighLevelClient(builder); return client; } }
- Create index
다음으로 문서 데이터를 저장할 인덱스(Index)를 생성해야 합니다. 인덱스는 데이터베이스의 테이블과 유사하며 다양한 인덱스에 다양한 유형의 문서 데이터를 저장할 수 있습니다. 다음 코드를 사용하여 인덱스를 만들 수 있습니다.
import org.elasticsearch.action.admin.indices.create.CreateIndexRequest; import org.elasticsearch.action.admin.indices.create.CreateIndexResponse; import org.elasticsearch.client.RequestOptions; import org.elasticsearch.client.RestHighLevelClient; import org.elasticsearch.common.xcontent.XContentType; import org.elasticsearch.common.xcontent.XContentBuilder; import org.elasticsearch.common.xcontent.XContentFactory; import org.elasticsearch.common.xcontent.XContentFactory.*; public class IndexCreator { public static void createIndex(String indexName) { try { RestHighLevelClient client = ElasticsearchClient.createClient(); // 创建索引请求 CreateIndexRequest request = new CreateIndexRequest(indexName); // 设置索引的映射规则 XContentBuilder mappingBuilder = XContentFactory.jsonBuilder(); mappingBuilder.startObject(); mappingBuilder.startObject("properties"); mappingBuilder.startObject("title"); mappingBuilder.field("type", "text"); mappingBuilder.endObject(); mappingBuilder.startObject("content"); mappingBuilder.field("type", "text"); mappingBuilder.endObject(); mappingBuilder.endObject(); mappingBuilder.endObject(); request.mapping(mappingBuilder); // 执行创建索引请求 CreateIndexResponse response = client.indices().create(request, RequestOptions.DEFAULT); // 处理响应结果 if (response.isAcknowledged()) { System.out.println("索引创建成功:" + indexName); } else { System.out.println("索引创建失败:" + indexName); } // 关闭客户端连接 client.close(); } catch (Exception e) { e.printStackTrace(); } } }
- Index Documents
인덱스가 있으면 문서 데이터를 인덱스에 저장할 수 있습니다. 문서는 데이터베이스의 레코드와 유사합니다. 동일한 인덱스 아래에 여러 문서를 저장할 수 있습니다. 다음 코드를 사용하여 문서 데이터를 색인에 저장할 수 있습니다.
import org.elasticsearch.action.index.IndexRequest; import org.elasticsearch.action.index.IndexResponse; import org.elasticsearch.client.RequestOptions; import org.elasticsearch.client.RestHighLevelClient; import org.elasticsearch.common.xcontent.XContentType; public class DocumentIndexer { public static void indexDocument(String indexName, String documentId, String title, String content) { try { RestHighLevelClient client = ElasticsearchClient.createClient(); // 创建文档索引请求 IndexRequest request = new IndexRequest(indexName); request.id(documentId); request.source("title", title); request.source("content", content); // 执行文档索引请求 IndexResponse response = client.index(request, RequestOptions.DEFAULT); // 处理响应结果 if (response.status().getStatus() == 201) { System.out.println("文档索引成功:" + documentId); } else { System.out.println("文档索引失败:" + documentId); } // 关闭客户端连接 client.close(); } catch (Exception e) { e.printStackTrace(); } } }
- 문서 검색
문서 색인을 사용하면 전체 텍스트 검색을 통해 키워드가 포함된 문서를 검색할 수 있습니다. 다음 코드를 사용하여 문서 검색을 수행할 수 있습니다.
import org.elasticsearch.action.search.SearchRequest; import org.elasticsearch.action.search.SearchResponse; import org.elasticsearch.client.RequestOptions; import org.elasticsearch.client.RestHighLevelClient; import org.elasticsearch.index.query.QueryBuilders; import org.elasticsearch.index.query.QueryBuilders.*; import org.elasticsearch.search.builder.SearchSourceBuilder; public class DocumentSearcher { public static void searchDocument(String indexName, String keyword) { try { RestHighLevelClient client = ElasticsearchClient.createClient(); // 创建搜索请求 SearchRequest request = new SearchRequest(indexName); SearchSourceBuilder sourceBuilder = new SearchSourceBuilder(); sourceBuilder.query(QueryBuilders.matchQuery("content", keyword)); request.source(sourceBuilder); // 执行搜索请求 SearchResponse response = client.search(request, RequestOptions.DEFAULT); // 处理响应结果 if (response.getHits().getTotalHits().value > 0) { System.out.println("搜索结果:"); for (SearchHit hit : response.getHits().getHits()) { System.out.println(hit.getSourceAsString()); } } else { System.out.println("未找到相关文档"); } // 关闭客户端连接 client.close(); } catch (Exception e) { e.printStackTrace(); } } }
위의 코드 예제를 사용하여 Elasticsearch 기반의 전체 텍스트 검색 애플리케이션 개발을 완료할 수 있습니다. 색인 생성, 문서 색인화 및 문서 검색을 통해 효율적이고 정확한 전체 텍스트 검색을 달성할 수 있습니다. 물론, Elasticsearch는 위에 표시된 기본 기능 외에도 다양한 고급 쿼리, 집계 분석, 분산 배포 및 기타 기능도 지원하며 특정 요구에 따라 추가로 개발 및 확장될 수 있습니다. 이 기사가 여러분에게 도움이 되기를 바라며, 전체 텍스트 검색 분야에서 여러분의 더 큰 성공을 기원합니다!
위 내용은 Java를 사용하여 Elasticsearch 기반의 전체 텍스트 검색 애플리케이션을 개발하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

드림위버 CS6
시각적 웹 개발 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는
