"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Java 고급 REST 클라이언트로 Elasticsearch 경험 향상()

Java 고급 REST 클라이언트로 Elasticsearch 경험 향상()

2024-08-01에 게시됨
검색:696

Elevate Your Elasticsearch Experience with Java High Level REST Client ()

소개

Java 고급 REST 클라이언트(7.x)는 Elasticsearch 클러스터와 상호 작용하기 위한 강력한 도구로, 서버 통신에 더 쉽게 접근하고 효율적으로 만들어줍니다. 이 가이드에서는 고급 REST 클라이언트를 사용하여 Alibaba Cloud Elasticsearch 클러스터에서 Elasticsearch Java API를 호출하는 단계를 안내합니다.

준비

1단계: Elasticsearch 클러스터 생성

클러스터 버전이 사용하려는 Java High Level REST 클라이언트 버전과 같거나 최신인지 확인하세요. 단계별 지침은 Alibaba Cloud Elasticsearch 클러스터 생성을 참조하세요.

2단계: 자동 인덱싱 활성화

YAML 구성 파일에서 자동 색인 기능을 활성화합니다. 자세한 내용은 YML 파일 구성을 참조하세요.

3단계: IP 주소 화이트리스트 구성

IP 주소 화이트리스트를 구성하여 적절한 통신을 보장하세요. 인터넷을 통해 클러스터에 액세스하는 경우 공용 또는 개인 IP 주소 허용 목록 구성의 지침에 따라 필수 IP 주소의 요청을 허용합니다.

4단계: JDK 설치

JDK(Java Development Kit) 버전 1.8 이상을 설치합니다. 자세한 내용은 JDK 설치를 참조하세요.

5단계: Java Maven 프로젝트 생성

pom.xml 파일에 필요한 종속성을 추가합니다. 종속성의 버전 번호를 7.x에서 사용 중인 상위 수준 REST 클라이언트의 특정 버전으로 변경합니다.


    org.elasticsearch.client
    elasticsearch-rest-high-level-client
    7.x


    org.apache.logging.log4j
    log4j-core
    2.20.0


    org.apache.logging.log4j
    log4j-api
    2.20.0

예: 인덱스 관리

아래는 High Level REST Client를 이용하여 인덱스를 생성하고 삭제하는 예이다. 자리표시자 {}를 특정 매개변수로 바꾸세요.

import org.apache.http.HttpHost;
import org.apache.http.auth.AuthScope;
import org.apache.http.auth.UsernamePasswordCredentials;
import org.apache.http.client.CredentialsProvider;
import org.apache.http.impl.client.BasicCredentialsProvider;
import org.apache.http.impl.nio.client.HttpAsyncClientBuilder;
import org.elasticsearch.action.delete.DeleteRequest;
import org.elasticsearch.action.delete.DeleteResponse;
import org.elasticsearch.action.index.IndexRequest;
import org.elasticsearch.action.index.IndexResponse;
import org.elasticsearch.client.*;

import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

public class RestClientExample {
    private static final RequestOptions COMMON_OPTIONS;

    static {
        RequestOptions.Builder builder = RequestOptions.DEFAULT.toBuilder();
        builder.setHttpAsyncResponseConsumerFactory(
                new HttpAsyncResponseConsumerFactory
                        .HeapBufferedResponseConsumerFactory(30 * 1024 * 1024));
        COMMON_OPTIONS = builder.build();
    }

    public static void main(String[] args) {
        final CredentialsProvider credentialsProvider = new BasicCredentialsProvider();
        credentialsProvider.setCredentials(AuthScope.ANY, 
            new UsernamePasswordCredentials("{Username}", "{Password}"));

        RestClientBuilder builder = RestClient.builder(new HttpHost("{Endpoint of the Elasticsearch cluster}", 9200, "http"))
                .setHttpClientConfigCallback(new RestClientBuilder.HttpClientConfigCallback() {
                    @Override
                    public HttpAsyncClientBuilder customizeHttpClient(HttpAsyncClientBuilder httpClientBuilder) {
                        return httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);
                    }
                });

        RestHighLevelClient highClient = new RestHighLevelClient(builder);

        try {
            Map jsonMap = new HashMap();
            jsonMap.put("{field_01}", "{value_01}");
            jsonMap.put("{field_02}", "{value_02}");

            IndexRequest indexRequest = new IndexRequest("{index_name}", "_doc", "{doc_id}").source(jsonMap);
            IndexResponse indexResponse = highClient.index(indexRequest, COMMON_OPTIONS);
            long version = indexResponse.getVersion();
            System.out.println("Index document successfully! "   version);

            DeleteRequest deleteRequest = new DeleteRequest("{index_name}", "_doc", "{doc_id}");
            DeleteResponse deleteResponse = highClient.delete(deleteRequest, COMMON_OPTIONS);
            System.out.println("Delete document successfully! \n"   deleteResponse.toString());

            highClient.close();
        } catch (IOException ioException) {
            ioException.printStackTrace();
        }
    }
}

높은 동시성 구성

동시성이 높은 시나리오의 경우 클라이언트 연결 수를 늘리십시오.

httpClientBuilder.setMaxConnTotal(500);
httpClientBuilder.setMaxConnPerRoute(300);

샘플 코드 조각:

String host = "127.0.0.1";
int port = 9200;
String username = "elastic";
String password = "passwd";
final int max_conn_total = 500;
final int max_conn_per_route = 300;

RestHighLevelClient restHighLevelClient = new RestHighLevelClient(
  RestClient.builder(new HttpHost(host, port, "http")).setHttpClientConfigCallback(new RestClientBuilder.HttpClientConfigCallback() {
    public HttpAsyncClientBuilder customizeHttpClient(HttpAsyncClientBuilder httpClientBuilder) {
      httpClientBuilder.setMaxConnTotal(max_conn_total);
      httpClientBuilder.setMaxConnPerRoute(max_conn_per_route);
      return httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);
    }
  })
);

기능 및 구성에 대한 자세한 내용은 공식 Java High Level REST 클라이언트 설명서를 참조하세요.

결론

Java 고급 REST 클라이언트를 사용하면 Alibaba Cloud Elasticsearch 클러스터와의 효율적인 상호 작용이 보장됩니다. Elasticsearch 설정을 최대한 활용하려면 이 가이드를 따르세요.
Alibaba Cloud에서 Elasticsearch와 함께 여정을 시작할 준비가 되셨나요? 귀하의 데이터를 시각적 걸작으로 변환하는 맞춤형 클라우드 솔루션과 서비스를 살펴보세요.

30일 무료 평가판을 시작하려면 여기를 클릭하세요.

릴리스 선언문 이 기사는 https://dev.to/a_lucas/elevate-your-elasticsearch-experience-with-java-high-level-rest-client-7x-348k?1에서 복제됩니다.1 침해가 있는 경우에는 Study_golang에 문의하세요. @163.com 삭제
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3