>백엔드 개발 >PHP 튜토리얼 >PHP에서 Elasticsearch를 사용하여 분산 검색 엔진 구현

PHP에서 Elasticsearch를 사용하여 분산 검색 엔진 구현

WBOY
WBOY원래의
2023-10-03 09:01:511414검색

PHP 中使用 Elasticsearch 实现分布式搜索引擎

PHP에서 Elasticsearch를 사용하여 분산 검색 엔진 구현

소개:
분산 검색 엔진은 빠른 전체 텍스트 검색, 효율적인 데이터 검색 및 정렬을 달성할 수 있는 현대 인터넷 애플리케이션의 매우 중요한 부분입니다. Elasticsearch는 Lucene 기반의 오픈 소스 분산 검색 엔진으로, 강력한 검색 및 분석 기능을 제공합니다. 이 기사에서는 PHP에서 Elasticsearch를 사용하여 간단한 분산 검색 엔진을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다.

전제 조건:
시작하기 전에 Elasticsearch 및 PHP 환경을 설치하고 Elasticsearch에 성공적으로 연결했는지 확인하세요. Elasticsearch 공식 홈페이지(https://www.elastic.co/downloads/elasticsearch)를 통해 Elasticsearch를 다운로드하여 설치하실 수 있으며, Composer(https://www.elastic.co/guide/)를 통해 Elasticsearch의 PHP 클라이언트를 설치하실 수 있습니다. en /elasticsearch/client/php-api/current/introduction.html#_installation_2).

예제 배경:
시스템에 여러 블로그 게시물과 태그가 있는 블로그 시스템이 있다고 가정해 보겠습니다. 우리는 블로그 게시물을 키워드로 검색하고 관련성을 기준으로 정렬할 수 있기를 원합니다. 우리는 Elasticsearch를 사용하여 블로그 기사의 전체 텍스트 검색 및 정렬을 구현하는 간단한 분산 검색 엔진을 구축합니다.

샘플 코드:
다음은 Elasticsearch의 PHP 클라이언트를 사용하여 분산 검색 엔진을 구현하는 방법을 보여주는 간단한 샘플 코드입니다.

<?php
require 'vendor/autoload.php';

// 设置Elasticsearch的连接信息
$hosts = [
    [
        'host' => 'localhost',
        'port' => 9200,
        'scheme' => 'http',
        'user' => 'username', // 可选的用户名
        'pass' => 'password' // 可选的密码
    ]
];

// 创建Elasticsearch客户端
$client = ElasticsearchClientBuilder::create()
            ->setHosts($hosts)
            ->build();

// 创建索引(博客文章)
$params = [
    'index' => 'blog',
    'body' => [
        'settings' => [
            'number_of_shards' => 2, // 分片数
            'number_of_replicas' => 1 // 副本数
        ],
        'mappings' => [
            'properties' => [
                'title' => [
                    'type' => 'text',
                    'analyzer' => 'standard'
                ],
                'content' => [
                    'type' => 'text',
                    'analyzer' => 'standard'
                ],
                'tags' => [
                    'type' => 'keyword'
                ]
            ]
        ]
    ]
];

$response = $client->indices()->create($params);

// 添加文档(博客文章)
$params = [
    'index' => 'blog',
    'id' => 1,
    'body' => [
        'title' => 'PHP入门教程',
        'content' => '这是一篇PHP入门教程的示例文章。',
        'tags' => ['PHP', '教程']
    ]
];

$response = $client->index($params);

// 搜索文档(博客文章)
$params = [
    'index' => 'blog',
    'body' => [
        'query' => [
            'match' => [
                'content' => 'PHP'
            ]
        ],
        'sort' => [
            '_score' => 'desc'
        ]
    ]
];

$response = $client->search($params);

// 解析搜索结果
foreach ($response['hits']['hits'] as $hit) {
    $source = $hit['_source'];
    echo '文章标题:' . $source['title'] . '<br>';
    echo '文章内容:' . $source['content'] . '<br>';
    echo '相关标签:' . implode(', ', $source['tags']) . '<br>';
    echo '<hr>';
}
?>

요약:
이 문서에서는 PHP 검색 엔진에서 Elasticsearch를 사용하여 간단한 배포를 구현하는 방법을 설명합니다. 이 예제를 통해 인덱스 생성, 문서 추가, 문서 검색, 검색 결과 구문 분석 등 Elasticsearch의 기본 작업을 배웠습니다. 실제 애플리케이션에서는 필요에 따라 사용자 지정 분석기, 필터, 집계 등 더 복잡한 작업을 수행할 수 있습니다. 이 기사가 여러분에게 도움이 되기를 바라며 Elasticsearch를 더 깊이 배우고 적용하는 데 영감을 주기를 바랍니다.

위 내용은 PHP에서 Elasticsearch를 사용하여 분산 검색 엔진 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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