>  기사  >  백엔드 개발  >  Golang을 사용하여 ES 검색용 애플리케이션을 개발하는 방법

Golang을 사용하여 ES 검색용 애플리케이션을 개발하는 방법

PHPz
PHPz원래의
2023-04-05 14:37:151076검색

인터넷 애플리케이션의 급속한 발전으로 대용량 데이터가 일반화되었으며, 이 데이터의 효율적인 저장 및 조회가 매우 중요해졌습니다. 검색 엔진은 대규모 분산 데이터 저장 환경을 위한 효율적이고 확장 가능한 분산 검색 엔진으로, 텍스트 검색 분야에 중점을 둔 기술입니다.

ElasticSearch(ES)는 Lucene 라이브러리를 기반으로 개발된 검색 엔진으로, 실시간 검색, 데이터 분석 및 기타 기능을 지원할 수 있는 RESTful 아키텍처 기반의 분산형 전체 텍스트 검색 엔진입니다. 오픈 소스 특성과 사용 용이성으로 인해 ElasticSearch는 점점 더 개발자들의 선호를 받고 있습니다. 이 기사에서는 Golang을 사용하여 ES 검색용 애플리케이션을 개발하는 방법을 소개합니다.

먼저 Go 프로그래밍 언어로 ES 클라이언트를 설치해야 합니다. ES 클라이언트는 RESTful 아키텍처를 사용하므로 Go의 HTTP 요청 라이브러리를 사용하여 ES와 상호 작용할 수 있습니다. 그런 다음 ES RESTful API를 호출하여 다음 코드 예제를 참조하여 간단한 검색을 구현할 수 있습니다.

package main

import (
    "encoding/json"
    "fmt"
    "net/http"
    "bytes"
)

type SearchResult struct {
    Hits struct {
        Total int `json:"total"`
        Hits []struct {
            Source interface{} `json:"_source"`
        } `json:"hits"`
    } `json:"hits"`
}

func main() {
    query := "hello"
    url := fmt.Sprintf("http://localhost:9200/_search?q=%s", query)
    resp, _ := http.Get(url)
    defer resp.Body.Close()
    var result SearchResult
    json.NewDecoder(resp.Body).Decode(&result)
    b, _ := json.Marshal(result.Hits.Hits)
    fmt.Println(string(b))
}

먼저 ES 검색 결과를 저장하기 위해 SearchResult라는 구조를 정의합니다. 그런 다음 fmt.Sprintf 함수를 사용하여 검색 URL을 구성하고 http.Get 함수를 통해 ES에 요청을 제출한 후 결과를 구조로 구문 분석했습니다.

마지막으로 결과를 JSON 형식으로 직렬화하고 콘솔에 인쇄합니다. 이런 식으로 우리는 Go 언어를 사용하여 ES의 문서를 매우 간단하게 검색할 수 있습니다.

단, 이 방법은 조건별 검색이나 집계 등 더 풍부한 기능이 필요한 작업에는 ES에서 공식 제공하는 Golang 클라이언트인 go-elasticsearch를 사용해야 합니다.

먼저 공식적으로 제공되는 go-elasticsearch 라이브러리를 설치해야 합니다. 다음 명령을 사용하여 설치할 수 있습니다.

go get github.com/elastic/go-elasticsearch/v8

다음으로 다음 코드 예제를 사용하여 ES 쿼리를 구현합니다.

package main

import (
    "context"
    "fmt"
    "github.com/elastic/go-elasticsearch/v8"
    "github.com/elastic/go-elasticsearch/v8/esapi"
    "encoding/json"
    "bytes"
)

type SearchResult struct {
    Hits struct {
        Total int `json:"total"`
        Hits []struct {
            Source interface{} `json:"_source"`
        } `json:"hits"`
    } `json:"hits"`
}

func main() {
    es, err := elasticsearch.NewDefaultClient()
    if err != nil {
        fmt.Println("Error creating Elasticsearch client:", err)
        return
    }

    query := "hello"

    var buf bytes.Buffer
    queryMap := map[string]interface{}{
        "query": map[string]interface{}{
            "match": map[string]interface{}{
                "message": query,
            },
        },
    }
    if err := json.NewEncoder(&buf).Encode(queryMap); err != nil {
        fmt.Println("Error encoding query:", err)
        return
    }

    req := esapi.SearchRequest{
        Index: []string{"my_index"},
        Body:  &buf,
        Pretty: true,
    }

    res, err := req.Do(context.Background(), es)
    if err != nil {
        fmt.Println("Error searching for documents:", err)
        return
    }
    defer res.Body.Close()

    var result SearchResult
    json.NewDecoder(res.Body).Decode(&result)
    b, _ := json.Marshal(result.Hits.Hits)
    fmt.Println(string(b))
}

먼저 Elasticsearch 클라이언트를 생성한 다음 쿼리 키워드를 정의합니다. 다음으로 쿼리 조건이 포함된 JSON 형식의 맵을 구성하고 json.NewEncoder 함수를 통해 이를 buf로 인코딩합니다.

마지막으로 go-elasticsearch 라이브러리에서 제공하는 ES API를 사용하여 쿼리 요청을 ES로 보내고 요청 응답을 읽고 구문 분석합니다.

go-elasticsearch 라이브러리를 사용하면 복잡한 ES 검색 기능을 쉽게 구현하고 코드를 더욱 우아하고 단순하게 만들 수 있습니다. ES 검색에 Golang을 사용하면 코드 효율성을 유지하면서 검색 속도가 크게 향상됩니다.

간단히 말하면 Golang은 간결하고 효율적인 프로그래밍 언어이며 ES 검색을 구현하는 데 사용하기가 매우 쉽습니다. 이 글이 ES 검색과 go-elasticsearch 라이브러리의 사용법을 이해하는 데 도움이 되기를 바랍니다.

위 내용은 Golang을 사용하여 ES 검색용 애플리케이션을 개발하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.