Workerman에서 데이터 저장 및 검색을 위해 ElasticSearch를 사용하는 방법
웹 개발에 있어서 데이터 저장과 검색은 매우 중요한 부분입니다. ElasticSearch는 데이터 검색 및 분석에 널리 사용되는 오픈 소스 분산 검색 엔진입니다. 대용량 데이터를 처리할 수 있으며 효율적인 검색 및 집계 기능을 제공합니다. Workerman은 실시간 통신, 온라인 게임, 높은 동시성 웹 서비스와 같은 애플리케이션 개발에 적합한 고성능 PHP 소켓 프레임워크입니다. 이번 글에서는 Workerman에서 데이터 저장 및 검색을 위해 ElasticSearch를 활용하는 방법을 소개하겠습니다.
- ElasticSearch 설치 및 구성
시작하기 전에 ElasticSearch를 설치하고 구성해야 합니다. ElasticSearch 공식 홈페이지 https://www.elastic.co/downloads/elasticsearch 에서 최신 설치 패키지를 다운로드 하신 후 운영체제 종류에 맞게 설치하시면 됩니다. 설치가 완료되면 다음 명령을 사용하여 ElasticSearch를 시작할 수 있습니다.
$ cd elasticsearch/bin $ ./elasticsearch
동시에 리스닝 포트, 클러스터 이름 및 데이터 저장소 설정과 같은 config/elasticsearch.yml 파일에서 ElasticSearch를 구성할 수도 있습니다. 길.
- Workerman 설치 및 구성
Workerman을 사용하기 전에 먼저 Workerman을 설치하고 구성해야 합니다. Workerman은 터미널에 다음 명령을 입력하여 설치할 수 있습니다.
$ composer require workerman/workerman
설치가 완료되면 PHP 스크립트 파일을 만들고 여기에 Workerman의 Autoloader 클래스를 도입한 다음 Workerman을 시작하려면 다음 코드를 추가해야 합니다.
require_once __DIR__ . '/vendor/autoload.php'; use WorkermanWorker; $worker = new Worker(); $worker->count = 4; $worker->onWorkerStart = function($worker){ // do something }; Worker::runAll();
위 코드에서는 Worker 객체를 생성하고 프로세스 수를 4로 설정했습니다. 동시에 onWorkerStart 콜백 함수를 통해 Worker 프로세스가 시작될 때의 동작도 정의합니다.
- ElasticSearch에서 데이터 추가, 삭제, 확인 및 수정
Workerman에서 데이터 저장 및 검색을 위해 ElasticSearch를 사용할 때 ElasticSearch에서 데이터의 추가, 삭제, 확인 및 수정 작업을 마스터해야 합니다.
a. 데이터 생성
ElasticSearch에서는 지정된 인덱스 및 문서 유형에 대한 HTTP PUT 요청을 통해 데이터 생성이 수행됩니다.
curl -XPUT http://localhost:9200/{index}/{type}/{id} -d '{ "title":"ElasticSearch tutorial", "tags":["search","elasticsearch"], "body":"ElasticSearch is a powerful search engine." }'
물론, PHP 코드를 사용하여 데이터 생성을 완료할 수도 있습니다:
$client = ElasticsearchClientBuilder::create()->build(); $params = [ 'index' => 'my_index', 'type' => 'my_type', 'id' => 'my_id', 'body' => [ 'title' => 'ElasticSearch tutorial', 'tags' => ['search', 'elasticsearch'], 'body' => 'ElasticSearch is a powerful search engine.' ] ]; $response = $client->index($params);
b. 데이터 쿼리
ElasticSearch에서 데이터 쿼리는 정밀 쿼리와 퍼지 쿼리의 두 가지 방법으로 나뉩니다. 그 중 정밀 질의는 필드와 값을 지정하여 데이터를 찾는 것을 말하고, 퍼지 질의는 퍼지 매칭을 통해 데이터를 찾는 것을 말한다. 데이터 쿼리를 완료하려면 다음 코드를 사용할 수 있습니다.
// 精确查询 $client = ElasticsearchClientBuilder::create()->build(); $params = [ 'index' => 'my_index', 'type' => 'my_type', 'body' => [ 'query' => [ 'match' => [ 'title' => 'ElasticSearch tutorial' ] ] ] ]; $response = $client->search($params); // 模糊查询 $client = ElasticsearchClientBuilder::create()->build(); $params = [ 'index' => 'my_index', 'type' => 'my_type', 'body' => [ 'query' => [ 'wildcard' => [ 'title' => '*search*' ] ] ] ]; $response = $client->search($params);
c. 데이터 업데이트
ElasticSearch에서는 지정된 인덱스 및 문서 유형에 대한 HTTP POST 요청을 통해 데이터 업데이트 작업이 완료됩니다. :
curl -XPOST http://localhost:9200/{index}/{type}/{id}/_update -d '{ "doc":{ "title":"New ElasticSearch tutorial" } }'
물론, PHP 코드를 사용하여 데이터 업데이트를 완료할 수도 있습니다:
$client = ElasticsearchClientBuilder::create()->build(); $params = [ 'index' => 'my_index', 'type' => 'my_type', 'id' => 'my_id', 'body' => [ 'doc' => [ 'title' => 'New ElasticSearch tutorial' ] ] ]; $response = $client->update($params);
d 데이터 삭제
ElasticSearch에서 데이터 삭제는 HTTP DELETE 요청을 통해 완료됩니다. 지정된 인덱스 및 문서 유형에 따라 다음 코드를 사용하여 데이터를 삭제할 수 있습니다.
curl -XDELETE http://localhost:9200/{index}/{type}/{id}
물론 PHP 코드를 사용하여 데이터 삭제를 완료할 수도 있습니다.
$client = ElasticsearchClientBuilder::create()->build(); $params = [ 'index' => 'my_index', 'type' => 'my_type', 'id' => 'my_id' ]; $response = $client->delete($params);
- Workerman의 ElasticSearch 예제
위를 통해 ElasticSearch에서 데이터를 삭제하는 과정을 마스터했으며, 데이터 저장 및 검색의 기본 작업을 마스터했습니다. 다음으로 Workerman에서 데이터 저장 및 검색을 위해 ElasticSearch를 사용하는 예제를 구현하겠습니다. 구체적인 코드는 다음과 같습니다.
require_once __DIR__ . '/vendor/autoload.php'; use WorkermanWorker; use ElasticsearchClientBuilder; // 创建一个Worker对象 $worker = new Worker(); $worker->count = 4; // 启动一个ElasticSearch客户端 $client = ClientBuilder::create()->build(); // 处理连接请求 $worker->onConnect = function($connection) { echo "New connection from " . $connection->getRemoteIp() . PHP_EOL; }; // 处理数据请求 $worker->onMessage = function($connection, $data) use($client) { $params = [ 'index' => 'my_index', 'type' => 'my_type', 'body' => [ 'query' => [ 'wildcard' => [ 'title' => '*' . $data . '*' ] ] ] ]; // 从ElasticSearch检索数据 $response = $client->search($params); // 处理检索结果 $hits = $response['hits']['hits']; if(count($hits) > 0) { $result = 'Results:' . PHP_EOL; foreach($hits as $hit) { $result .= $hit['_source']['title'] . PHP_EOL; } } else { $result = 'No results found.' . PHP_EOL; } // 发送结果给客户端 $connection->send($result); }; Worker::runAll();
위 코드에서는 먼저 ElasticSearch 클라이언트를 시작하고 연결 및 데이터를 처리하는 Worker 객체를 생성합니다. 요청. 클라이언트가 연결하여 데이터 요청을 받으면 ElasticSearch에서 데이터를 검색하고 결과를 클라이언트에 보냅니다.
- 요약
이 글에서는 Workerman에서 데이터 저장 및 검색을 위해 ElasticSearch를 사용하는 방법을 소개합니다. ElasticSearch의 데이터 추가, 삭제, 쿼리 및 수정 작업을 마스터함으로써 웹 애플리케이션에서 데이터를 빠르게 저장하고 검색할 수 있습니다. 동시에 위의 작업을 더 잘 이해하고 적용하기 위해 Workerman에 간단한 ElasticSearch 애플리케이션도 구현했습니다.
위 내용은 Workerman에서 데이터 저장 및 검색을 위해 ElasticSearch를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

Workerman의 WebSocket 클라이언트는 비동기 통신, 고성능, 확장 성 및 보안과 같은 기능으로 실시간 통신을 향상시켜 기존 시스템과 쉽게 통합합니다.

이 기사는 고성능 PHP 서버 인 Workerman을 사용하여 실시간 협업 도구를 구축하는 것에 대해 설명합니다. 설치, 서버 설정, 실시간 기능 구현 및 기존 시스템과의 통합을 포함하여 Workerman의 키 F를 강조합니다.

이 기사는 비동기 프로그래밍, 네트워크 구성, 리소스 관리, 데이터 전송 최소화,로드 밸런싱 및 정기적 인 업데이트에 중점을 둔 저지성 응용 프로그램에 대한 Workerman 최적화에 대해 논의합니다.

이 기사에서는 Workerman 및 MySQL을 사용하여 실시간 데이터 동기화 구현, 설정, 모범 사례, 데이터 일관성 보장 및 일반적인 문제 해결에 중점을 둡니다.

이 기사에서는 Workerman을 서버리스 아키텍처에 통합하여 확장 성, 무국적, 냉장 시작, 자원 관리 및 통합 복잡성에 중점을 둡니다. Workerman은 동시성이 높은 냉간 STA를 통해 성능을 향상시킵니다

이 기사는 Websocket 지원 및 확장 성과 같은 기능에 중점을 두어 실시간 상호 작용 및 효율성을 향상시키는 Workerman을 사용하여 고성능 전자 상거래 플랫폼을 구축하는 것에 대해 설명합니다.

Workerman의 WebSocket 서버는 일반적인 위협에 대한 확장 성, 낮은 대기 시간 및 보안 측정과 같은 기능으로 실시간 통신을 향상시킵니다.

이 기사는 고성능 PHP 서버 인 Workerman을 사용하여 실시간 분석 대시 보드를 구축하는 것에 대해 설명합니다. React, Vue.js 및 Angular와 같은 프레임 워크와의 설치, 서버 설정, 데이터 처리 및 프론트 엔드 통합을 다룹니다. 주요 특징


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

WebStorm Mac 버전
유용한 JavaScript 개발 도구

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기
