PHP 프레임워크 ThinkPHP ThinkPHP6 및 Swoole로 구축된 RPC 서비스를 사용하여 고가용성 작업 대기열 구현

ThinkPHP6 및 Swoole로 구축된 RPC 서비스를 사용하여 고가용성 작업 대기열 구현

Oct 12, 2023 pm 02:39 PM
thinkphp RPC 서비스 swoole

ThinkPHP6 및 Swoole로 구축된 RPC 서비스를 사용하여 고가용성 작업 대기열 구현

ThinkPHP6 및 Swoole로 구축된 RPC 서비스를 사용하여 고가용성 작업 대기열 구현

[소개]
작업 대기열은 현대 개발에서 시간이 많이 걸리는 작업을 주요 프로세스에서 분리하고 응답을 개선할 수 있는 중요한 역할을 합니다. 시스템 속도는 시스템 장애나 네트워크 중단 시 작업의 신뢰성과 고가용성을 보장할 수 있습니다. 이 기사에서는 ThinkPHP6 및 Swoole을 사용하여 비동기 작업 처리를 구현하는 고가용성 작업 대기열을 구축하는 동시에 작업 대기열 관리를 위한 RPC 서비스를 제공하는 방법을 소개합니다.

【환경 준비】
시작하기 전에 다음을 포함한 몇 가지 개발 환경을 준비해야 합니다.

  1. PHP 환경에서는 PHP 7.4 이상을 사용하는 것이 좋습니다.
  2. 컴포저를 설치하여 프로젝트 종속성을 관리합니다. 작업 관련 정보를 저장하는 데 사용되는 데이터베이스
  3. 작업 대기열의 실시간 알림 및 모니터링을 구현하는 데 사용되는 Redis 설치
  4. 고성능 RPC 서비스 및 비동기 작업 처리를 구현하는 데 사용되는 Swoole 확장 프로그램 설치.
  5. 【프로젝트 구성】

프로젝트 만들기
    Composer를 사용하여 새로운 ThinkPHP6 프로젝트를 만듭니다.

  1. composer create-project topthink/think hello-think
    로그인 후 복사
종속성 추가
    프로젝트 루트 디렉터리의 작곡가.json 파일에 Swoole 및 Swoole-ide-helper의 종속성을 추가합니다.

  1. "require": {
        "swoole/swoole": "4.6.7",
        "swoole/ide-helper": "4.6.7"
    }
    로그인 후 복사
  2. 그런 다음
명령을 실행하여 종속성을 설치합니다.

composer update

Swoole의 RPC 서비스 및 예약된 작업 구성
    프로젝트 루트 디렉터리 아래의 config 디렉터리에 swoole.php 구성 파일을 생성하고 다음 콘텐츠를 추가하세요.

  1. return [
        'rpc' => [
            'listen_ip' => '0.0.0.0',
            'listen_port' => 9501,
            'worker_num' => 4,
            'task_worker_num' => 4,
        ],
        'task' => [
            'task_ip' => '127.0.0.1',
            'task_port' => 9502,
        ],
        'timer' => [
            'interval' => 1000,
        ],
    ];
    로그인 후 복사
RPC 서버 생성
    앱 디렉터리에 생성 프로젝트의 rpc 디렉터리를 만들고 rpc 디렉터리에 서버 디렉터리를 만듭니다. 그런 다음 TaskServer.php 파일을 생성하고 다음 내용을 추가합니다.

  1. namespace apppcserver;
    
    use SwooleServer;
    use thinkRpcServer;
    use thinkacadeConfig;
    
    class TaskServer
    {
        protected $server;
    
        public function start()
        {
            $this->server = new Server(Config::get('swoole.rpc.listen_ip'), Config::get('swoole.rpc.listen_port'));
    
            $rpcServer = new RpcServer($this->server);
    
            $rpcServer->classMap([
                'apppcserviceTaskService',
            ]);
    
            $rpcServer->start();
        }
      
    }
    로그인 후 복사
RPC 서비스 생성
    rpc 디렉토리에 서비스 디렉토리를 생성하고 서비스 디렉토리에 TaskService.php 파일을 생성합니다. TaskService.php 파일에서는 addTask 및 getTask와 같은 특정 RPC 메소드를 정의합니다.

  1. namespace apppcservice;
    
    class TaskService
    {
        public function addTask($data)
        {
            // 处理添加任务的逻辑,将任务添加到任务队列中
        }
    
        public function getTask($id)
        {
            // 处理获取任务的逻辑,从任务队列中获取相关任务信息
        }
    
        // 其他RPC方法...
    }
    로그인 후 복사
  2. [작업 큐 구현]

작업 대기열 테이블 생성
    작업 관련 정보를 저장하기 위해 MySQL 데이터베이스에 작업 테이블을 생성합니다.

  1. CREATE TABLE `task` (
      `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
      `task_name` varchar(255) DEFAULT NULL,
      `task_data` text,
      `task_status` tinyint(1) DEFAULT NULL,
      `create_time` int(11) DEFAULT NULL,
      `update_time` int(11) DEFAULT NULL,
      PRIMARY KEY (`id`),
      KEY `task_status` (`task_status`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
    로그인 후 복사
작업 모델 만들기
    appmodel 디렉터리에 Task.php 파일을 만들고 다음 콘텐츠를 추가합니다.

  1. namespace appmodel;
    
    use thinkModel;
    
    class Task extends Model
    {
        protected $autoWriteTimestamp = true;
        protected $dateFormat = 'Y-m-d H:i:s';
    }
    로그인 후 복사
작업 처리 로직 만들기
    appservice 디렉터리에 TaskService.php 파일을 만들고 다음 콘텐츠를 추가합니다. :

  1. namespace appservice;
    
    use appmodelTask;
    
    class TaskService
    {
        public function addTask($data)
        {
            $task = new Task;
            $task->task_name = $data['task_name'];
            $task->task_data = $data['task_data'];
            $task->task_status = 0;
            $task->save();
    
            // TODO: 将任务添加到任务队列中
        }
    
        public function getTask($id)
        {
            return Task::find($id);
        }
    
        // 其他任务处理逻辑...
    }
    로그인 후 복사
RPC 서버는 작업 처리 로직을 호출합니다
    TaskService.php의 addTask 메소드에서는 데이터베이스에 작업을 저장한 후 작업 큐에 작업을 추가하는 등의 작업을 추가하는 로직을 처리하겠습니다.

  1. [예약된 작업 구현]

예약된 작업 처리 로직 만들기
    appservice 디렉터리에 TimerService.php 파일을 만들고 다음 내용을 추가하세요.

  1. namespace appservice;
    
    use appmodelTask;
    use SwooleTimer;
    
    class TimerService
    {
        public function start()
        {
            Timer::tick(config('swoole.timer.interval'), function() {
                // TODO: 定时检查任务队列,处理待执行的任务
            });
        }
      
        // 其他定时任务处理逻辑...
    }
    로그인 후 복사
TaskServer.php에 예약된 작업 추가
    TaskServer In .php의 시작 메소드에 예약된 작업의 시작 로직을 추가합니다.

  1. public function start()
    {
        $this->server = new Server(Config::get('swoole.rpc.listen_ip'), Config::get('swoole.rpc.listen_port'));
    
        $rpcServer = new RpcServer($this->server);
    
        $rpcServer->classMap([
            'apppcserviceTaskService',
        ]);
    
        $timerService = new TimerService();
        $timerService->start();
    
        $rpcServer->start();
    }
    로그인 후 복사
  2. 【RPC 서비스 및 작업 큐 시작】
프로젝트 루트 디렉터리에서 다음 명령을 실행하여 RPC 서비스 및 작업 큐를 시작합니다.

php think swoole:rpc start
로그인 후 복사

【RPC 호출 예시】

응용 프로그램에서 RPC를 사용하여 작업 대기열을 호출하는 예시입니다.

class Index extends Controller
{
    public function index()
    {
        $taskService = new pppcserviceTaskService();
        $taskService->addTask([
            'task_name' => '任务名称',
            'task_data' => '任务数据',
        ]);
    }
}
로그인 후 복사

【요약】ThinkPHP6 및 Swoole 확장을 사용하여 가용성이 높은 작업 대기열 시스템을 구축할 수 있습니다. RPC 서비스를 사용하여 작업 대기열을 관리하고, 작업 추가 및 가져오기를 위한 인터페이스를 제공하고, 작업의 비동기 처리를 실현하고, 시스템의 응답 속도와 가용성을 향상시킵니다. 동시에 Swoole의 예약된 작업 기능을 사용하면 정기적으로 작업 대기열을 확인하고 대기 중인 작업을 적시에 처리할 수 있습니다. 이러한 시스템 아키텍처는 시스템의 처리 능력을 향상시킬 수 있을 뿐만 아니라 확장성과 내결함성도 우수합니다.

위 내용은 ThinkPHP6 및 Swoole로 구축된 RPC 서비스를 사용하여 고가용성 작업 대기열 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

thinkphp 프로젝트를 실행하는 방법 thinkphp 프로젝트를 실행하는 방법 Apr 09, 2024 pm 05:33 PM

ThinkPHP 프로젝트를 실행하려면 다음이 필요합니다: Composer를 설치하고, 프로젝트 디렉터리를 입력하고 php bin/console을 실행하고, 시작 페이지를 보려면 http://localhost:8000을 방문하세요.

thinkphp에는 여러 버전이 있습니다. thinkphp에는 여러 버전이 있습니다. Apr 09, 2024 pm 06:09 PM

ThinkPHP에는 다양한 PHP 버전용으로 설계된 여러 버전이 있습니다. 메이저 버전에는 3.2, 5.0, 5.1, 6.0이 포함되며, 마이너 버전은 버그를 수정하고 새로운 기능을 제공하는 데 사용됩니다. 최신 안정 버전은 ThinkPHP 6.0.16입니다. 버전을 선택할 때 PHP 버전, 기능 요구 사항 및 커뮤니티 지원을 고려하십시오. 최상의 성능과 지원을 위해서는 최신 안정 버전을 사용하는 것이 좋습니다.

thinkphp를 실행하는 방법 thinkphp를 실행하는 방법 Apr 09, 2024 pm 05:39 PM

ThinkPHP Framework를 로컬에서 실행하는 단계: ThinkPHP Framework를 로컬 디렉터리에 다운로드하고 압축을 풉니다. ThinkPHP 루트 디렉터리를 가리키는 가상 호스트(선택 사항)를 만듭니다. 데이터베이스 연결 매개변수를 구성합니다. 웹 서버를 시작합니다. ThinkPHP 애플리케이션을 초기화합니다. ThinkPHP 애플리케이션 URL에 접속하여 실행하세요.

Laravel에서 Swoole 코루틴을 사용하는 방법 Laravel에서 Swoole 코루틴을 사용하는 방법 Apr 09, 2024 pm 06:48 PM

Laravel에서 Swoole 코루틴을 사용하면 많은 수의 요청을 동시에 처리할 수 있습니다. 장점은 다음과 같습니다. 동시 처리: 여러 요청을 동시에 처리할 수 있습니다. 고성능: Linux epoll 이벤트 메커니즘을 기반으로 요청을 효율적으로 처리합니다. 낮은 리소스 소비: 더 적은 서버 리소스가 필요합니다. 간편한 통합: Laravel 프레임워크와 원활하게 통합되어 사용이 간편합니다.

laravel과 thinkphp 중 어느 것이 더 낫나요? laravel과 thinkphp 중 어느 것이 더 낫나요? Apr 09, 2024 pm 03:18 PM

Laravel과 ThinkPHP 프레임워크의 성능 비교: ThinkPHP는 일반적으로 최적화 및 캐싱에 중점을 두고 Laravel보다 성능이 좋습니다. Laravel은 잘 작동하지만 복잡한 애플리케이션의 경우 ThinkPHP가 더 적합할 수 있습니다.

개발 제안: ThinkPHP 프레임워크를 사용하여 비동기 작업을 구현하는 방법 개발 제안: ThinkPHP 프레임워크를 사용하여 비동기 작업을 구현하는 방법 Nov 22, 2023 pm 12:01 PM

"개발 제안: ThinkPHP 프레임워크를 사용하여 비동기 작업을 구현하는 방법" 인터넷 기술의 급속한 발전으로 인해 웹 응용 프로그램은 많은 수의 동시 요청과 복잡한 비즈니스 논리를 처리하기 위한 요구 사항이 점점 더 높아졌습니다. 시스템 성능과 사용자 경험을 향상시키기 위해 개발자는 이메일 보내기, 파일 업로드 처리, 보고서 생성 등과 같이 시간이 많이 걸리는 작업을 수행하기 위해 비동기 작업을 사용하는 것을 종종 고려합니다. PHP 분야에서 널리 사용되는 개발 프레임워크인 ThinkPHP 프레임워크는 비동기 작업을 구현하는 몇 가지 편리한 방법을 제공합니다.

스울과 워커맨 중 어느 것이 더 낫나요? 스울과 워커맨 중 어느 것이 더 낫나요? Apr 09, 2024 pm 07:00 PM

Swoole과 Workerman은 모두 고성능 PHP 서버 프레임워크입니다. 비동기 처리, 우수한 성능 및 확장성으로 잘 알려진 Swoole은 많은 수의 동시 요청과 높은 처리량을 처리해야 하는 프로젝트에 적합합니다. Workerman은 사용 편의성과 낮은 동시성 볼륨을 처리하는 프로젝트에 더 적합한 직관적인 API를 통해 비동기식 및 동기식 모드의 유연성을 제공합니다.

swoole_process를 사용하면 사용자가 어떻게 전환할 수 있나요? swoole_process를 사용하면 사용자가 어떻게 전환할 수 있나요? Apr 09, 2024 pm 06:21 PM

Swoole 프로세스를 통해 사용자는 프로세스를 생성하고 프로세스를 시작할 수 있습니다.

See all articles